rgossip 0.1.0 → 0.1.1
Sign up to get free protection for your applications and to get access to all the features.
- data/lib/rgossip/gossipper.rb +47 -45
- metadata +3 -3
data/lib/rgossip/gossipper.rb
CHANGED
@@ -1,56 +1,58 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
@
|
21
|
-
|
1
|
+
module RGossip
|
2
|
+
class Gossiper
|
3
|
+
@@interval = 0.1
|
4
|
+
def self.interval; @@interval; end
|
5
|
+
def self.interval=(v); @@interval = v; end
|
6
|
+
|
7
|
+
def initialize(my_node, node_list)
|
8
|
+
@my_node = my_node
|
9
|
+
@node_list = node_list
|
10
|
+
@running = true
|
11
|
+
end
|
12
|
+
|
13
|
+
def start
|
14
|
+
RGossip.log("Start Gossiper: interval=#{@@interval}")
|
15
|
+
|
16
|
+
@thread = Thread.start {
|
17
|
+
begin
|
18
|
+
sock = UDPSocket.open
|
19
|
+
|
20
|
+
while @running
|
21
|
+
@node_list.synchronize { gossip(sock) }
|
22
|
+
sleep(@@interval)
|
23
|
+
end
|
24
|
+
ensure
|
25
|
+
sock.close
|
22
26
|
end
|
23
|
-
|
24
|
-
|
25
|
-
end
|
26
|
-
}
|
27
|
-
end
|
27
|
+
}
|
28
|
+
end
|
28
29
|
|
29
|
-
|
30
|
-
|
30
|
+
def stop
|
31
|
+
RGossip.log("Stop Gossiper")
|
31
32
|
|
32
|
-
|
33
|
-
|
33
|
+
@running = false
|
34
|
+
end
|
34
35
|
|
35
|
-
|
36
|
-
|
37
|
-
|
36
|
+
def join
|
37
|
+
@thread.join
|
38
|
+
end
|
38
39
|
|
39
|
-
|
40
|
-
|
41
|
-
|
40
|
+
private
|
41
|
+
def gossip(sock)
|
42
|
+
@my_node.update_timestamp
|
42
43
|
|
43
|
-
|
44
|
-
|
44
|
+
dest = @node_list.choice_without(@my_node)
|
45
|
+
return unless dest
|
45
46
|
|
46
|
-
|
47
|
+
RGossip.log("Gossip: destination=#{dest.address}")
|
47
48
|
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
49
|
+
@node_list.serialize_to_chunks.each do |chunk|
|
50
|
+
begin
|
51
|
+
sock.send(chunk, 0, dest.address, RGossip.port)
|
52
|
+
rescue Exception => e
|
53
|
+
raise e unless RGossip.error_handler
|
54
|
+
RGossip.error_handler.call(e)
|
55
|
+
end
|
54
56
|
end
|
55
57
|
end
|
56
58
|
end # Gossiper
|
metadata
CHANGED