Statistics
| Branch: | Tag: | Revision:

root / lib / constants.py @ 4776e022

History | View | Annotate | Download (21 kB)

1 2f31098c Iustin Pop
#
2 a8083063 Iustin Pop
#
3 a8083063 Iustin Pop
4 a8083063 Iustin Pop
# Copyright (C) 2006, 2007 Google Inc.
5 a8083063 Iustin Pop
#
6 a8083063 Iustin Pop
# This program is free software; you can redistribute it and/or modify
7 a8083063 Iustin Pop
# it under the terms of the GNU General Public License as published by
8 a8083063 Iustin Pop
# the Free Software Foundation; either version 2 of the License, or
9 a8083063 Iustin Pop
# (at your option) any later version.
10 a8083063 Iustin Pop
#
11 a8083063 Iustin Pop
# This program is distributed in the hope that it will be useful, but
12 a8083063 Iustin Pop
# WITHOUT ANY WARRANTY; without even the implied warranty of
13 a8083063 Iustin Pop
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 a8083063 Iustin Pop
# General Public License for more details.
15 a8083063 Iustin Pop
#
16 a8083063 Iustin Pop
# You should have received a copy of the GNU General Public License
17 a8083063 Iustin Pop
# along with this program; if not, write to the Free Software
18 a8083063 Iustin Pop
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19 a8083063 Iustin Pop
# 02110-1301, USA.
20 a8083063 Iustin Pop
21 a8083063 Iustin Pop
22 a8083063 Iustin Pop
"""Module holding different constants."""
23 a8083063 Iustin Pop
24 4fe80ef2 Iustin Pop
import re
25 4fe80ef2 Iustin Pop
26 2ec08468 Michael Hanselmann
from ganeti import _autoconf
27 7c18ef8e Michael Hanselmann
28 a8083063 Iustin Pop
# various versions
29 f3e2e4c6 Iustin Pop
PROTOCOL_VERSION = 20
30 2ec08468 Michael Hanselmann
RELEASE_VERSION = _autoconf.PACKAGE_VERSION
31 d1a7d66f Guido Trotter
OS_API_V10 = 10
32 d1a7d66f Guido Trotter
OS_API_V15 = 15
33 d1a7d66f Guido Trotter
OS_API_VERSIONS = frozenset([OS_API_V10, OS_API_V15])
34 a8083063 Iustin Pop
EXPORT_VERSION = 0
35 bac5ffc3 Oleksiy Mishchenko
RAPI_VERSION = 2
36 a8083063 Iustin Pop
37 1b45f4e5 Michael Hanselmann
38 243cdbcc Michael Hanselmann
# Format for CONFIG_VERSION:
39 243cdbcc Michael Hanselmann
#   01 03 0123 = 01030123
40 243cdbcc Michael Hanselmann
#   ^^ ^^ ^^^^
41 243cdbcc Michael Hanselmann
#   |  |  + Configuration version/revision
42 243cdbcc Michael Hanselmann
#   |  + Minor version
43 243cdbcc Michael Hanselmann
#   + Major version
44 243cdbcc Michael Hanselmann
#
45 243cdbcc Michael Hanselmann
# It stored as an integer. Make sure not to write an octal number.
46 1b45f4e5 Michael Hanselmann
47 1b45f4e5 Michael Hanselmann
# BuildVersion and SplitVersion must be in here because we can't import other
48 1b45f4e5 Michael Hanselmann
# modules. The cfgupgrade tool must be able to read and write version numbers
49 1b45f4e5 Michael Hanselmann
# and thus requires these functions. To avoid code duplication, they're kept in
50 1b45f4e5 Michael Hanselmann
# here.
51 1b45f4e5 Michael Hanselmann
52 1b45f4e5 Michael Hanselmann
def BuildVersion(major, minor, revision):
53 1b45f4e5 Michael Hanselmann
  """Calculates int version number from major, minor and revision numbers.
54 1b45f4e5 Michael Hanselmann

55 1b45f4e5 Michael Hanselmann
  Returns: int representing version number
56 1b45f4e5 Michael Hanselmann

57 1b45f4e5 Michael Hanselmann
  """
58 1b45f4e5 Michael Hanselmann
  assert isinstance(major, int)
59 1b45f4e5 Michael Hanselmann
  assert isinstance(minor, int)
60 1b45f4e5 Michael Hanselmann
  assert isinstance(revision, int)
61 1b45f4e5 Michael Hanselmann
  return (1000000 * major +
62 1b45f4e5 Michael Hanselmann
            10000 * minor +
63 1b45f4e5 Michael Hanselmann
                1 * revision)
64 1b45f4e5 Michael Hanselmann
65 1b45f4e5 Michael Hanselmann
66 1b45f4e5 Michael Hanselmann
def SplitVersion(version):
67 1b45f4e5 Michael Hanselmann
  """Splits version number stored in an int.
68 1b45f4e5 Michael Hanselmann

69 1b45f4e5 Michael Hanselmann
  Returns: tuple; (major, minor, revision)
70 1b45f4e5 Michael Hanselmann

71 1b45f4e5 Michael Hanselmann
  """
72 1b45f4e5 Michael Hanselmann
  assert isinstance(version, int)
73 1b45f4e5 Michael Hanselmann
74 1b45f4e5 Michael Hanselmann
  (major, remainder) = divmod(version, 1000000)
75 1b45f4e5 Michael Hanselmann
  (minor, revision) = divmod(remainder, 10000)
76 1b45f4e5 Michael Hanselmann
77 1b45f4e5 Michael Hanselmann
  return (major, minor, revision)
