summaryrefslogtreecommitdiffstats
path: root/src/com.gluster.storage.management.server/WebContent/scripts/vmware-discover-servers.py
blob: e9ae86661b089c31d3d9aa9b8eb1a91e6c413a35 (plain)
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
83
84
85
86
87
88
89
90
#!/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
import time
from XmlHandler import *

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)
    sendtime = time.time()
    socketSend.sendto("<request><name>ServerDiscovery</name><time>%s</time></request>" % (sendtime), (multiCastGroup, port))

    try:
        while True:
            response = socketReceive.recvfrom(200)
            if not response:
                continue
            dom = XDOM()
            dom.parseString(response[0])
            if not dom:
                continue
            if dom.getTextByTagRoute("request.name"):
                continue
            responsetime = dom.getTextByTagRoute("response.time")
            servername = dom.getTextByTagRoute("response.servername")
            if responsetime == str(sendtime):
                servers.append(servername)
            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:
        for server in servers:
            print server
    except IOError:
        Common.log(syslog.LOG_ERR, "Unable to open file %s" % Globals.DISCOVERED_SERVER_LIST_FILENAME)
        sys.exit(-1)
    sys.exit(0)

if __name__ == "__main__":
    main()