Class: Embulk::OutputRedis

Inherits:
OutputPlugin
  • Object
show all
Defined in:
lib/embulk/output/redis.rb

Class Method Summary collapse

Instance Method Summary collapse

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

#abortObject



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

#closeObject



35
36
# File 'lib/embulk/output/redis.rb', line 35

def close
end

#commitObject



53
54
55
56
57
58
# File 'lib/embulk/output/redis.rb', line 53

def commit
  commit_report = {
    "records" => @records
  }
  return commit_report
end

#finishObject



47
48
# File 'lib/embulk/output/redis.rb', line 47

def finish
end