Statistics
| Branch: | Tag: | Revision:

root / lib / constants.py @ 7ba594c0

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