[Groonga-commit] droonga/droonga-engine at 224ac0a [master] Do absorb via serf event

アーカイブの一覧に戻る

YUKI Hiroshi null+****@clear*****
Sun Jun 29 03:06:51 JST 2014


YUKI Hiroshi	2014-06-29 03:06:51 +0900 (Sun, 29 Jun 2014)

  New Revision: 224ac0aece78823c55968e3b7ba6c7f03a66e411
  https://github.com/droonga/droonga-engine/commit/224ac0aece78823c55968e3b7ba6c7f03a66e411

  Message:
    Do absorb via serf event

  Modified files:
    bin/droonga-engine-absorb-data
    lib/droonga/command/serf_event_handler.rb

  Modified: bin/droonga-engine-absorb-data (+18 -42)
===================================================================
--- bin/droonga-engine-absorb-data    2014-06-29 02:48:25 +0900 (a4acbb6)
+++ bin/droonga-engine-absorb-data    2014-06-29 03:06:51 +0900 (8258a35)
@@ -21,11 +21,12 @@ require "open3"
 
 require "droonga/engine/version"
 require "droonga/catalog_generator"
-require "droonga/data_absorber"
+require "droonga/serf"
 
 options = OpenStruct.new
-options.drndump = "drndump"
-options.client  = "droonga-request"
+options.port    = Droonga::CatalogGenerator::DEFAULT_PORT
+options.tag     = Droonga::CatalogGenerator::DEFAULT_TAG
+options.dataset = Droonga::CatalogGenerator::DEFAULT_DATASET
 parser = OptionParser.new
 parser.version = Droonga::Engine::VERSION
 
@@ -41,7 +42,7 @@ parser.on("--destination-host=HOST",
 end
 parser.on("--port=PORT", Integer,
           "Port number of the source cluster to be connected.",
-          "(#{Droonga::CatalogGenerator::DEFAULT_PORT})") do |port|
+          "(#{options.port})") do |port|
   options.port = port
 end
 
@@ -49,58 +50,33 @@ parser.separator("")
 parser.separator("Data:")
 parser.on("--tag=TAG",
           "Tag name to be used to communicate with Droonga system.",
-          "(#{Droonga::CatalogGenerator::DEFAULT_TAG})") do |tag|
+          "(#{options.tag})") do |tag|
   options.tag = tag
 end
 parser.on("--dataset=DATASET",
           "Dataset to be absorbed.",
-          "(#{Droonga::CatalogGenerator::DEFAULT_DATASET})") do |dataset|
+          "(#{options.dataset})") do |dataset|
   options.dataset = dataset
 end
 
-parser.separator("")
-parser.separator("Droonga protocol:")
-parser.on("--receiver-host=HOST",
-          "Host name of this node to be received a response from clusters.") do |host|
-  options.destination_host = host
-end
-parser.on("--receiver-port=PORT", Integer,
-          "Port number of this node to be received a response from clusters.") do |port|
-  options.receiver_port = port
-end
-
-parser.separator("")
-parser.separator("Commands:")
-parser.on("--drndump=PATH",
-          "Path to the drndump command.",
-          "(#{options.client})") do |path|
-  options.drndump = path
-end
-parser.on("--droonga-request=PATH",
-          "Path to the droonga-request command.",
-          "(#{options.client})") do |path|
-  options.client = path
-end
-
 parser.parse!(ARGV)
 
 unless options.source_host
   raise "You must specify the source host via --source-host option."
 end
 unless options.destination_host
-  raise "You must specify the destination host (this node) " +
-          "via --destination-host option."
+  raise "You must specify the destination host via --destination-host option."
 end
 
-Droonga::DataAbsorber.absorb(:drndump          => options.drndump,
-                             :client           => options.client,
-                             :dataset          => options.dataset,
-                             :source_host      => options.source_host,
-                             :destination_host => options.destination_host,
-                             :port             => options.port,
-                             :tag              => options.tag,
-                             :receiver_port    => options.receiver_port) do |dump|
-  puts dump
-end
+destination_node = "#{options.destination_host}:#{options.port}/#{options.tag}"
+
+puts "Absorbing data..."
+Droonga::Serf.send_query(destination_node, "absorb_data",
+                         "node"    => destination_node,
+                         "source"  => options.source_host,
+                         "port"    => options.port,
+                         "tag"     => options.tag,
+                         "dataset" => options.dataset)
+puts "Done."
 
 exit(true)

  Modified: lib/droonga/command/serf_event_handler.rb (+16 -7)
===================================================================
--- lib/droonga/command/serf_event_handler.rb    2014-06-29 02:48:25 +0900 (8bd10e4)
+++ lib/droonga/command/serf_event_handler.rb    2014-06-29 03:06:51 +0900 (38c463f)
@@ -191,18 +191,27 @@ module Droonga
       end
 
       def absorb_data
-        dataset = @payload["dataset"]
-        return unless dataset
+        return unless event_for_me?
 
         soruce = @payload["soruce"]
         return unless soruce
 
-        current_catalog = JSON.parse(Path.catalog.read)
-        generator = CatalogGenerator.new
-        generator.load(current_catalog)
+        dataset_name = @payload["dataset"]
+        port         = @payload["port"]
+        tag          = @payload["port"]
+
+        if dataset_name.nil? or port.nil? or tag.nil?
+          current_catalog = JSON.parse(Path.catalog.read)
+          generator = CatalogGenerator.new
+          generator.load(current_catalog)
 
-        port = @payload["port"] || generator.datasets[dataset].replicas.port
-        tag  = @payload["tag"]  || generator.datasets[dataset].replicas.tag
+          dataset = generator.dataset_for_host(soruce)
+          return unless dataset
+
+          dataset_name = dataset.name
+          port = dataset.replicas.port
+          tag  = dataset.replicas.tag
+        end
 
         DataAbsorber.absorb(:dataset          => dataset,
                             :source_host      => source,
-------------- next part --------------
HTML����������������������������...
ダウンロード 



More information about the Groonga-commit mailing list
アーカイブの一覧に戻る