78 1b45f4e5 Michael Hanselmann
79 1b45f4e5 Michael Hanselmann
80 243cdbcc Michael Hanselmann
CONFIG_MAJOR = int(_autoconf.VERSION_MAJOR)
81 243cdbcc Michael Hanselmann
CONFIG_MINOR = int(_autoconf.VERSION_MINOR)
82 243cdbcc Michael Hanselmann
CONFIG_REVISION = 0
83 1b45f4e5 Michael Hanselmann
CONFIG_VERSION = BuildVersion(CONFIG_MAJOR, CONFIG_MINOR, CONFIG_REVISION)
84 a8083063 Iustin Pop
85 a8083063 Iustin Pop
# file paths
86 2ec08468 Michael Hanselmann
DATA_DIR = _autoconf.LOCALSTATEDIR + "/lib/ganeti"
87 1ed70996 Iustin Pop
RUN_DIR = _autoconf.LOCALSTATEDIR + "/run"
88 75afaefc Iustin Pop
RUN_GANETI_DIR = RUN_DIR + "/ganeti"
89 42ff3343 Guido Trotter
BDEV_CACHE_DIR = RUN_GANETI_DIR + "/bdev-cache"
90 75afaefc Iustin Pop
DISK_LINKS_DIR = RUN_GANETI_DIR + "/instance-disks"
91 817a030d Guido Trotter
RUN_DIRS_MODE = 0755
92 b4442fd9 Guido Trotter
SOCKET_DIR = RUN_GANETI_DIR + "/socket"
93 5ecb7e48 Guido Trotter
SOCKET_DIR_MODE = 0700
94 75afaefc Iustin Pop
# keep RUN_GANETI_DIR first here, to make sure all get created when the node
95 75afaefc Iustin Pop
# daemon is started (this takes care of RUN_DIR being tmpfs)
96 75afaefc Iustin Pop
SUB_RUN_DIRS = [ RUN_GANETI_DIR, BDEV_CACHE_DIR, DISK_LINKS_DIR ]
97 3aecd2c7 Iustin Pop
LOCK_DIR = _autoconf.LOCALSTATEDIR + "/lock"
98 0c223ea9 Michael Hanselmann
SSCONF_LOCK_FILE = LOCK_DIR + "/ganeti-ssconf.lock"
99 a8083063 Iustin Pop
CLUSTER_CONF_FILE = DATA_DIR + "/config.data"
100 a8083063 Iustin Pop
SSL_CERT_FILE = DATA_DIR + "/server.pem"
101 61a08fa3 Michael Hanselmann
RAPI_CERT_FILE = DATA_DIR + "/rapi.pem"
102 4a34c5cf Guido Trotter
HMAC_CLUSTER_KEY = DATA_DIR + "/hmac.key"
103 5a3103e9 Michael Hanselmann
WATCHER_STATEFILE = DATA_DIR + "/watcher.data"
104 05e50653 Michael Hanselmann
WATCHER_PAUSEFILE = DATA_DIR + "/watcher.pause"
105 78f44650 Iustin Pop
INSTANCE_UPFILE = RUN_GANETI_DIR + "/instance-status"
106 82122173 Iustin Pop
SSH_KNOWN_HOSTS_FILE = DATA_DIR + "/known_hosts"
107 b5b67ef9 Michael Hanselmann
RAPI_USERS_FILE = DATA_DIR + "/rapi_users"
108 f1da30e6 Michael Hanselmann
QUEUE_DIR = DATA_DIR + "/queue"
109 f154a7a3 Michael Hanselmann
DAEMON_UTIL = _autoconf.PKGLIBDIR + "/daemon-util"
110 c8a0948f Michael Hanselmann
ETC_HOSTS = "/etc/hosts"
111 1abbbbe2 Manuel Franceschini
DEFAULT_FILE_STORAGE_DIR = _autoconf.FILE_STORAGE_DIR
112 5420ffc9 Guido Trotter
SYSCONFDIR = _autoconf.SYSCONFDIR
113 bea60381 Michael Hanselmann
TOOLSDIR = _autoconf.TOOLSDIR
114 131178b9 Luca Bigliardi
CONF_DIR = SYSCONFDIR + "/ganeti"
115 9894ece7 Michael Hanselmann
116 227647ac Guido Trotter
MASTER_SOCKET = SOCKET_DIR + "/ganeti-master"
117 a8083063 Iustin Pop
118 cd50653c Guido Trotter
NODED = "ganeti-noded"
119 18679072 Guido Trotter
CONFD = "ganeti-confd"
120 8c96d01f Guido Trotter
RAPI = "ganeti-rapi"
121 dae3fdd2 Guido Trotter
MASTERD = "ganeti-masterd"
122 cd50653c Guido Trotter
123 04ccf5e9 Guido Trotter
MULTITHREADED_DAEMONS = frozenset([MASTERD])
124 04ccf5e9 Guido Trotter
125 3b1b0cb6 Guido Trotter
DAEMONS_SSL = {
126 3b1b0cb6 Guido Trotter
  # daemon-name: (default-cert-path, default-key-path)
127 3b1b0cb6 Guido Trotter
  NODED: (SSL_CERT_FILE, SSL_CERT_FILE),
128 3b1b0cb6 Guido Trotter
  RAPI: (RAPI_CERT_FILE, RAPI_CERT_FILE),
129 3b1b0cb6 Guido Trotter
}
130 3b1b0cb6 Guido Trotter
131 cd50653c Guido Trotter
DAEMONS_PORTS = {
132 cd50653c Guido Trotter
  # daemon-name: ("proto", "default-port")
133 cd50653c Guido Trotter
  NODED: ("tcp", 1811),
134 18679072 Guido Trotter
  CONFD: ("udp", 1814),
135 8c96d01f Guido Trotter
  RAPI: ("tcp", 5080),
136 cd50653c Guido Trotter
}
137 cd50653c Guido Trotter
DEFAULT_NODED_PORT = DAEMONS_PORTS[NODED][1]
138 18679072 Guido Trotter
DEFAULT_CONFD_PORT = DAEMONS_PORTS[CONFD][1]
139 8c96d01f Guido Trotter
DEFAULT_RAPI_PORT = DAEMONS_PORTS[RAPI][1]
140 cd50653c Guido Trotter
141 a8083063 Iustin Pop
FIRST_DRBD_PORT = 11000
142 a8083063 Iustin Pop
LAST_DRBD_PORT = 14999
143 880478f8 Iustin Pop
MASTER_SCRIPT = "ganeti-master"
144 a8083063 Iustin Pop
145 9936bd63 Iustin Pop
LOG_DIR = _autoconf.LOCALSTATEDIR + "/log/ganeti/"
146 dae3fdd2 Guido Trotter
DAEMONS_LOGFILES = {
147 d73ef63f Michael Hanselmann
  # "daemon-name": "logfile"
148 d73ef63f Michael Hanselmann
  NODED: LOG_DIR + "node-daemon.log",
149 d73ef63f Michael Hanselmann
  CONFD: LOG_DIR + "conf-daemon.log",
150 d73ef63f Michael Hanselmann
  RAPI: LOG_DIR + "rapi-daemon.log",
151 d73ef63f Michael Hanselmann
  MASTERD: LOG_DIR + "master-daemon.log",
152 d73ef63f Michael Hanselmann
  }
153 9936bd63 Iustin Pop
LOG_OS_DIR = LOG_DIR + "os"
154 9936bd63 Iustin Pop
LOG_WATCHER = LOG_DIR + "watcher.log"
155 9936bd63 Iustin Pop
LOG_COMMANDS = LOG_DIR + "commands.log"
156 6abe9194 Iustin Pop
LOG_BURNIN = LOG_DIR + "burnin.log"
157 a8083063 Iustin Pop
158 7c3d51d4 Guido Trotter
OS_SEARCH_PATH = _autoconf.OS_SEARCH_PATH
159 68dccc07 Guido Trotter
EXPORT_DIR = _autoconf.EXPORT_DIR
160 a8083063 Iustin Pop
161 a8083063 Iustin Pop
EXPORT_CONF_FILE = "config.ini"
162 a8083063 Iustin Pop
163 2f2dbb4b Jun Futagawa
XEN_BOOTLOADER = _autoconf.XEN_BOOTLOADER
164 f00b46bc Michael Hanselmann
XEN_KERNEL = _autoconf.XEN_KERNEL
165 f00b46bc Michael Hanselmann
XEN_INITRD = _autoconf.XEN_INITRD
166 f00b46bc Michael Hanselmann
167 7e2c5b9e Guido Trotter
KVM_PATH = _autoconf.KVM_PATH
168 14aa53cb Guido Trotter
SOCAT_PATH = _autoconf.SOCAT_PATH
169 fe5b0c42 Michael Hanselmann
SOCAT_USE_ESCAPE = _autoconf.SOCAT_USE_ESCAPE
170 86d6bc2a Guido Trotter
SOCAT_ESCAPE_CODE = "0x1d"
171 7e2c5b9e Guido Trotter
172 973d7867 Iustin Pop
VALUE_DEFAULT = "default"
173 4c566ede Guido Trotter
VALUE_AUTO = "auto"
174 4c566ede Guido Trotter
VALUE_GENERATE = "generate"
175 973d7867 Iustin Pop
VALUE_NONE = "none"
176 1817f49b Guido Trotter
VALUE_TRUE = "true"
177 1817f49b Guido Trotter
VALUE_FALSE = "false"
178 973d7867 Iustin Pop
179 4fe80ef2 Iustin Pop
# External script validation mask
180 4fe80ef2 Iustin Pop
EXT_PLUGIN_MASK = re.compile("^[a-zA-Z0-9_-]+$")
181 4fe80ef2 Iustin Pop
182 a8083063 Iustin Pop
# hooks-related constants
183 131178b9 Luca Bigliardi
HOOKS_BASE_DIR = CONF_DIR + "/hooks"
184 a8083063 Iustin Pop
HOOKS_PHASE_PRE = "pre"
185 a8083063 Iustin Pop
HOOKS_PHASE_POST = "post"
186 6a4aa7c1 Iustin Pop
HOOKS_NAME_CFGUPDATE = "config-update"
187 f3e2e4c6 Iustin Pop
HOOKS_VERSION = 2
188 a8083063 Iustin Pop
189 a8083063 Iustin Pop
# hooks subject type (what object type does the LU deal with)
190 a8083063 Iustin Pop
HTYPE_CLUSTER = "CLUSTER"
191 a8083063 Iustin Pop
HTYPE_NODE = "NODE"
192 a8083063 Iustin Pop
HTYPE_INSTANCE = "INSTANCE"
193 a8083063 Iustin Pop
194 a8083063 Iustin Pop
HKR_SKIP = 0
195 a8083063 Iustin Pop
HKR_FAIL = 1
196 a8083063 Iustin Pop
HKR_SUCCESS = 2
197 a8083063 Iustin Pop
198 ac2d0fe4 Michael Hanselmann
# Storage types
199 ac2d0fe4 Michael Hanselmann
ST_FILE = "file"
200 ac2d0fe4 Michael Hanselmann
ST_LVM_PV = "lvm-pv"
201 ac2d0fe4 Michael Hanselmann
ST_LVM_VG = "lvm-vg"
202 6032697c Michael Hanselmann
203 6032697c Michael Hanselmann
# Storage fields
204 620a85fd Iustin Pop
# first two are valid in LU context only, not passed to backend
205 620a85fd Iustin Pop
SF_NODE = "node"
206 620a85fd Iustin Pop
SF_TYPE = "type"
207 620a85fd Iustin Pop
# and the rest are valid in backend
208 6032697c Michael Hanselmann
SF_NAME = "name"
209 6032697c Michael Hanselmann
SF_SIZE = "size"
210 6032697c Michael Hanselmann
SF_FREE = "free"
211 6032697c Michael Hanselmann
SF_USED = "used"
212 6032697c Michael Hanselmann
SF_ALLOCATABLE = "allocatable"
213 6032697c Michael Hanselmann
214 6c3c6db9 Michael Hanselmann
# Storage operations
215 6c3c6db9 Michael Hanselmann
SO_FIX_CONSISTENCY = "fix-consistency"
216 6c3c6db9 Michael Hanselmann
217 6032697c Michael Hanselmann
# Available fields per storage type
218 620a85fd Iustin Pop
VALID_STORAGE_FIELDS = frozenset([SF_NAME, SF_TYPE, SF_SIZE,
219 620a85fd Iustin Pop
                                  SF_USED, SF_FREE, SF_ALLOCATABLE])
