Module: Serfx::Commands
- Included in:
- Connection
- Defined in:
- lib/serfx/commands.rb
Overview
Implements all of Serf’s rpc commands using Serfx::Connection#request method
Instance Method Summary collapse
- 
  
    
      #auth  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    authenticate against the serf agent. 
- 
  
    
      #event(name, payload = nil, coalesce = true)  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    fires an user event. 
- 
  
    
      #force_leave(node)  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    force a failed node to leave the cluster. 
- 
  
    
      #handshake  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    performs initial hanshake of an RPC session. 
- 
  
    
      #install_key(key)  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    install a new encryption key onto the cluster’s keyring. 
- 
  
    
      #join(existing, replay = false)  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    join an existing cluster. 
- 
  
    
      #leave  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    leave is used trigger a graceful leave and shutdown of the current agent. 
- 
  
    
      #list_keys  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    return a list of all encryption keys currently in use on the cluster. 
- 
  
    
      #members  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    obtain the list of existing members. 
- 
  
    
      #members_filtered(tags, status = 'alive', name = nil)  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    obatin the list of cluster members, filtered by tags. 
- 
  
    
      #monitor(loglevel = 'debug')  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    monitor is similar to the stream command, but instead of events it subscribes the channel to log messages from the agent. 
- 
  
    
      #query(name, payload, opts = {}, &block)  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    query is used to issue a new query. 
- 
  
    
      #remove_key(key)  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    remove a key from the cluster’s keyring. 
- 
  
    
      #respond(id, payload)  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    respond is used with ‘stream` to subscribe to queries and then respond. 
- 
  
    
      #stats  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    obtain stats about the agent(same as info command). 
- 
  
    
      #stop(sequence_number)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    stop is used to stop either a stream or monitor. 
- 
  
    
      #stream(types, &block)  ⇒ Thread, Response 
    
    
  
  
  
  
  
  
  
  
  
    subscribe to a stream of all events matching a given type filter. 
- 
  
    
      #tags(tags, delete_tags = [])  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    alter the tags on a Serf agent while it is running. 
- 
  
    
      #use_key(key)  ⇒ Response 
    
    
  
  
  
  
  
  
  
  
  
    change the primary key, which is used to encrypt messages. 
Instance Method Details
#auth ⇒ Response
authenticate against the serf agent. if RPC credentials are setup, then ‘auth` has to be second command, immediately after `handshake`.
| 24 25 26 27 | # File 'lib/serfx/commands.rb', line 24 def auth tcp_send(:auth, 'AuthKey' => @authkey) read_response(:auth) end | 
#event(name, payload = nil, coalesce = true) ⇒ Response
fires an user event
same name during similar time frame
| 35 36 37 38 39 40 41 42 | # File 'lib/serfx/commands.rb', line 35 def event(name, payload = nil, coalesce = true) event = { 'Name' => name, 'Coalesce' => coalesce } event['Payload'] = payload unless payload.nil? request(:event, event) end | 
#force_leave(node) ⇒ Response
force a failed node to leave the cluster
| 48 49 50 | # File 'lib/serfx/commands.rb', line 48 def force_leave(node) request(:force_leave, 'Node' => node) end | 
#handshake ⇒ Response
performs initial hanshake of an RPC session. Handshake has to be the first command to be invoked during an RPC session.
| 15 16 17 18 | # File 'lib/serfx/commands.rb', line 15 def handshake tcp_send(:handshake, 'Version' => 1) read_response(:handshake) end | 
#install_key(key) ⇒ Response
install a new encryption key onto the cluster’s keyring
| 175 176 177 | # File 'lib/serfx/commands.rb', line 175 def install_key(key) request(:install_key, 'Key' => key) end | 
#join(existing, replay = false) ⇒ Response
join an existing cluster.
| 57 58 59 | # File 'lib/serfx/commands.rb', line 57 def join(existing, replay = false) request(:join, 'Existing' => existing, 'Replay' => replay) end | 
#leave ⇒ Response
leave is used trigger a graceful leave and shutdown of the current agent
| 135 136 137 | # File 'lib/serfx/commands.rb', line 135 def leave request(:leave) end | 
#list_keys ⇒ Response
return a list of all encryption keys currently in use on the cluster
| 198 199 200 | # File 'lib/serfx/commands.rb', line 198 def list_keys request(:list_keys) end | 
#members ⇒ Response
obtain the list of existing members
| 64 65 66 | # File 'lib/serfx/commands.rb', line 64 def members request(:members) end | 
#members_filtered(tags, status = 'alive', name = nil) ⇒ Response
obatin the list of cluster members, filtered by tags.
| 75 76 77 78 79 80 81 82 | # File 'lib/serfx/commands.rb', line 75 def members_filtered(, status = 'alive', name = nil) filter = { 'Tags' => , 'Status' => status } filter['Name'] = name unless name.nil? request(:members_filtered, filter) end | 
#monitor(loglevel = 'debug') ⇒ Response
monitor is similar to the stream command, but instead of events it subscribes the channel to log messages from the agent
| 123 124 125 | # File 'lib/serfx/commands.rb', line 123 def monitor(loglevel = 'debug') request(:monitor, 'LogLevel' => loglevel.upcase) end | 
#query(name, payload, opts = {}, &block) ⇒ Response
query is used to issue a new query
| 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 | # File 'lib/serfx/commands.rb', line 145 def query(name, payload, opts = {}, &block) params = { 'Name' => name, 'Payload' => payload } params.merge!(opts) res = request(:query, params) loop do header = read_data check_rpc_error!(header) ev = read_data if ev['Type'] == 'done' break else block.call(ev) if block end end res end | 
#remove_key(key) ⇒ Response
remove a key from the cluster’s keyring
| 191 192 193 | # File 'lib/serfx/commands.rb', line 191 def remove_key(key) request(:remove_key, 'Key' => key) end | 
#respond(id, payload) ⇒ Response
respond is used with ‘stream` to subscribe to queries and then respond.
| 167 168 169 | # File 'lib/serfx/commands.rb', line 167 def respond(id, payload) request(:respond, 'ID' => id, 'Payload' => payload) end | 
#stats ⇒ Response
obtain stats about the agent(same as info command)
| 205 206 207 | # File 'lib/serfx/commands.rb', line 205 def stats request(:stats) end | 
#stop(sequence_number) ⇒ Object
stop is used to stop either a stream or monitor
| 128 129 130 | # File 'lib/serfx/commands.rb', line 128 def stop(sequence_number) tcp_send(:stop, 'Stop' => sequence_number) end | 
#stream(types, &block) ⇒ Thread, Response
subscribe to a stream of all events matching a given type filter. Events will continue to be sent until the stream is stopped
| 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 | # File 'lib/serfx/commands.rb', line 101 def stream(types, &block) res = request(:stream, 'Type' => types) t = Thread.new do loop do header = read_data check_rpc_error!(header) if header['Seq'] == res.header.seq ev = read_data block.call(ev) if block else break end end end [res, t] end | 
#tags(tags, delete_tags = []) ⇒ Response
alter the tags on a Serf agent while it is running. A member-update event will be triggered immediately to notify the other agents in the cluster of the change. The tags command can add new tags, modify existing tags, or delete tags
| 92 93 94 | # File 'lib/serfx/commands.rb', line 92 def (, = []) request(:tags, 'Tags' => , 'DeleteTags' => ) end | 
#use_key(key) ⇒ Response
change the primary key, which is used to encrypt messages
| 183 184 185 | # File 'lib/serfx/commands.rb', line 183 def use_key(key) request(:use_key, 'Key' => key) end |