-
Notifications
You must be signed in to change notification settings - Fork 339
/
shinken-scheduler
executable file
·147 lines (129 loc) · 5.62 KB
/
shinken-scheduler
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
#!/usr/bin/env python
# Copyright (C) 2009-2014:
# Gabes Jean, naparuba@gmail.com
# Gerhard Lausser, Gerhard.Lausser@consol.de
# Gregory Starck, g.starck@gmail.com
# Hartmut Goebel, h.goebel@goebel-consult.de
#
# This file is part of Shinken.
#
# Shinken is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Shinken 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 Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with Shinken. If not, see <http://www.gnu.org/licenses/>.
# For the Shinken application, I try to respect
# The Zen of Python, by Tim Peters. It's just some
# very goods ideas that make Python programming very fun
# and efficient. If it's good for Python, it must be good for
# Shinken. :)
#
#
#
# Beautiful is better than ugly.
# Explicit is better than implicit.
# Simple is better than complex.
# Complex is better than complicated.
# Flat is better than nested.
# Sparse is better than dense.
# Readability counts.
# Special cases aren't special enough to break the rules.
# Although practicality beats purity.
# Errors should never pass silently.
# Unless explicitly silenced.
# In the face of ambiguity, refuse the temptation to guess.
# There should be one-- and preferably only one --obvious way to do it.
# Although that way may not be obvious at first unless you're Dutch.
# Now is better than never.
# Although never is often better than *right* now.
# If the implementation is hard to explain, it's a bad idea.
# If the implementation is easy to explain, it may be a good idea.
# Namespaces are one honking great idea -- let's do more of those!
'''
This class is the application in charge of scheduling
The scheduler listens to the Arbiter for the configuration sent through
the given port as first argument.
The configuration sent by the arbiter specifies which checks and actions
the scheduler must schedule, and a list of reactionners and pollers
to execute them
When the scheduler is already launched and has its own conf, it keeps on
listening the arbiter (one a timeout)
In case the arbiter has a new conf to send, the scheduler is stopped
and a new one is created.
'''
from __future__ import absolute_import, division, print_function, unicode_literals
import os
import sys
import optparse
# We try to raise up recusion limit on
# but we don't have resource module on windows
if os.name != 'nt':
import resource
# All the pickle will ask for a lot of recursion, so we must make
# sure to set it at a high value. The maximum recursion depth depends
# on the Python version and the process limit "stack size".
# The factors used were acquired by testing a broad range of installations
stacksize_soft, stacksize_hard = resource.getrlimit(3)
if sys.version_info < (3,):
sys.setrecursionlimit(int(stacksize_soft * 1.9 + 3200))
else:
sys.setrecursionlimit(int(stacksize_soft * 2.4 + 3200))
try:
from shinken.bin import VERSION
import shinken
except ImportError:
# If importing shinken fails, try to load from current directory
# or parent directory to support running without installation.
# Submodules will then be loaded from there, too.
import imp
imp.load_module('shinken',
*imp.find_module('shinken',
[os.path.realpath("."),
os.path.realpath(".."),
os.path.join(os.path.abspath(os.path.dirname(sys.argv[0])),
"..")]))
import shinken
# Ok we should add the shinken root directory to our sys.path so our sons
# will be able to use the shinken import without problems
shinken_root_path = os.path.dirname(os.path.dirname(shinken.__file__))
os.environ['PYTHONPATH'] = os.path.join(os.environ.get('PYTHONPATH', ''), shinken_root_path)
from shinken.daemons.schedulerdaemon import Shinken
from shinken.bin import VERSION
# Protect for windows multiprocessing that will RELAUNCH all
def main():
parser = optparse.OptionParser(
"%prog [options]", version="%prog " + VERSION)
parser.add_option('-c', '--config',
dest="config_file", metavar="INI-CONFIG-FILE",
help='Config file')
parser.add_option('-d', '--daemon', action='store_true',
dest="is_daemon",
help="Run in daemon mode")
parser.add_option('-r', '--replace', action='store_true',
dest="do_replace",
help="Replace previous running scheduler")
parser.add_option('--debugfile', dest='debug_file',
help=("Enable debug log and save it to a file. "
"Default: not used"))
parser.add_option("-p", "--profile",
dest="profile",
help="Dump a profile file. Need the python cProfile library")
opts, args = parser.parse_args()
if args:
parser.error("Does not accept any argument.")
daemon = Shinken(debug=opts.debug_file is not None, **opts.__dict__)
if not opts.profile:
daemon.main()
else:
# For perf running:
import cProfile
cProfile.runctx('''daemon.main()''', globals(), locals(), opts.profile)
if __name__ == '__main__':
main()