1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
#!/usr/bin/python
# Copyright (C) 2009 Gluster, Inc. <http://www.gluster.com>
# This file is part of Gluster Storage Platform.
#
# Gluster Storage Platform is free software; you can redistribute it
# and/or modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 3 of
# the License, or (at your option) any later version.
#
# Gluster Storage Platform is distributed in the hope that it will be
# useful, but WITHOUT ANY WARRANTY; without even the implied warranty
# of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see
# <http://www.gnu.org/licenses/>.
import sys
import socket
import signal
import struct
import syslog
import Globals
import Common
class TimeoutException(Exception):
pass
def timeoutSignal(signum, frame):
raise TimeoutException, "Timed out"
def serverDiscoveryRequest(multiCastGroup, port):
servers = []
# Sending request to all the servers
socketSend = socket.socket(socket.AF_INET, socket.SOCK_DGRAM, socket.IPPROTO_UDP)
socketSend.setsockopt(socket.IPPROTO_IP, socket.IP_MULTICAST_TTL, 2)
socketSend.sendto("ServerDiscovery", (multiCastGroup, port))
# Waiting for the response
socketReceive = socket.socket(socket.AF_INET, socket.SOCK_DGRAM, socket.IPPROTO_UDP)
socketReceive.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
socketReceive.bind(('', port))
mreq = struct.pack("4sl", socket.inet_aton(multiCastGroup), socket.INADDR_ANY)
socketReceive.setsockopt(socket.IPPROTO_IP, socket.IP_ADD_MEMBERSHIP, mreq)
socketSend.sendto("ServerDiscovery", (multiCastGroup, port))
try:
while True:
response = socketReceive.recvfrom(200)
if response and response[0].upper() != "SERVERDISCOVERY":
servers.append(response[0] + "\n")
signal.signal(signal.SIGALRM, timeoutSignal)
signal.alarm(3)
except TimeoutException:
return servers
return None
def main():
syslog.openlog("discovery server request")
servers = serverDiscoveryRequest(Globals.MULTICAST_GROUP, Globals.MULTICAST_PORT)
if not servers:
Common.log(syslog.LOG_ERR, "Failed to discover new servers")
sys.exit(-1)
servers = set(servers)
try:
fp = open(Globals.DISCOVERED_SERVER_LIST_FILENAME, "w")
print(list(servers))
fp.writelines(list(servers))
fp.close()
except IOError:
Common.log(syslog.LOG_ERR, "Unable to open file %s" % Globals.DISCOVERED_SERVER_LIST_FILENAME)
sys.exit(-1)
#for serverName in servers:
# print serverName
sys.exit(0)
if __name__ == "__main__":
main()
|