220 620a85fd Iustin Pop
221 620a85fd Iustin Pop
VALID_STORAGE_TYPES = frozenset([ST_FILE, ST_LVM_PV, ST_LVM_VG])
222 a8083063 Iustin Pop
223 efb8da02 Michael Hanselmann
MODIFIABLE_STORAGE_FIELDS = {
224 efb8da02 Michael Hanselmann
  ST_LVM_PV: frozenset([SF_ALLOCATABLE]),
225 efb8da02 Michael Hanselmann
  }
226 efb8da02 Michael Hanselmann
227 4b37cac5 Michael Hanselmann
VALID_STORAGE_OPERATIONS = {
228 6c3c6db9 Michael Hanselmann
  ST_LVM_VG: frozenset([SO_FIX_CONSISTENCY]),
229 4b37cac5 Michael Hanselmann
  }
230 4b37cac5 Michael Hanselmann
231 74f37195 Michael Hanselmann
# Local disk status
232 74f37195 Michael Hanselmann
# Note: Code depends on LDS_OKAY < LDS_UNKNOWN < LDS_FAULTY
233 74f37195 Michael Hanselmann
(LDS_OKAY,
234 74f37195 Michael Hanselmann
 LDS_UNKNOWN,
235 74f37195 Michael Hanselmann
 LDS_FAULTY) = range(1, 4)
236 74f37195 Michael Hanselmann
237 a8083063 Iustin Pop
# disk template types
238 a8083063 Iustin Pop
DT_DISKLESS = "diskless"
239 a8083063 Iustin Pop
DT_PLAIN = "plain"
240 a1f445d3 Iustin Pop
DT_DRBD8 = "drbd"
241 04fa07f2 Manuel Franceschini
DT_FILE = "file"
242 a1f445d3 Iustin Pop
243 a1f445d3 Iustin Pop
# the set of network-mirrored disk templates
244 abdf0113 Iustin Pop
DTS_NET_MIRROR = frozenset([DT_DRBD8])
245 a8083063 Iustin Pop
246 d63e148a Manuel Franceschini
# the set of non-lvm-based disk templates
247 d63e148a Manuel Franceschini
DTS_NOT_LVM = frozenset([DT_DISKLESS, DT_FILE])
248 d63e148a Manuel Franceschini
249 fe96220b Iustin Pop
# logical disk types
250 fe96220b Iustin Pop
LD_LV = "lvm"
251 a1f445d3 Iustin Pop
LD_DRBD8 = "drbd8"
252 04fa07f2 Manuel Franceschini
LD_FILE = "file"
253 464736ae Guido Trotter
LDS_BLOCK = frozenset([LD_LV, LD_DRBD8])
254 04fa07f2 Manuel Franceschini
255 2899d9de Iustin Pop
# drbd constants
256 2899d9de Iustin Pop
DRBD_HMAC_ALG = "md5"
257 3c03759a Iustin Pop
DRBD_NET_PROTOCOL = "C"
258 2899d9de Iustin Pop
259 04fa07f2 Manuel Franceschini
# file backend driver
260 04fa07f2 Manuel Franceschini
FD_LOOP = "loop"
261 04fa07f2 Manuel Franceschini
FD_BLKTAP = "blktap"
262 a1f445d3 Iustin Pop
263 a1f445d3 Iustin Pop
# the set of drbd-like disk types
264 abdf0113 Iustin Pop
LDS_DRBD = frozenset([LD_DRBD8])
265 fe96220b Iustin Pop
266 08db7c5c Iustin Pop
# disk access mode
267 24991749 Iustin Pop
DISK_RDONLY = "ro"
268 24991749 Iustin Pop
DISK_RDWR = "rw"
269 08db7c5c Iustin Pop
DISK_ACCESS_SET = frozenset([DISK_RDONLY, DISK_RDWR])
270 08db7c5c Iustin Pop
271 a9e0c397 Iustin Pop
# disk replacement mode
272 cfacfd6e Iustin Pop
REPLACE_DISK_PRI = "replace_on_primary"    # replace disks on primary
273 cfacfd6e Iustin Pop
REPLACE_DISK_SEC = "replace_on_secondary"  # replace disks on secondary
274 cfacfd6e Iustin Pop
REPLACE_DISK_CHG = "replace_new_secondary" # change secondary node
275 942be002 Michael Hanselmann
REPLACE_DISK_AUTO = "replace_auto"
276 a9e0c397 Iustin Pop
277 f6d9a522 Guido Trotter
# lock recalculate mode
278 f6d9a522 Guido Trotter
LOCKS_REPLACE = 'replace'
279 9513b6ab Guido Trotter
LOCKS_APPEND = 'append'
280 f6d9a522 Guido Trotter
281 2f6eebee Guido Trotter
# instance creation modes
282 a8083063 Iustin Pop
INSTANCE_CREATE = "create"
283 a8083063 Iustin Pop
INSTANCE_IMPORT = "import"
284 a8083063 Iustin Pop
285 a8083063 Iustin Pop
DISK_TEMPLATES = frozenset([DT_DISKLESS, DT_PLAIN,
286 04fa07f2 Manuel Franceschini
                            DT_DRBD8, DT_FILE])
