fluent-plugin-memcached 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.gitignore +9 -0
- data/.travis.yml +10 -0
- data/Gemfile +4 -0
- data/README.md +33 -0
- data/Rakefile +9 -0
- data/fluent-plugin-memcached.gemspec +24 -0
- data/lib/fluent/plugin/out_memcached.rb +38 -0
- data/test/plugin/test_out_memcached.rb +47 -0
- metadata +109 -0
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA1:
|
3
|
+
metadata.gz: 45e1f9f3477cfebeabd1eaa93d089445ed9d6c51
|
4
|
+
data.tar.gz: 53e4d63689483090a6429b2583332efa2a4186cd
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: 3f0527d453d22f515314b911800cde070c4b28e93a2905ecfee71a29b9ea9c5bf69ccdbd8f2195ed43c13e114d2722105c92a0e1026fd343e226bccc605304cf
|
7
|
+
data.tar.gz: dabaaa0ceef0624087dfbaadd307a1521538bce52bddfb403dfa946032193fe599527786575c91ecf974c8e483312c81f531792ea2893a8575324eb46135631c
|
data/.gitignore
ADDED
data/.travis.yml
ADDED
data/Gemfile
ADDED
data/README.md
ADDED
@@ -0,0 +1,33 @@
|
|
1
|
+
# Fluent::Plugin::Memcached, a plugin for [Fluentd](http://www.fluentd.org)
|
2
|
+
|
3
|
+
[](https://travis-ci.org/innossh/fluent-plugin-memcached)
|
4
|
+
|
5
|
+
Send your logs to Memcached.
|
6
|
+
|
7
|
+
## Installation
|
8
|
+
|
9
|
+
```sh
|
10
|
+
$ gem install fluent-plugin-memcached
|
11
|
+
```
|
12
|
+
|
13
|
+
## Usage
|
14
|
+
|
15
|
+
In your Fluentd configuration, use `type memcached`.
|
16
|
+
Default values would look like this:
|
17
|
+
|
18
|
+
```
|
19
|
+
<match dummy>
|
20
|
+
type memcached
|
21
|
+
host localhost
|
22
|
+
port 11211
|
23
|
+
</match>
|
24
|
+
```
|
25
|
+
|
26
|
+
## Contributing
|
27
|
+
|
28
|
+
Bug reports and pull requests are welcome.
|
29
|
+
|
30
|
+
## License
|
31
|
+
|
32
|
+
- Copyright (c) 2015 innossh
|
33
|
+
- [Apache License, Version 2.0](http://www.apache.org/licenses/LICENSE-2.0)
|
data/Rakefile
ADDED
@@ -0,0 +1,24 @@
|
|
1
|
+
# coding: utf-8
|
2
|
+
lib = File.expand_path('../lib', __FILE__)
|
3
|
+
$LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
|
4
|
+
|
5
|
+
Gem::Specification.new do |gem|
|
6
|
+
gem.name = "fluent-plugin-memcached"
|
7
|
+
gem.version = "0.0.1"
|
8
|
+
gem.authors = ["innossh"]
|
9
|
+
gem.email = ["innossh@users.noreply.github.com"]
|
10
|
+
|
11
|
+
gem.summary = %q{Memcached output plugin for Fluent}
|
12
|
+
gem.homepage = "https://github.com/innossh/fluent-plugin-memcached"
|
13
|
+
gem.license = "Apache-2.0"
|
14
|
+
|
15
|
+
gem.files = `git ls-files -z`.split("\x0")
|
16
|
+
gem.executables = gem.files.grep(%r{^bin/}).map{ |f| File.basename(f) }
|
17
|
+
gem.test_files = gem.files.grep(%r{^(test|spec|features)/})
|
18
|
+
gem.require_paths = ["lib"]
|
19
|
+
|
20
|
+
gem.add_runtime_dependency "fluentd"
|
21
|
+
gem.add_runtime_dependency "dalli"
|
22
|
+
gem.add_development_dependency "rake"
|
23
|
+
gem.add_development_dependency "test-unit"
|
24
|
+
end
|
@@ -0,0 +1,38 @@
|
|
1
|
+
class Fluent::MemcachedOutput < Fluent::BufferedOutput
|
2
|
+
Fluent::Plugin.register_output('memcached', self)
|
3
|
+
attr_reader :host, :port, :memcached
|
4
|
+
|
5
|
+
def initialize
|
6
|
+
super
|
7
|
+
require 'dalli'
|
8
|
+
end
|
9
|
+
|
10
|
+
def configure(conf)
|
11
|
+
super
|
12
|
+
@host = conf.has_key?('host') ? conf['host'] : 'localhost'
|
13
|
+
@port = conf.has_key?('port') ? conf['port'].to_i : 11211
|
14
|
+
end
|
15
|
+
|
16
|
+
def start
|
17
|
+
super
|
18
|
+
@memcached = Dalli::Client.new("#{host}:#{port}")
|
19
|
+
end
|
20
|
+
|
21
|
+
def shutdown
|
22
|
+
@memcached.close
|
23
|
+
end
|
24
|
+
|
25
|
+
def format(tag, time, record)
|
26
|
+
[tag, time, record].to_msgpack
|
27
|
+
end
|
28
|
+
|
29
|
+
def write(chunk)
|
30
|
+
chunk.msgpack_each { |record|
|
31
|
+
array = record[2].split(' ')
|
32
|
+
key = array.first
|
33
|
+
value = array.drop(1).join(' ')
|
34
|
+
@memcached.set key, value
|
35
|
+
}
|
36
|
+
end
|
37
|
+
|
38
|
+
end
|
@@ -0,0 +1,47 @@
|
|
1
|
+
require 'test/unit'
|
2
|
+
require 'fluent/test'
|
3
|
+
require 'fluent/plugin/out_memcached'
|
4
|
+
|
5
|
+
class MemcachedOutputTest < Test::Unit::TestCase
|
6
|
+
def setup
|
7
|
+
Fluent::Test.setup
|
8
|
+
end
|
9
|
+
|
10
|
+
CONFIG = %[
|
11
|
+
host 127.0.0.1
|
12
|
+
port 11211
|
13
|
+
]
|
14
|
+
|
15
|
+
def create_driver(conf = CONFIG, tag='test')
|
16
|
+
Fluent::Test::BufferedOutputTestDriver.new(Fluent::MemcachedOutput, tag).configure(conf)
|
17
|
+
end
|
18
|
+
|
19
|
+
def test_configure
|
20
|
+
d = create_driver('')
|
21
|
+
|
22
|
+
assert_equal 'localhost', d.instance.host
|
23
|
+
assert_equal 11211, d.instance.port
|
24
|
+
|
25
|
+
d = create_driver
|
26
|
+
|
27
|
+
assert_equal '127.0.0.1', d.instance.host
|
28
|
+
assert_equal 11211, d.instance.port
|
29
|
+
end
|
30
|
+
|
31
|
+
def test_format
|
32
|
+
d = create_driver
|
33
|
+
time = Time.parse('2011-01-02 13:14:15 UTC').to_i
|
34
|
+
d.emit('a 1', time)
|
35
|
+
d.expect_format(['test', time, 'a 1'].to_msgpack)
|
36
|
+
d.run
|
37
|
+
end
|
38
|
+
|
39
|
+
def test_write
|
40
|
+
d = create_driver
|
41
|
+
time = Time.parse('2011-01-02 13:14:15 UTC').to_i
|
42
|
+
d.emit('a 1', time)
|
43
|
+
d.run
|
44
|
+
|
45
|
+
assert_equal '1', d.instance.memcached.get('a')
|
46
|
+
end
|
47
|
+
end
|
metadata
ADDED
@@ -0,0 +1,109 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: fluent-plugin-memcached
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 0.0.1
|
5
|
+
platform: ruby
|
6
|
+
authors:
|
7
|
+
- innossh
|
8
|
+
autorequire:
|
9
|
+
bindir: bin
|
10
|
+
cert_chain: []
|
11
|
+
date: 2015-11-23 00:00:00.000000000 Z
|
12
|
+
dependencies:
|
13
|
+
- !ruby/object:Gem::Dependency
|
14
|
+
name: fluentd
|
15
|
+
requirement: !ruby/object:Gem::Requirement
|
16
|
+
requirements:
|
17
|
+
- - ">="
|
18
|
+
- !ruby/object:Gem::Version
|
19
|
+
version: '0'
|
20
|
+
type: :runtime
|
21
|
+
prerelease: false
|
22
|
+
version_requirements: !ruby/object:Gem::Requirement
|
23
|
+
requirements:
|
24
|
+
- - ">="
|
25
|
+
- !ruby/object:Gem::Version
|
26
|
+
version: '0'
|
27
|
+
- !ruby/object:Gem::Dependency
|
28
|
+
name: dalli
|
29
|
+
requirement: !ruby/object:Gem::Requirement
|
30
|
+
requirements:
|
31
|
+
- - ">="
|
32
|
+
- !ruby/object:Gem::Version
|
33
|
+
version: '0'
|
34
|
+
type: :runtime
|
35
|
+
prerelease: false
|
36
|
+
version_requirements: !ruby/object:Gem::Requirement
|
37
|
+
requirements:
|
38
|
+
- - ">="
|
39
|
+
- !ruby/object:Gem::Version
|
40
|
+
version: '0'
|
41
|
+
- !ruby/object:Gem::Dependency
|
42
|
+
name: rake
|
43
|
+
requirement: !ruby/object:Gem::Requirement
|
44
|
+
requirements:
|
45
|
+
- - ">="
|
46
|
+
- !ruby/object:Gem::Version
|
47
|
+
version: '0'
|
48
|
+
type: :development
|
49
|
+
prerelease: false
|
50
|
+
version_requirements: !ruby/object:Gem::Requirement
|
51
|
+
requirements:
|
52
|
+
- - ">="
|
53
|
+
- !ruby/object:Gem::Version
|
54
|
+
version: '0'
|
55
|
+
- !ruby/object:Gem::Dependency
|
56
|
+
name: test-unit
|
57
|
+
requirement: !ruby/object:Gem::Requirement
|
58
|
+
requirements:
|
59
|
+
- - ">="
|
60
|
+
- !ruby/object:Gem::Version
|
61
|
+
version: '0'
|
62
|
+
type: :development
|
63
|
+
prerelease: false
|
64
|
+
version_requirements: !ruby/object:Gem::Requirement
|
65
|
+
requirements:
|
66
|
+
- - ">="
|
67
|
+
- !ruby/object:Gem::Version
|
68
|
+
version: '0'
|
69
|
+
description:
|
70
|
+
email:
|
71
|
+
- innossh@users.noreply.github.com
|
72
|
+
executables: []
|
73
|
+
extensions: []
|
74
|
+
extra_rdoc_files: []
|
75
|
+
files:
|
76
|
+
- ".gitignore"
|
77
|
+
- ".travis.yml"
|
78
|
+
- Gemfile
|
79
|
+
- README.md
|
80
|
+
- Rakefile
|
81
|
+
- fluent-plugin-memcached.gemspec
|
82
|
+
- lib/fluent/plugin/out_memcached.rb
|
83
|
+
- test/plugin/test_out_memcached.rb
|
84
|
+
homepage: https://github.com/innossh/fluent-plugin-memcached
|
85
|
+
licenses:
|
86
|
+
- Apache-2.0
|
87
|
+
metadata: {}
|
88
|
+
post_install_message:
|
89
|
+
rdoc_options: []
|
90
|
+
require_paths:
|
91
|
+
- lib
|
92
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
93
|
+
requirements:
|
94
|
+
- - ">="
|
95
|
+
- !ruby/object:Gem::Version
|
96
|
+
version: '0'
|
97
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
98
|
+
requirements:
|
99
|
+
- - ">="
|
100
|
+
- !ruby/object:Gem::Version
|
101
|
+
version: '0'
|
102
|
+
requirements: []
|
103
|
+
rubyforge_project:
|
104
|
+
rubygems_version: 2.4.5.1
|
105
|
+
signing_key:
|
106
|
+
specification_version: 4
|
107
|
+
summary: Memcached output plugin for Fluent
|
108
|
+
test_files:
|
109
|
+
- test/plugin/test_out_memcached.rb
|