Class: Legion::Cluster::Leader
- Inherits:
-
Object
- Object
- Legion::Cluster::Leader
- Defined in:
- lib/legion/cluster/leader.rb
Constant Summary collapse
- HEARTBEAT_INTERVAL =
seconds
10- LOCK_NAME =
'legion_leader'
Instance Attribute Summary collapse
-
#is_leader ⇒ Object
readonly
Returns the value of attribute is_leader.
-
#node_id ⇒ Object
readonly
Returns the value of attribute node_id.
Instance Method Summary collapse
-
#initialize(node_id: SecureRandom.uuid) ⇒ Leader
constructor
A new instance of Leader.
- #leader? ⇒ Boolean
- #start ⇒ Object
- #stop ⇒ Object
Constructor Details
#initialize(node_id: SecureRandom.uuid) ⇒ Leader
Returns a new instance of Leader.
11 12 13 14 15 16 |
# File 'lib/legion/cluster/leader.rb', line 11 def initialize(node_id: SecureRandom.uuid) @node_id = node_id @is_leader = false @heartbeat_thread = nil @running = false end |
Instance Attribute Details
#is_leader ⇒ Object (readonly)
Returns the value of attribute is_leader.
9 10 11 |
# File 'lib/legion/cluster/leader.rb', line 9 def is_leader @is_leader end |
#node_id ⇒ Object (readonly)
Returns the value of attribute node_id.
9 10 11 |
# File 'lib/legion/cluster/leader.rb', line 9 def node_id @node_id end |
Instance Method Details
#leader? ⇒ Boolean
29 30 31 |
# File 'lib/legion/cluster/leader.rb', line 29 def leader? @is_leader end |
#start ⇒ Object
18 19 20 21 |
# File 'lib/legion/cluster/leader.rb', line 18 def start @running = true @heartbeat_thread = Thread.new { election_loop } end |
#stop ⇒ Object
23 24 25 26 27 |
# File 'lib/legion/cluster/leader.rb', line 23 def stop @running = false @heartbeat_thread&.join(HEARTBEAT_INTERVAL + 2) resign if @is_leader end |