287 04fa07f2 Manuel Franceschini
288 04fa07f2 Manuel Franceschini
FILE_DRIVER = frozenset([FD_LOOP, FD_BLKTAP])
289 a8083063 Iustin Pop
290 a8083063 Iustin Pop
# import/export config options
291 a8083063 Iustin Pop
INISECT_EXP = "export"
292 a8083063 Iustin Pop
INISECT_INS = "instance"
293 38242904 Iustin Pop
294 24991749 Iustin Pop
# dynamic device modification
295 24991749 Iustin Pop
296 24991749 Iustin Pop
DDM_ADD = 'add'
297 24991749 Iustin Pop
DDM_REMOVE = 'remove'
298 24991749 Iustin Pop
299 38242904 Iustin Pop
# common exit codes
300 a5bc662a Iustin Pop
EXIT_SUCCESS = 0
301 438b45d4 Michael Hanselmann
EXIT_FAILURE = 1
302 46479775 Guido Trotter
EXIT_NOTCLUSTER = 5
303 38242904 Iustin Pop
EXIT_NOTMASTER = 11
304 619fdc8e Iustin Pop
EXIT_NODESETUP_ERROR = 12
305 a5bc662a Iustin Pop
EXIT_CONFIRMATION = 13 # need user confirmation
306 3f71b464 Guido Trotter
EXIT_NOTCANDIDATE = 14
307 cf62a272 Michael Hanselmann
308 5c947f38 Iustin Pop
# tags
309 5c947f38 Iustin Pop
TAG_CLUSTER = "cluster"
310 5c947f38 Iustin Pop
TAG_NODE = "node"
311 5c947f38 Iustin Pop
TAG_INSTANCE = "instance"
312 5c947f38 Iustin Pop
MAX_TAG_LEN = 128
313 5c947f38 Iustin Pop
MAX_TAGS_PER_OBJ = 4096
314 5c947f38 Iustin Pop
315 cf62a272 Michael Hanselmann
# others
316 cf62a272 Michael Hanselmann
DEFAULT_BRIDGE = "xen-br0"
317 24b0d752 Iustin Pop
SYNC_SPEED = 60 * 1024
318 aa4260ca Iustin Pop
LOCALHOST_IP_ADDRESS = "127.0.0.1"
319 16abfbc2 Alexander Schreiber
TCP_PING_TIMEOUT = 10
320 7900ed01 Iustin Pop
GANETI_RUNAS = "root"
321 d63e148a Manuel Franceschini
DEFAULT_VG = "xenvg"
322 31a853d2 Iustin Pop
BIND_ADDRESS_GLOBAL = "0.0.0.0"
323 8d1a2a64 Michael Hanselmann
MIN_VG_SIZE = 20480
324 c5e489f7 Iustin Pop
DEFAULT_MAC_PREFIX = "aa:00:00"
325 3736cb6b Iustin Pop
LVM_STRIPECOUNT = _autoconf.LVM_STRIPECOUNT
326 88cd08aa Guido Trotter
# default maximum instance wait time, in seconds.
327 88cd08aa Guido Trotter
DEFAULT_SHUTDOWN_TIMEOUT = 120
328 313b2dd4 Michael Hanselmann
NODE_MAX_CLOCK_SKEW = 150
329 7900ed01 Iustin Pop
330 12bce260 Michael Hanselmann
# RPC constants
331 12bce260 Michael Hanselmann
(RPC_ENCODING_NONE,
332 12bce260 Michael Hanselmann
 RPC_ENCODING_ZLIB_BASE64) = range(2)
333 12bce260 Michael Hanselmann
334 ded1c679 Guido Trotter
# os related constants
335 ded1c679 Guido Trotter
OS_SCRIPT_CREATE = 'create'
336 ded1c679 Guido Trotter
OS_SCRIPT_IMPORT = 'import'
337 ded1c679 Guido Trotter
OS_SCRIPT_EXPORT = 'export'
338 ded1c679 Guido Trotter
OS_SCRIPT_RENAME = 'rename'
339 16653425 Iustin Pop
OS_SCRIPTS = frozenset([OS_SCRIPT_CREATE, OS_SCRIPT_IMPORT,
340 ded1c679 Guido Trotter
                        OS_SCRIPT_EXPORT, OS_SCRIPT_RENAME])
341 37482e7b Guido Trotter
342 b6b45e0d Guido Trotter
OS_API_FILE = 'ganeti_api_version'
343 6d79896b Guido Trotter
OS_VARIANTS_FILE = 'variants.list'
344 b6b45e0d Guido Trotter
345 70d9e3d8 Iustin Pop
# ssh constants
346 70d9e3d8 Iustin Pop
SSH_CONFIG_DIR = "/etc/ssh/"
347 70d9e3d8 Iustin Pop
SSH_HOST_DSA_PRIV = SSH_CONFIG_DIR + "ssh_host_dsa_key"
348 70d9e3d8 Iustin Pop
SSH_HOST_DSA_PUB = SSH_HOST_DSA_PRIV + ".pub"
349 70d9e3d8 Iustin Pop
SSH_HOST_RSA_PRIV = SSH_CONFIG_DIR + "ssh_host_rsa_key"
350 70d9e3d8 Iustin Pop
SSH_HOST_RSA_PUB = SSH_HOST_RSA_PRIV + ".pub"
351 fff33d70 Michael Hanselmann
SSH = "ssh"
352 fff33d70 Michael Hanselmann
SCP = "scp"
353 007a2f3e Alexander Schreiber
354 007a2f3e Alexander Schreiber
# reboot types
355 007a2f3e Alexander Schreiber
INSTANCE_REBOOT_SOFT = "soft"
356 007a2f3e Alexander Schreiber
INSTANCE_REBOOT_HARD = "hard"
357 007a2f3e Alexander Schreiber
INSTANCE_REBOOT_FULL = "full"
358 2584d4a4 Alexander Schreiber
359 00f91f29 Iustin Pop
REBOOT_TYPES = frozenset([INSTANCE_REBOOT_SOFT,
360 00f91f29 Iustin Pop
                          INSTANCE_REBOOT_HARD,
361 00f91f29 Iustin Pop
                          INSTANCE_REBOOT_FULL])
362 00f91f29 Iustin Pop
363 a5728081 Guido Trotter
VTYPE_STRING = 'string'
364 a5728081 Guido Trotter
VTYPE_BOOL = 'bool'
365 a5728081 Guido Trotter
VTYPE_SIZE = 'size' # size, in MiBs
366 a5728081 Guido Trotter
VTYPE_INT = 'int'
367 a5728081 Guido Trotter
ENFORCEABLE_TYPES = frozenset([
368 a5728081 Guido Trotter
                      VTYPE_STRING,
369 a5728081 Guido Trotter
                      VTYPE_BOOL,
370 a5728081 Guido Trotter
                      VTYPE_SIZE,
371 a5728081 Guido Trotter
                      VTYPE_INT,
372 a5728081 Guido Trotter
                      ])
