ea014c796e46deb7e7855d6db365218f57a42410
[ganeti-local] / lib / constants.py
1 #
2 #
3
4 # Copyright (C) 2006, 2007 Google Inc.
5 #
6 # This program is free software; you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License as published by
8 # the Free Software Foundation; either version 2 of the License, or
9 # (at your option) any later version.
10 #
11 # This program is distributed in the hope that it will be useful, but
12 # WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 # General Public License for more details.
15 #
16 # You should have received a copy of the GNU General Public License
17 # along with this program; if not, write to the Free Software
18 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19 # 02110-1301, USA.
20
21
22 """Module holding different constants."""
23
24 from ganeti import _autoconf
25
26 # various versions
27 CONFIG_VERSION = 3
28 PROTOCOL_VERSION = 15
29 RELEASE_VERSION = _autoconf.PACKAGE_VERSION
30 OS_API_VERSION = 5
31 EXPORT_VERSION = 0
32 RAPI_VERSION = 1
33
34
35 # file paths
36 DATA_DIR = _autoconf.LOCALSTATEDIR + "/lib/ganeti"
37 RUN_DIR = _autoconf.LOCALSTATEDIR + "/run"
38 RUN_GANETI_DIR = RUN_DIR + "/ganeti"
39 BDEV_CACHE_DIR = RUN_GANETI_DIR # TODO(2.0): move deeper
40 DISK_LINKS_DIR = RUN_GANETI_DIR + "/instance-disks"
41 # keep RUN_GANETI_DIR first here, to make sure all get created when the node
42 # daemon is started (this takes care of RUN_DIR being tmpfs)
43 SUB_RUN_DIRS = [ RUN_GANETI_DIR, BDEV_CACHE_DIR, DISK_LINKS_DIR ]
44 LOCK_DIR = _autoconf.LOCALSTATEDIR + "/lock"
45 CLUSTER_CONF_FILE = DATA_DIR + "/config.data"
46 SSL_CERT_FILE = DATA_DIR + "/server.pem"
47 WATCHER_STATEFILE = DATA_DIR + "/watcher.data"
48 SSH_KNOWN_HOSTS_FILE = DATA_DIR + "/known_hosts"
49 ETC_HOSTS = "/etc/hosts"
50
51 NODE_INITD_SCRIPT = _autoconf.SYSCONFDIR + "/init.d/ganeti"
52 DEFAULT_NODED_PORT = 1811
53 FIRST_DRBD_PORT = 11000
54 LAST_DRBD_PORT = 14999
55 MASTER_SCRIPT = "ganeti-master"
56
57 LOG_DIR = _autoconf.LOCALSTATEDIR + "/log/ganeti"
58 LOG_OS_DIR = LOG_DIR + "/os"
59 LOG_NODESERVER = LOG_DIR + "/node-daemon.log"
60 LOG_RAPISERVER = LOG_DIR + "/rapi-daemon.log"
61 LOG_RAPIACCESS = LOG_DIR + "/rapi-access.log"
62 LOG_WATCHER = LOG_DIR + "/watcher.log"
63
64 OS_SEARCH_PATH = _autoconf.OS_SEARCH_PATH
65 EXPORT_DIR = _autoconf.EXPORT_DIR
66
67 EXPORT_CONF_FILE = "config.ini"
68
69 XEN_KERNEL = _autoconf.XEN_KERNEL
70 XEN_INITRD = _autoconf.XEN_INITRD
71
72 VALUE_DEFAULT = "default"
73 VALUE_AUTO = "auto"
74 VALUE_GENERATE = "generate"
75 VALUE_NONE = "none"
76
77 # hooks-related constants
78 HOOKS_BASE_DIR = _autoconf.SYSCONFDIR + "/ganeti/hooks"
79 HOOKS_PHASE_PRE = "pre"
80 HOOKS_PHASE_POST = "post"
81 HOOKS_NAME_CFGUPDATE = "config-update"
82 HOOKS_VERSION = 1
83
84 # hooks subject type (what object type does the LU deal with)
85 HTYPE_CLUSTER = "CLUSTER"
86 HTYPE_NODE = "NODE"
87 HTYPE_INSTANCE = "INSTANCE"
88
89 HKR_SKIP = 0
90 HKR_FAIL = 1
91 HKR_SUCCESS = 2
92
93 # disk template types
94 DT_DISKLESS = "diskless"
95 DT_PLAIN = "plain"
96 DT_LOCAL_RAID1 = "local_raid1"
97 DT_REMOTE_RAID1 = "remote_raid1"
98 DT_DRBD8 = "drbd"
99
100 # the set of network-mirrored disk templates
101 DTS_NET_MIRROR = frozenset([DT_REMOTE_RAID1, DT_DRBD8])
102
103 # logical disk types
104 LD_LV = "lvm"
105 LD_MD_R1 = "md_raid1"
106 LD_DRBD7 = "drbd"
107 LD_DRBD8 = "drbd8"
108
109 # the set of drbd-like disk types
110 LDS_DRBD = frozenset([LD_DRBD7, LD_DRBD8])
111
112 # disk replacement mode
113 REPLACE_DISK_PRI = "replace_primary"
114 REPLACE_DISK_SEC = "replace_secondary"
115 REPLACE_DISK_ALL = "replace_all"
116
117 # instance creation modes
118 INSTANCE_CREATE = "create"
119 INSTANCE_IMPORT = "import"
120
121 DISK_TEMPLATES = frozenset([DT_DISKLESS, DT_PLAIN,
122                             DT_LOCAL_RAID1, DT_REMOTE_RAID1,
123                             DT_DRBD8])
124
125 # import/export config options
126 INISECT_EXP = "export"
127 INISECT_INS = "instance"
128
129 # common exit codes
130 EXIT_SUCCESS = 0
131 EXIT_FAILURE = 1
132 EXIT_NOTMASTER = 11
133 EXIT_NODESETUP_ERROR = 12
134 EXIT_CONFIRMATION = 13 # need user confirmation
135
136 # tags
137 TAG_CLUSTER = "cluster"
138 TAG_NODE = "node"
139 TAG_INSTANCE = "instance"
140 MAX_TAG_LEN = 64
141 MAX_TAGS_PER_OBJ = 48
142
143 # others
144 DEFAULT_BRIDGE = "xen-br0"
145 SYNC_SPEED = 30 * 1024
146 LOCALHOST_IP_ADDRESS = "127.0.0.1"
147 TCP_PING_TIMEOUT = 10
148 GANETI_RUNAS = "root"
149 BIND_ADDRESS_GLOBAL = "0.0.0.0"
150
151 # migration rpc steps
152 (DRBD_RECONF_RPC_INIT,
153  DRBD_RECONF_RPC_DISCONNECT,
154  DRBD_RECONF_RPC_RECONNECT,
155  DRBD_RECONF_RPC_SECONDARY,
156  DRBD_RECONF_RPC_WFSYNC,
157  ) = range(5)
158
159 # valid os status
160 OS_VALID_STATUS = "VALID"
161
162 # ssh constants
163 SSH_INITD_SCRIPT = _autoconf.SSH_INITD_SCRIPT
164 SSH_CONFIG_DIR = "/etc/ssh/"
165 SSH_HOST_DSA_PRIV = SSH_CONFIG_DIR + "ssh_host_dsa_key"
166 SSH_HOST_DSA_PUB = SSH_HOST_DSA_PRIV + ".pub"
167 SSH_HOST_RSA_PRIV = SSH_CONFIG_DIR + "ssh_host_rsa_key"
168 SSH_HOST_RSA_PUB = SSH_HOST_RSA_PRIV + ".pub"
169
170 # reboot types
171 INSTANCE_REBOOT_SOFT = "soft"
172 INSTANCE_REBOOT_HARD = "hard"
173 INSTANCE_REBOOT_FULL = "full"
174
175 # Hypervisor constants
176 HT_XEN_PVM30 = "xen-3.0"
177 HT_FAKE = "fake"
178 HT_XEN_HVM31 = "xen-hvm-3.1"
179 HYPER_TYPES = frozenset([HT_XEN_PVM30, HT_FAKE, HT_XEN_HVM31])
180 HTS_REQ_PORT = frozenset([HT_XEN_HVM31])
181
182 HT_HVM_VNC_BASE_PORT = 5900
183 HT_HVM_DEFAULT_BOOT_ORDER = 'dc'
184 HT_HVM_DEFAULT_ACPI_MODE = '1'
185 HT_HVM_DEFAULT_PAE_MODE = '1'
186 VNC_PASSWORD_FILE = _autoconf.SYSCONFDIR + "/ganeti/vnc-cluster-password"
187 VNC_DEFAULT_BIND_ADDRESS = '0.0.0.0'
188
189 # HVM NIC types
190 HT_HVM_NIC_RTL8139 = "rtl8139"
191 HT_HVM_NIC_NE2K_PCI = "ne2k_pci"
192 HT_HVM_NIC_NE2K_ISA = "ne2k_isa"
193 HT_HVM_DEV_PARAVIRTUAL = "paravirtual"
194 HT_HVM_DEV_IOEMU = "ioemu"
195 HT_HVM_VALID_NIC_TYPES = frozenset([HT_HVM_NIC_RTL8139, HT_HVM_NIC_NE2K_PCI,
196                                     HT_HVM_NIC_NE2K_ISA,
197                                     HT_HVM_DEV_PARAVIRTUAL])
198 HT_HVM_VALID_DISK_TYPES = frozenset([HT_HVM_DEV_PARAVIRTUAL, HT_HVM_DEV_IOEMU])
199
200 # Cluster Verify steps
201 VERIFY_NPLUSONE_MEM = 'nplusone_mem'
202 VERIFY_OPTIONAL_CHECKS = frozenset([VERIFY_NPLUSONE_MEM])
203
204 # Allocator framework constants
205 IALLOCATOR_DIR_IN = "in"
206 IALLOCATOR_DIR_OUT = "out"
207 IALLOCATOR_MODE_ALLOC = "allocate"
208 IALLOCATOR_MODE_RELOC = "relocate"
209 IALLOCATOR_SEARCH_PATH = _autoconf.IALLOCATOR_SEARCH_PATH
210 IARUN_NOTFOUND = 1
211 IARUN_FAILURE = 2
212 IARUN_SUCCESS = 3
213
214 # Remote API constants
215 RAPI_ENABLE = _autoconf.RAPI_ENABLE
216 RAPI_PORT = 5080