Class: Embulk::OutputRedis
- Inherits:
-
OutputPlugin
- Object
- OutputPlugin
- Embulk::OutputRedis
- Defined in:
- lib/embulk/output/redis.rb
Class Method Summary collapse
Instance Method Summary collapse
- #abort ⇒ Object
- #add(page) ⇒ Object
- #close ⇒ Object
- #commit ⇒ Object
- #finish ⇒ Object
-
#initialize(task, schema, index) ⇒ OutputRedis
constructor
A new instance of OutputRedis.
Constructor Details
#initialize(task, schema, index) ⇒ OutputRedis
Returns a new instance of OutputRedis.
24 25 26 27 28 29 30 31 32 33 |
# File 'lib/embulk/output/redis.rb', line 24 def initialize(task, schema, index) puts "Example output thread #{index}..." super @records = 0 if task['url'].nil? || task['url'].empty? @redis = ::Redis.new(:host => task['host'], :port => task['port'], :db => task['db']) else @redis = ::Redis.new(:url => task['url']) end end |
Class Method Details
.transaction(config, schema, processor_count, &control) ⇒ Object
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
# File 'lib/embulk/output/redis.rb', line 8 def self.transaction(config, schema, processor_count, &control) task = { 'host' => config.param('host', :string, :default => 'localhost'), 'port' => config.param('port', :integer, :default => 6379), 'db' => config.param('db', :integer, :default => 0), 'key' => config.param('key', :string), 'url' => config.param('url', :string), } puts "Redis output started." commit_reports = yield(task) puts "Redis output finished. Commit reports = #{commit_reports.to_json}" return {} end |
Instance Method Details
#abort ⇒ Object
50 51 |
# File 'lib/embulk/output/redis.rb', line 50 def abort end |
#add(page) ⇒ Object
38 39 40 41 42 43 44 45 |
# File 'lib/embulk/output/redis.rb', line 38 def add(page) page.each do |record| hash = Hash[schema.names.zip(record)] puts "#{@message}: #{hash.to_json}" @redis.set(hash[task['key']], hash) @records += 1 end end |
#close ⇒ Object
35 36 |
# File 'lib/embulk/output/redis.rb', line 35 def close end |
#commit ⇒ Object
53 54 55 56 57 58 |
# File 'lib/embulk/output/redis.rb', line 53 def commit commit_report = { "records" => @records } return commit_report end |
#finish ⇒ Object
47 48 |
# File 'lib/embulk/output/redis.rb', line 47 def finish end |