373 a5728081 Guido Trotter
374 e64b8beb Iustin Pop
# HV parameter names (global namespace)
375 e64b8beb Iustin Pop
HV_BOOT_ORDER = "boot_order"
376 e64b8beb Iustin Pop
HV_CDROM_IMAGE_PATH = "cdrom_image_path"
377 e64b8beb Iustin Pop
HV_NIC_TYPE = "nic_type"
378 e64b8beb Iustin Pop
HV_DISK_TYPE = "disk_type"
379 e64b8beb Iustin Pop
HV_VNC_BIND_ADDRESS = "vnc_bind_address"
380 6e6bb8d5 Guido Trotter
HV_VNC_PASSWORD_FILE = "vnc_password_file"
381 8b2d1013 Guido Trotter
HV_VNC_TLS = "vnc_tls"
382 8b2d1013 Guido Trotter
HV_VNC_X509 = "vnc_x509_path"
383 8b2d1013 Guido Trotter
HV_VNC_X509_VERIFY = "vnc_x509_verify"
384 e64b8beb Iustin Pop
HV_ACPI = "acpi"
385 e64b8beb Iustin Pop
HV_PAE = "pae"
386 2f2dbb4b Jun Futagawa
HV_USE_BOOTLOADER = "use_bootloader"
387 2f2dbb4b Jun Futagawa
HV_BOOTLOADER_ARGS = "bootloader_args"
388 2f2dbb4b Jun Futagawa
HV_BOOTLOADER_PATH = "bootloader_path"
389 f9d6542d Iustin Pop
HV_KERNEL_ARGS = "kernel_args"
390 e64b8beb Iustin Pop
HV_KERNEL_PATH = "kernel_path"
391 e64b8beb Iustin Pop
HV_INITRD_PATH = "initrd_path"
392 074ca009 Guido Trotter
HV_ROOT_PATH = "root_path"
393 a2faf9ee Guido Trotter
HV_SERIAL_CONSOLE = "serial_console"
394 11344a50 Guido Trotter
HV_USB_MOUSE = "usb_mouse"
395 09ea8710 Iustin Pop
HV_DEVICE_MODEL = "device_model"
396 48297fa2 Iustin Pop
HV_INIT_SCRIPT = "init_script"
397 78411c60 Iustin Pop
HV_MIGRATION_PORT = "migration_port"
398 6b970cef Jun Futagawa
HV_USE_LOCALTIME = "use_localtime"
399 19572932 Iustin Pop
HV_DISK_CACHE = "disk_cache"
400 e64b8beb Iustin Pop
401 a5728081 Guido Trotter
HVS_PARAMETER_TYPES = {
402 a5728081 Guido Trotter
  HV_BOOT_ORDER: VTYPE_STRING,
403 a5728081 Guido Trotter
  HV_CDROM_IMAGE_PATH: VTYPE_STRING,
404 a5728081 Guido Trotter
  HV_NIC_TYPE: VTYPE_STRING,
405 a5728081 Guido Trotter
  HV_DISK_TYPE: VTYPE_STRING,
406 6e6bb8d5 Guido Trotter
  HV_VNC_PASSWORD_FILE: VTYPE_STRING,
407 a5728081 Guido Trotter
  HV_VNC_BIND_ADDRESS: VTYPE_STRING,
408 a5728081 Guido Trotter
  HV_VNC_TLS: VTYPE_BOOL,
409 a5728081 Guido Trotter
  HV_VNC_X509: VTYPE_STRING,
410 a5728081 Guido Trotter
  HV_VNC_X509_VERIFY: VTYPE_BOOL,
411 a5728081 Guido Trotter
  HV_ACPI: VTYPE_BOOL,
412 a5728081 Guido Trotter
  HV_PAE: VTYPE_BOOL,
413 2f2dbb4b Jun Futagawa
  HV_USE_BOOTLOADER: VTYPE_BOOL,
414 2f2dbb4b Jun Futagawa
  HV_BOOTLOADER_PATH: VTYPE_STRING,
415 2f2dbb4b Jun Futagawa
  HV_BOOTLOADER_ARGS: VTYPE_STRING,
416 a5728081 Guido Trotter
  HV_KERNEL_PATH: VTYPE_STRING,
417 f9d6542d Iustin Pop
  HV_KERNEL_ARGS: VTYPE_STRING,
418 a5728081 Guido Trotter
  HV_INITRD_PATH: VTYPE_STRING,
419 a5728081 Guido Trotter
  HV_ROOT_PATH: VTYPE_STRING,
420 a5728081 Guido Trotter
  HV_SERIAL_CONSOLE: VTYPE_BOOL,
421 a5728081 Guido Trotter
  HV_USB_MOUSE: VTYPE_STRING,
422 09ea8710 Iustin Pop
  HV_DEVICE_MODEL: VTYPE_STRING,
423 48297fa2 Iustin Pop
  HV_INIT_SCRIPT: VTYPE_STRING,
424 78411c60 Iustin Pop
  HV_MIGRATION_PORT: VTYPE_INT,
425 6b970cef Jun Futagawa
  HV_USE_LOCALTIME: VTYPE_BOOL,
426 19572932 Iustin Pop
  HV_DISK_CACHE: VTYPE_STRING,
427 a5728081 Guido Trotter
  }
428 a5728081 Guido Trotter
429 a5728081 Guido Trotter
HVS_PARAMETERS = frozenset(HVS_PARAMETER_TYPES.keys())
430 5018a335 Iustin Pop
431 e64b8beb Iustin Pop
# BE parameter names
432 cd3ab26e Iustin Pop
BE_MEMORY = "memory"
433 e64b8beb Iustin Pop
BE_VCPUS = "vcpus"
434 c0f2b229 Iustin Pop
BE_AUTO_BALANCE = "auto_balance"
435 e64b8beb Iustin Pop
436 a5728081 Guido Trotter
BES_PARAMETER_TYPES = {
437 a5728081 Guido Trotter
    BE_MEMORY: VTYPE_SIZE,
438 a5728081 Guido Trotter
    BE_VCPUS: VTYPE_INT,
439 a5728081 Guido Trotter
    BE_AUTO_BALANCE: VTYPE_BOOL,
440 a5728081 Guido Trotter
    }
441 a5728081 Guido Trotter
442 a5728081 Guido Trotter
BES_PARAMETERS = frozenset(BES_PARAMETER_TYPES.keys())
443 cd3ab26e Iustin Pop
444 4ef7f423 Guido Trotter
# Instance Parameters Profile
445 4ef7f423 Guido Trotter
PP_DEFAULT = "default"
446 e64b8beb Iustin Pop
447 ac061be9 Guido Trotter
NIC_MODE = "mode"
448 ac061be9 Guido Trotter
NIC_LINK = "link"
449 ac061be9 Guido Trotter
450 ac061be9 Guido Trotter
NIC_MODE_BRIDGED = "bridged"
451 ac061be9 Guido Trotter
NIC_MODE_ROUTED = "routed"
452 ac061be9 Guido Trotter
453 ac061be9 Guido Trotter
NIC_VALID_MODES = frozenset([NIC_MODE_BRIDGED, NIC_MODE_ROUTED])
454 ac061be9 Guido Trotter
455 ac061be9 Guido Trotter
NICS_PARAMETER_TYPES = {
456 ac061be9 Guido Trotter
    NIC_MODE: VTYPE_STRING,
457 ac061be9 Guido Trotter
    NIC_LINK: VTYPE_STRING,
458 ac061be9 Guido Trotter
    }
459 ac061be9 Guido Trotter
460 ac061be9 Guido Trotter
NICS_PARAMETERS = frozenset(NICS_PARAMETER_TYPES.keys())
461 e64b8beb Iustin Pop
462 2584d4a4 Alexander Schreiber
# Hypervisor constants
463 00cd937c Iustin Pop
HT_XEN_PVM = "xen-pvm"
464 2584d4a4 Alexander Schreiber
HT_FAKE = "fake"
465 00cd937c Iustin Pop
HT_XEN_HVM = "xen-hvm"
466 550e49b9 Guido Trotter
HT_KVM = "kvm"
467 48297fa2 Iustin Pop
HT_CHROOT = "chroot"
468 48297fa2 Iustin Pop
HYPER_TYPES = frozenset([HT_XEN_PVM, HT_FAKE, HT_XEN_HVM, HT_KVM, HT_CHROOT])
469 fd4daa3a Guido Trotter
HTS_REQ_PORT = frozenset([HT_XEN_HVM, HT_KVM])
470 2584d4a4 Alexander Schreiber
471 377d74c9 Guido Trotter
VNC_BASE_PORT = 5900
472 131178b9 Luca Bigliardi
VNC_PASSWORD_FILE = CONF_DIR + "/vnc-cluster-password"
473 31a853d2 Iustin Pop
VNC_DEFAULT_BIND_ADDRESS = '0.0.0.0'
474 e54c4c5e Guido Trotter
475 835528af Iustin Pop
# NIC types
476 d08f6067 Guido Trotter
HT_NIC_RTL8139 = "rtl8139"
477 d08f6067 Guido Trotter
HT_NIC_NE2K_PCI = "ne2k_pci"
478 d08f6067 Guido Trotter
HT_NIC_NE2K_ISA = "ne2k_isa"
479 43440815 Guido Trotter
HT_NIC_I82551 = "i82551"
480 43440815 Guido Trotter
HT_NIC_I85557B = "i82557b"
481 43440815 Guido Trotter
HT_NIC_I8259ER = "i82559er"
482 43440815 Guido Trotter
HT_NIC_PCNET = "pcnet"
483 43440815 Guido Trotter
HT_NIC_E1000 = "e1000"
484 d08f6067 Guido Trotter
HT_NIC_PARAVIRTUAL = HT_DISK_PARAVIRTUAL = "paravirtual"
485 43440815 Guido Trotter
486 d08f6067 Guido Trotter
HT_HVM_VALID_NIC_TYPES = frozenset([HT_NIC_RTL8139, HT_NIC_NE2K_PCI,
487 d08f6067 Guido Trotter
                                    HT_NIC_NE2K_ISA, HT_NIC_PARAVIRTUAL])
488 43440815 Guido Trotter
HT_KVM_VALID_NIC_TYPES = frozenset([HT_NIC_RTL8139, HT_NIC_NE2K_PCI,
489 43440815 Guido Trotter
                                    HT_NIC_NE2K_ISA, HT_NIC_I82551,
490 43440815 Guido Trotter
                                    HT_NIC_I85557B, HT_NIC_I8259ER,
491 43440815 Guido Trotter
                                    HT_NIC_PCNET, HT_NIC_E1000,
492 43440815 Guido Trotter
                                    HT_NIC_PARAVIRTUAL])
