Class: Droonga::ForwardBuffer
- Inherits:
-
Object
- Object
- Droonga::ForwardBuffer
- Includes:
- Loggable
- Defined in:
- lib/droonga/forward_buffer.rb
Constant Summary collapse
- SUFFIX =
".msgpack"
Instance Attribute Summary collapse
-
#on_forward ⇒ Object
writeonly
Sets the attribute on_forward.
Instance Method Summary collapse
- #add(message, destination) ⇒ Object
- #buffered_messages ⇒ Object
- #empty? ⇒ Boolean
-
#initialize(node_name) ⇒ ForwardBuffer
constructor
A new instance of ForwardBuffer.
- #process_messages_newer_than(timestamp) ⇒ Object
- #start_forward ⇒ Object
Constructor Details
#initialize(node_name) ⇒ ForwardBuffer
Returns a new instance of ForwardBuffer.
37 38 39 40 41 42 43 44 45 |
# File 'lib/droonga/forward_buffer.rb', line 37 def initialize(node_name) @on_forward = nil @packer = MessagePack::Packer.new @unpacker = MessagePack::Unpacker.new @target = node_name @process_messages_newer_than_timestamp = nil end |
Instance Attribute Details
#on_forward=(value) ⇒ Object
Sets the attribute on_forward
35 36 37 |
# File 'lib/droonga/forward_buffer.rb', line 35 def on_forward=(value) @on_forward = value end |
Instance Method Details
#add(message, destination) ⇒ Object
47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
# File 'lib/droonga/forward_buffer.rb', line 47 def add(, destination) logger.trace("add: start") serf.(@target) = { "message" => , "destination" => destination, } @packer.pack() file_path = SafeFileWriter.write(file_path) do |output, file| output.puts(@packer.to_s) end @packer.clear logger.trace("add: done", :path => file_path) end |
#buffered_messages ⇒ Object
84 85 86 87 88 |
# File 'lib/droonga/forward_buffer.rb', line 84 def Pathname.glob("#{data_directory}/*#{SUFFIX}").sort_by do |path| path end end |
#empty? ⇒ Boolean
90 91 92 |
# File 'lib/droonga/forward_buffer.rb', line 90 def empty? data_directory.children.empty? end |
#process_messages_newer_than(timestamp) ⇒ Object
94 95 96 |
# File 'lib/droonga/forward_buffer.rb', line 94 def () @process_messages_newer_than_timestamp = end |
#start_forward ⇒ Object
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 |
# File 'lib/droonga/forward_buffer.rb', line 63 def start_forward logger.trace("start_forward: start") = 0 .each do || forwarded = forward() += 1 if forwarded end if > 0 and @process_messages_newer_than_timestamp logger.info("#{} new messages forwarded. " + "The boundary is now cleared.") # Don't clear the boundary while forwarding. # Because buffered messages are not sorted by their "date", # so older messages can appear after newer one. # (ex. messages generated by Dispatcher) @process_messages_newer_than_timestamp = nil end serf.(@target) logger.trace("start_forward: done") end |