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
|
"""
ping minions to see whether they are up.
Copyright 2007, Red Hat, Inc
Michael DeHaan <mdehaan@redhat.com>
also see AUTHORS
This software may be freely redistributed under the terms of the GNU
general public license.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
"""
import optparse
import os
import pprint
import stat
import xmlrpclib
from func.overlord import command
from func.overlord import client
class Ping(client.command.BaseCommand):
name = "ping"
usage = "see what func minions are up/accessible"
def addOptions(self):
"""
Not too many options for you! (Seriously, it's a simple command ... func "*" ping)
"""
# FIXME: verbose and port should be added globally to all sub modules
self.parser.add_option("-v", "--verbose", dest="verbose",
action="store_true")
def handleOptions(self, options):
"""
Nothing to do here...
"""
self.verbose = self.options.verbose
def do(self, args):
self.server_spec = self.parentCommand.server_spec
# because this is mainly an interactive command, expand the server list and make seperate connections.
# to make things look more speedy.
minion_set = client.Minions(self.server_spec, port=self.port)
servers = minion_set.get_all_hosts()
for server in servers:
overlord_obj = client.Overlord(server,port=self.port,
interactive=False,
verbose=self.verbose,
config=self.config,
noglobs=True)
results = overlord_obj.run("test", "ping", [])
print "results", results, type(results)
if results == 1:
print "[ ok ... ] %s" % server
else:
print "[ FAILED ] %s" % server
return 1
|