493 835528af Iustin Pop
# Disk types
494 835528af Iustin Pop
HT_DISK_IOEMU = "ioemu"
495 835528af Iustin Pop
HT_DISK_IDE = "ide"
496 835528af Iustin Pop
HT_DISK_SCSI = "scsi"
497 835528af Iustin Pop
HT_DISK_SD = "sd"
498 835528af Iustin Pop
HT_DISK_MTD = "mtd"
499 835528af Iustin Pop
HT_DISK_PFLASH = "pflash"
500 835528af Iustin Pop
501 19572932 Iustin Pop
HT_CACHE_DEFAULT = "default"
502 19572932 Iustin Pop
HT_CACHE_NONE = "none"
503 19572932 Iustin Pop
HT_CACHE_WTHROUGH = "writethrough"
504 19572932 Iustin Pop
HT_CACHE_WBACK = "writeback"
505 19572932 Iustin Pop
HT_VALID_CACHE_TYPES = frozenset([HT_CACHE_DEFAULT,
506 19572932 Iustin Pop
                                  HT_CACHE_NONE,
507 19572932 Iustin Pop
                                  HT_CACHE_WTHROUGH,
508 19572932 Iustin Pop
                                  HT_CACHE_WBACK])
509 19572932 Iustin Pop
510 835528af Iustin Pop
HT_HVM_VALID_DISK_TYPES = frozenset([HT_DISK_PARAVIRTUAL, HT_DISK_IOEMU])
511 43440815 Guido Trotter
HT_KVM_VALID_DISK_TYPES = frozenset([HT_DISK_PARAVIRTUAL, HT_DISK_IDE,
512 43440815 Guido Trotter
                                     HT_DISK_SCSI, HT_DISK_SD, HT_DISK_MTD,
513 43440815 Guido Trotter
                                     HT_DISK_PFLASH])
514 b894f5a8 Alexander Schreiber
515 835528af Iustin Pop
# Mouse types:
516 835528af Iustin Pop
HT_MOUSE_MOUSE = "mouse"
517 835528af Iustin Pop
HT_MOUSE_TABLET = "tablet"
518 835528af Iustin Pop
519 835528af Iustin Pop
HT_KVM_VALID_MOUSE_TYPES = frozenset([HT_MOUSE_MOUSE, HT_MOUSE_TABLET])
520 835528af Iustin Pop
521 835528af Iustin Pop
# Boot order
522 835528af Iustin Pop
HT_BO_CDROM = "cdrom"
523 835528af Iustin Pop
HT_BO_DISK = "disk"
524 835528af Iustin Pop
HT_BO_NETWORK = "network"
525 835528af Iustin Pop
526 835528af Iustin Pop
HT_KVM_VALID_BO_TYPES = frozenset([HT_BO_CDROM, HT_BO_DISK, HT_BO_NETWORK])
527 835528af Iustin Pop
528 e54c4c5e Guido Trotter
# Cluster Verify steps
529 e54c4c5e Guido Trotter
VERIFY_NPLUSONE_MEM = 'nplusone_mem'
530 e54c4c5e Guido Trotter
VERIFY_OPTIONAL_CHECKS = frozenset([VERIFY_NPLUSONE_MEM])
531 e54c4c5e Guido Trotter
532 25361b9a Iustin Pop
# Node verify constants
533 25361b9a Iustin Pop
NV_FILELIST = "filelist"
534 25361b9a Iustin Pop
NV_HVINFO = "hvinfo"
535 25361b9a Iustin Pop
NV_HYPERVISOR = "hypervisor"
536 25361b9a Iustin Pop
NV_INSTANCELIST = "instancelist"
537 25361b9a Iustin Pop
NV_NODELIST = "nodelist"
538 25361b9a Iustin Pop
NV_NODENETTEST = "node-net-test"
539 25361b9a Iustin Pop
NV_VERSION = "version"
540 25361b9a Iustin Pop
NV_VGLIST = "vglist"
541 d091393e Iustin Pop
NV_LVLIST = "lvlist"
542 d091393e Iustin Pop
NV_PVLIST = "pvlist"
543 6d2e83d5 Iustin Pop
NV_DRBDLIST = "drbd-list"
544 7c0aa8e9 Iustin Pop
NV_NODESETUP = "nodesetup"
545 313b2dd4 Michael Hanselmann
NV_TIME = "time"
546 25361b9a Iustin Pop
547 d61df03e Iustin Pop
# Allocator framework constants
548 77031881 Iustin Pop
IALLOCATOR_VERSION = 2
549 298fe380 Iustin Pop
IALLOCATOR_DIR_IN = "in"
550 298fe380 Iustin Pop
IALLOCATOR_DIR_OUT = "out"
551 298fe380 Iustin Pop
IALLOCATOR_MODE_ALLOC = "allocate"
552 298fe380 Iustin Pop
IALLOCATOR_MODE_RELOC = "relocate"
553 298fe380 Iustin Pop
IALLOCATOR_SEARCH_PATH = _autoconf.IALLOCATOR_SEARCH_PATH
554 5f33b613 Michael Hanselmann
555 f1da30e6 Michael Hanselmann
# Job queue
556 f1da30e6 Michael Hanselmann
JOB_QUEUE_VERSION = 1
557 f1da30e6 Michael Hanselmann
JOB_QUEUE_LOCK_FILE = QUEUE_DIR + "/lock"
558 f1da30e6 Michael Hanselmann
JOB_QUEUE_VERSION_FILE = QUEUE_DIR + "/version"
559 f1da30e6 Michael Hanselmann
JOB_QUEUE_SERIAL_FILE = QUEUE_DIR + "/serial"
560 0cb94105 Michael Hanselmann
JOB_QUEUE_ARCHIVE_DIR = QUEUE_DIR + "/archive"
561 686d7433 Iustin Pop
JOB_QUEUE_DRAIN_FILE = QUEUE_DIR + "/drain"
562 f87b405e Michael Hanselmann
JOB_QUEUE_SIZE_HARD_LIMIT = 5000
563 f87b405e Michael Hanselmann
JOB_QUEUE_SIZE_SOFT_LIMIT = JOB_QUEUE_SIZE_HARD_LIMIT * 0.8
564 f1da30e6 Michael Hanselmann
565 bac5ffc3 Oleksiy Mishchenko
JOB_ID_TEMPLATE = r"\d+"
566 bac5ffc3 Oleksiy Mishchenko
567 5c735209 Iustin Pop
# unchanged job return
568 5c735209 Iustin Pop
JOB_NOTCHANGED = "nochange"
569 5c735209 Iustin Pop
570 5f33b613 Michael Hanselmann
# Job status
571 5f33b613 Michael Hanselmann
JOB_STATUS_QUEUED = "queued"
572 e92376d7 Iustin Pop
JOB_STATUS_WAITLOCK = "waiting"
573 fbf0262f Michael Hanselmann
JOB_STATUS_CANCELING = "canceling"
574 5f33b613 Michael Hanselmann
JOB_STATUS_RUNNING = "running"
575 5f33b613 Michael Hanselmann
JOB_STATUS_CANCELED = "canceled"
576 5f33b613 Michael Hanselmann
JOB_STATUS_SUCCESS = "success"
577 5f33b613 Michael Hanselmann
JOB_STATUS_ERROR = "error"
578 5f33b613 Michael Hanselmann
579 34327f51 Iustin Pop
# OpCode status
580 34327f51 Iustin Pop
# not yet finalized
581 5f33b613 Michael Hanselmann
OP_STATUS_QUEUED = "queued"
582 e92376d7 Iustin Pop
OP_STATUS_WAITLOCK = "waiting"
583 fbf0262f Michael Hanselmann
OP_STATUS_CANCELING = "canceling"
584 5f33b613 Michael Hanselmann
OP_STATUS_RUNNING = "running"
585 34327f51 Iustin Pop
# finalized
586 4cb1d919 Michael Hanselmann
OP_STATUS_CANCELED = "canceled"
587 5f33b613 Michael Hanselmann
OP_STATUS_SUCCESS = "success"
588 5f33b613 Michael Hanselmann
OP_STATUS_ERROR = "error"
589 34327f51 Iustin Pop
OPS_FINALIZED = frozenset([OP_STATUS_CANCELED,
590 34327f51 Iustin Pop
                           OP_STATUS_SUCCESS,
591 34327f51 Iustin Pop
                           OP_STATUS_ERROR])
592 f1048938 Iustin Pop
593 f1048938 Iustin Pop
# Execution log types
594 f1048938 Iustin Pop
ELOG_MESSAGE = "message"
595 f1048938 Iustin Pop
ELOG_PROGRESS = "progress"
596 d4104181 Iustin Pop
597 c5e489f7 Iustin Pop
# max dynamic devices
598 24991749 Iustin Pop
MAX_NICS = 8
599 24991749 Iustin Pop
MAX_DISKS = 16
600 24991749 Iustin Pop
601 93384844 Iustin Pop
# SSCONF keys
602 93384844 Iustin Pop
SS_CLUSTER_NAME = "cluster_name"
603 5d60b3bd Iustin Pop
SS_CLUSTER_TAGS = "cluster_tags"
604 93384844 Iustin Pop
SS_FILE_STORAGE_DIR = "file_storage_dir"
605 f56618e0 Iustin Pop
SS_MASTER_CANDIDATES = "master_candidates"
606 8113a52e Luca Bigliardi
SS_MASTER_CANDIDATES_IPS = "master_candidates_ips"
607 93384844 Iustin Pop
SS_MASTER_IP = "master_ip"
608 93384844 Iustin Pop
SS_MASTER_NETDEV = "master_netdev"
609 93384844 Iustin Pop
SS_MASTER_NODE = "master_node"
610 93384844 Iustin Pop
SS_NODE_LIST = "node_list"
611 f9780ccd Luca Bigliardi
SS_NODE_PRIMARY_IPS = "node_primary_ips"
612 f9780ccd Luca Bigliardi
SS_NODE_SECONDARY_IPS = "node_secondary_ips"
613 a3316e4a Iustin Pop
SS_OFFLINE_NODES = "offline_nodes"
614 81a49123 Iustin Pop
SS_ONLINE_NODES = "online_nodes"
615 81a49123 Iustin Pop
SS_INSTANCE_LIST = "instance_list"
616 8a113c7a Iustin Pop
SS_RELEASE_VERSION = "release_version"
617 93384844 Iustin Pop
618 7888a614 Alexander Schreiber
# cluster wide default parameters
619 7888a614 Alexander Schreiber
DEFAULT_ENABLED_HYPERVISOR = HT_XEN_PVM
620 7888a614 Alexander Schreiber
621 7888a614 Alexander Schreiber
HVC_DEFAULTS = {
622 bd0ff7c2 Iustin Pop
  HT_XEN_PVM: {
623 2f2dbb4b Jun Futagawa
    HV_USE_BOOTLOADER: False,
624 2f2dbb4b Jun Futagawa
    HV_BOOTLOADER_PATH: XEN_BOOTLOADER,
625 2f2dbb4b Jun Futagawa
    HV_BOOTLOADER_ARGS: '',
626 bd0ff7c2 Iustin Pop
    HV_KERNEL_PATH: "/boot/vmlinuz-2.6-xenU",
627 a5728081 Guido Trotter
    HV_INITRD_PATH: '',
628 1cd8141c Guido Trotter
    HV_ROOT_PATH: '/dev/sda1',
629 f9d6542d Iustin Pop
    HV_KERNEL_ARGS: 'ro',
630 78411c60 Iustin Pop
    HV_MIGRATION_PORT: 8002,
631 bd0ff7c2 Iustin Pop
    },
632 bd0ff7c2 Iustin Pop
  HT_XEN_HVM: {
633 bd0ff7c2 Iustin Pop
    HV_BOOT_ORDER: "cd",
634 a5728081 Guido Trotter
    HV_CDROM_IMAGE_PATH: '',
635 d08f6067 Guido Trotter
    HV_NIC_TYPE: HT_NIC_RTL8139,
636 43440815 Guido Trotter
    HV_DISK_TYPE: HT_DISK_PARAVIRTUAL,
637 bd0ff7c2 Iustin Pop
    HV_VNC_BIND_ADDRESS: '0.0.0.0',
638 6e6bb8d5 Guido Trotter
    HV_VNC_PASSWORD_FILE: VNC_PASSWORD_FILE,
639 bd0ff7c2 Iustin Pop
    HV_ACPI: True,
640 bd0ff7c2 Iustin Pop
    HV_PAE: True,
641 e2ee1cea Iustin Pop
    HV_KERNEL_PATH: "/usr/lib/xen/boot/hvmloader",
642 09ea8710 Iustin Pop
    HV_DEVICE_MODEL: "/usr/lib/xen/bin/qemu-dm",
643 78411c60 Iustin Pop
    HV_MIGRATION_PORT: 8002,
644 6b970cef Jun Futagawa
    HV_USE_LOCALTIME: False,
645 bd0ff7c2 Iustin Pop
    },
646 bd0ff7c2 Iustin Pop
  HT_KVM: {
647 bd0ff7c2 Iustin Pop
    HV_KERNEL_PATH: "/boot/vmlinuz-2.6-kvmU",
648 a5728081 Guido Trotter
    HV_INITRD_PATH: '',
649 f9d6542d Iustin Pop
    HV_KERNEL_ARGS: 'ro',
650 1cd8141c Guido Trotter
    HV_ROOT_PATH: '/dev/vda1',
651 bd0ff7c2 Iustin Pop
    HV_ACPI: True,
652 bd0ff7c2 Iustin Pop
    HV_SERIAL_CONSOLE: True,
653 a5728081 Guido Trotter
    HV_VNC_BIND_ADDRESS: '',
654 8b2d1013 Guido Trotter
    HV_VNC_TLS: False,
655 8b2d1013 Guido Trotter
    HV_VNC_X509: '',
656 8b2d1013 Guido Trotter
    HV_VNC_X509_VERIFY: False,
657 6e6bb8d5 Guido Trotter
    HV_VNC_PASSWORD_FILE: '',
658 a5728081 Guido Trotter
    HV_CDROM_IMAGE_PATH: '',
659 835528af Iustin Pop
    HV_BOOT_ORDER: HT_BO_DISK,
660 43440815 Guido Trotter
    HV_NIC_TYPE: HT_NIC_PARAVIRTUAL,
661 43440815 Guido Trotter
    HV_DISK_TYPE: HT_DISK_PARAVIRTUAL,
662 a5728081 Guido Trotter
    HV_USB_MOUSE: '',
663 3c075436 Iustin Pop
    HV_MIGRATION_PORT: 8102,
664 6b970cef Jun Futagawa
    HV_USE_LOCALTIME: False,
665 19572932 Iustin Pop
    HV_DISK_CACHE: HT_CACHE_DEFAULT,
666 bd0ff7c2 Iustin Pop
    },
667 bd0ff7c2 Iustin Pop
  HT_FAKE: {
668 bd0ff7c2 Iustin Pop
    },
669 48297fa2 Iustin Pop
  HT_CHROOT: {
670 48297fa2 Iustin Pop
    HV_INIT_SCRIPT: "/ganeti-chroot",
671 48297fa2 Iustin Pop
    },
672 bd0ff7c2 Iustin Pop
  }
673 7888a614 Alexander Schreiber
674 7736a5f2 Iustin Pop
HVC_GLOBALS = frozenset([
675 7736a5f2 Iustin Pop
  HV_MIGRATION_PORT,
676 7736a5f2 Iustin Pop
  ])
677 7736a5f2 Iustin Pop
678 7888a614 Alexander Schreiber
BEC_DEFAULTS = {
679 bd0ff7c2 Iustin Pop
  BE_MEMORY: 128,
680 bd0ff7c2 Iustin Pop
  BE_VCPUS: 1,
681 bd0ff7c2 Iustin Pop
  BE_AUTO_BALANCE: True,
682 bd0ff7c2 Iustin Pop
  }
683 c3e618cc Guido Trotter
684 ac061be9 Guido Trotter
NICC_DEFAULTS = {
685 ac061be9 Guido Trotter
  NIC_MODE: NIC_MODE_BRIDGED,
686 ac061be9 Guido Trotter
  NIC_LINK: DEFAULT_BRIDGE,
687 ac061be9 Guido Trotter
  }
688 ac061be9 Guido Trotter
689 c3e618cc Guido Trotter
MASTER_POOL_SIZE_DEFAULT = 10
690 ea1518af Guido Trotter
691 ea1518af Guido Trotter
CONFD_PROTOCOL_VERSION = 1
692 ea1518af Guido Trotter
693 09444532 Guido Trotter
CONFD_REQ_PING = 0
694 ea1518af Guido Trotter
CONFD_REQ_NODE_ROLE_BYNAME = 1
695 ea1518af Guido Trotter
CONFD_REQ_NODE_PIP_BY_INSTANCE_IP = 2
696 48166551 Guido Trotter
CONFD_REQ_CLUSTER_MASTER = 3
697 efbb4fd2 Luca Bigliardi
CONFD_REQ_NODE_PIP_LIST = 4
698 efbb4fd2 Luca Bigliardi
CONFD_REQ_MC_PIP_LIST = 5
699 d01ae714 Luca Bigliardi
CONFD_REQ_INSTANCES_IPS_LIST = 6
700 ea1518af Guido Trotter
701 19351457 Guido Trotter
# Confd request query fields. These are used to narrow down queries.
702 19351457 Guido Trotter
# These must be strings rather than integers, because json-encoding
703 19351457 Guido Trotter
# converts them to strings anyway, as they're used as dict-keys.
704 19351457 Guido Trotter
CONFD_REQQ_LINK = "0"
705 19351457 Guido Trotter
CONFD_REQQ_IP = "1"
706 19351457 Guido Trotter
CONFD_REQQ_IPLIST = "2"
707 250554a9 Guido Trotter
CONFD_REQQ_FIELDS = "3"
708 250554a9 Guido Trotter
709 250554a9 Guido Trotter
CONFD_REQFIELD_NAME = "0"
710 250554a9 Guido Trotter
CONFD_REQFIELD_IP = "1"
711 43dc8496 Guido Trotter
CONFD_REQFIELD_MNODE_PIP = "2"
712 19351457 Guido Trotter
713 ea1518af Guido Trotter
CONFD_REQS = frozenset([
714 09444532 Guido Trotter
  CONFD_REQ_PING,
715 ea1518af Guido Trotter
  CONFD_REQ_NODE_ROLE_BYNAME,
716 ea1518af Guido Trotter
  CONFD_REQ_NODE_PIP_BY_INSTANCE_IP,
717 48166551 Guido Trotter
  CONFD_REQ_CLUSTER_MASTER,
718 efbb4fd2 Luca Bigliardi
  CONFD_REQ_NODE_PIP_LIST,
719 efbb4fd2 Luca Bigliardi
  CONFD_REQ_MC_PIP_LIST,
720 d01ae714 Luca Bigliardi
  CONFD_REQ_INSTANCES_IPS_LIST,
721 ea1518af Guido Trotter
  ])
722 ea1518af Guido Trotter
723 31c2a99e Guido Trotter
CONFD_REPL_STATUS_OK = 0
724 31c2a99e Guido Trotter
CONFD_REPL_STATUS_ERROR = 1
725 31c2a99e Guido Trotter
CONFD_REPL_STATUS_NOTIMPLEMENTED = 2
726 31c2a99e Guido Trotter
727 31c2a99e Guido Trotter
CONFD_REPL_STATUSES = frozenset([
728 31c2a99e Guido Trotter
  CONFD_REPL_STATUS_OK,
729 31c2a99e Guido Trotter
  CONFD_REPL_STATUS_ERROR,
730 31c2a99e Guido Trotter
  CONFD_REPL_STATUS_NOTIMPLEMENTED,
731 31c2a99e Guido Trotter
  ])
732 31c2a99e Guido Trotter
733 89c52785 Guido Trotter
(CONFD_NODE_ROLE_MASTER,
734 89c52785 Guido Trotter
 CONFD_NODE_ROLE_CANDIDATE,
735 89c52785 Guido Trotter
 CONFD_NODE_ROLE_OFFLINE,
736 197b0f5d Guido Trotter
 CONFD_NODE_ROLE_DRAINED,
737 197b0f5d Guido Trotter
 CONFD_NODE_ROLE_REGULAR,
738 197b0f5d Guido Trotter
 ) = range(5)
739 89c52785 Guido Trotter
740 ca2a5b13 Guido Trotter
# A few common errors for confd
741 ca2a5b13 Guido Trotter
CONFD_ERROR_UNKNOWN_ENTRY = 1
742 7189e790 Guido Trotter
CONFD_ERROR_INTERNAL = 2
743 19351457 Guido Trotter
CONFD_ERROR_ARGUMENT = 3
744 ca2a5b13 Guido Trotter
745 71f27d19 Guido Trotter
# Each request is "salted" by the current timestamp.
746 71f27d19 Guido Trotter
# This constants decides how many seconds of skew to accept.
747 71f27d19 Guido Trotter
# TODO: make this a default and allow the value to be more configurable
748 313b2dd4 Michael Hanselmann
CONFD_MAX_CLOCK_SKEW = 2 * NODE_MAX_CLOCK_SKEW
749 84c3ab28 Guido Trotter
750 84c3ab28 Guido Trotter
# When we haven't reloaded the config for more than this amount of seconds, we
751 84c3ab28 Guido Trotter
# force a test to see if inotify is betraying us.
752 84c3ab28 Guido Trotter
CONFD_CONFIG_RELOAD_TIMEOUT = 60
753 84c3ab28 Guido Trotter
754 84c3ab28 Guido Trotter
# If we receive more than one update in this amount of seconds, we move to
755 84c3ab28 Guido Trotter
# polling every RATELIMIT seconds, rather than relying on inotify, to be able
756 84c3ab28 Guido Trotter
# to serve more requests.
757 84c3ab28 Guido Trotter
CONFD_CONFIG_RELOAD_RATELIMIT = 2
758 c8eded0b Guido Trotter
759 a3758ab2 Guido Trotter
# Magic number prepended to all confd queries.
760 a3758ab2 Guido Trotter
# This allows us to distinguish different types of confd protocols and handle
761 a3758ab2 Guido Trotter
# them. For example by changing this we can move the whole payload to be
762 a3758ab2 Guido Trotter
# compressed, or move away from json.
763 a3758ab2 Guido Trotter
CONFD_MAGIC_FOURCC = 'plj0'
764 a3758ab2 Guido Trotter
765 e4ccf6cd Guido Trotter
# By default a confd request is sent to the minimum between this number and all
766 e4ccf6cd Guido Trotter
# MCs. 6 was chosen because even in the case of a disastrous 50% response rate,
767 e4ccf6cd Guido Trotter
# we should have enough answers to be able to compare more than one.
768 e4ccf6cd Guido Trotter
CONFD_DEFAULT_REQ_COVERAGE = 6
769 e4ccf6cd Guido Trotter
770 e4ccf6cd Guido Trotter
# Timeout in seconds to expire pending query request in the confd client
771 e4ccf6cd Guido Trotter
# library. We don't actually expect any answer more than 10 seconds after we
772 e4ccf6cd Guido Trotter
# sent a request.
773 e4ccf6cd Guido Trotter
CONFD_CLIENT_EXPIRE_TIMEOUT = 10
774 e4ccf6cd Guido Trotter
775 c8eded0b Guido Trotter
# Maximum UDP datagram size.
776 c8eded0b Guido Trotter
# On IPv4: 64K - 20 (ip header size) - 8 (udp header size) = 65507
777 c8eded0b Guido Trotter
# On IPv6: 64K - 40 (ip6 header size) - 8 (udp header size) = 65487
778 c8eded0b Guido Trotter
#   (assuming we can't use jumbo frames)
779 c8eded0b Guido Trotter
# We just set this to 60K, which should be enough
780 c8eded0b Guido Trotter
MAX_UDP_DATA_SIZE = 61440