Statistics
| Branch: | Tag: | Revision:

root / lib / pathutils.py @ 5e12acfe

History | View | Annotate | Download (5.1 kB)

1 3329f4de Michael Hanselmann
#
2 3329f4de Michael Hanselmann
#
3 3329f4de Michael Hanselmann
4 3329f4de Michael Hanselmann
# Copyright (C) 2006, 2007, 2008, 2009, 2010, 2011, 2012 Google Inc.
5 3329f4de Michael Hanselmann
#
6 3329f4de Michael Hanselmann
# This program is free software; you can redistribute it and/or modify
7 3329f4de Michael Hanselmann
# it under the terms of the GNU General Public License as published by
8 3329f4de Michael Hanselmann
# the Free Software Foundation; either version 2 of the License, or
9 3329f4de Michael Hanselmann
# (at your option) any later version.
10 3329f4de Michael Hanselmann
#
11 3329f4de Michael Hanselmann
# This program is distributed in the hope that it will be useful, but
12 3329f4de Michael Hanselmann
# WITHOUT ANY WARRANTY; without even the implied warranty of
13 3329f4de Michael Hanselmann
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 3329f4de Michael Hanselmann
# General Public License for more details.
15 3329f4de Michael Hanselmann
#
16 3329f4de Michael Hanselmann
# You should have received a copy of the GNU General Public License
17 3329f4de Michael Hanselmann
# along with this program; if not, write to the Free Software
18 3329f4de Michael Hanselmann
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19 3329f4de Michael Hanselmann
# 02110-1301, USA.
20 3329f4de Michael Hanselmann
21 3329f4de Michael Hanselmann
22 3329f4de Michael Hanselmann
"""Module containing constants and functions for filesystem paths.
23 3329f4de Michael Hanselmann

24 3329f4de Michael Hanselmann
"""
25 3329f4de Michael Hanselmann
26 3329f4de Michael Hanselmann
from ganeti import _autoconf
27 cffbbae7 Michael Hanselmann
from ganeti import vcluster
28 cffbbae7 Michael Hanselmann
29 3329f4de Michael Hanselmann
30 3329f4de Michael Hanselmann
# Build-time constants
31 cffbbae7 Michael Hanselmann
DEFAULT_FILE_STORAGE_DIR = vcluster.AddNodePrefix(_autoconf.FILE_STORAGE_DIR)
32 cffbbae7 Michael Hanselmann
DEFAULT_SHARED_FILE_STORAGE_DIR = \
33 cffbbae7 Michael Hanselmann
  vcluster.AddNodePrefix(_autoconf.SHARED_FILE_STORAGE_DIR)
34 cffbbae7 Michael Hanselmann
EXPORT_DIR = vcluster.AddNodePrefix(_autoconf.EXPORT_DIR)
35 3329f4de Michael Hanselmann
OS_SEARCH_PATH = _autoconf.OS_SEARCH_PATH
36 3329f4de Michael Hanselmann
SSH_CONFIG_DIR = _autoconf.SSH_CONFIG_DIR
37 cffbbae7 Michael Hanselmann
SYSCONFDIR = vcluster.AddNodePrefix(_autoconf.SYSCONFDIR)
38 3329f4de Michael Hanselmann
TOOLSDIR = _autoconf.TOOLSDIR
39 cffbbae7 Michael Hanselmann
LOCALSTATEDIR = vcluster.AddNodePrefix(_autoconf.LOCALSTATEDIR)
40 3329f4de Michael Hanselmann
41 3329f4de Michael Hanselmann
# Paths which don't change for a virtual cluster
42 3329f4de Michael Hanselmann
DAEMON_UTIL = _autoconf.PKGLIBDIR + "/daemon-util"
43 3329f4de Michael Hanselmann
IMPORT_EXPORT_DAEMON = _autoconf.PKGLIBDIR + "/import-export"
44 3329f4de Michael Hanselmann
KVM_CONSOLE_WRAPPER = _autoconf.PKGLIBDIR + "/tools/kvm-console-wrapper"
45 3329f4de Michael Hanselmann
KVM_IFUP = _autoconf.PKGLIBDIR + "/kvm-ifup"
46 224ff0f7 Michael Hanselmann
PREPARE_NODE_JOIN = _autoconf.PKGLIBDIR + "/prepare-node-join"
47 b9612abb Iustin Pop
XEN_CONSOLE_WRAPPER = _autoconf.PKGLIBDIR + "/tools/xen-console-wrapper"
48 fe4f6dca Michael Hanselmann
ETC_HOSTS = vcluster.ETC_HOSTS
49 3329f4de Michael Hanselmann
50 3329f4de Michael Hanselmann
# Top-level paths
51 cffbbae7 Michael Hanselmann
DATA_DIR = LOCALSTATEDIR + "/lib/ganeti"
52 cffbbae7 Michael Hanselmann
LOCK_DIR = LOCALSTATEDIR + "/lock"
53 cffbbae7 Michael Hanselmann
LOG_DIR = LOCALSTATEDIR + "/log/ganeti"
54 cffbbae7 Michael Hanselmann
RUN_DIR = LOCALSTATEDIR + "/run/ganeti"
55 3329f4de Michael Hanselmann
56 3329f4de Michael Hanselmann
#: Script to configure master IP address
57 3329f4de Michael Hanselmann
DEFAULT_MASTER_SETUP_SCRIPT = TOOLSDIR + "/master-ip-setup"
58 3329f4de Michael Hanselmann
59 3329f4de Michael Hanselmann
SSH_HOST_DSA_PRIV = SSH_CONFIG_DIR + "/ssh_host_dsa_key"
60 3329f4de Michael Hanselmann
SSH_HOST_DSA_PUB = SSH_HOST_DSA_PRIV + ".pub"
61 3329f4de Michael Hanselmann
SSH_HOST_RSA_PRIV = SSH_CONFIG_DIR + "/ssh_host_rsa_key"
62 3329f4de Michael Hanselmann
SSH_HOST_RSA_PUB = SSH_HOST_RSA_PRIV + ".pub"
63 3329f4de Michael Hanselmann
64 3329f4de Michael Hanselmann
BDEV_CACHE_DIR = RUN_DIR + "/bdev-cache"
65 3329f4de Michael Hanselmann
DISK_LINKS_DIR = RUN_DIR + "/instance-disks"
66 3329f4de Michael Hanselmann
SOCKET_DIR = RUN_DIR + "/socket"
67 3329f4de Michael Hanselmann
CRYPTO_KEYS_DIR = RUN_DIR + "/crypto"
68 3329f4de Michael Hanselmann
IMPORT_EXPORT_DIR = RUN_DIR + "/import-export"
69 3329f4de Michael Hanselmann
INSTANCE_STATUS_FILE = RUN_DIR + "/instance-status"
70 3329f4de Michael Hanselmann
#: User-id pool lock directory (used user IDs have a corresponding lock file in
71 3329f4de Michael Hanselmann
#: this directory)
72 3329f4de Michael Hanselmann
UIDPOOL_LOCKDIR = RUN_DIR + "/uid-pool"
73 3329f4de Michael Hanselmann
74 3329f4de Michael Hanselmann
SSCONF_LOCK_FILE = LOCK_DIR + "/ganeti-ssconf.lock"
75 3329f4de Michael Hanselmann
76 3329f4de Michael Hanselmann
CLUSTER_CONF_FILE = DATA_DIR + "/config.data"
77 3329f4de Michael Hanselmann
NODED_CERT_FILE = DATA_DIR + "/server.pem"
78 3329f4de Michael Hanselmann
RAPI_CERT_FILE = DATA_DIR + "/rapi.pem"
79 3329f4de Michael Hanselmann
CONFD_HMAC_KEY = DATA_DIR + "/hmac.key"
80 3329f4de Michael Hanselmann
SPICE_CERT_FILE = DATA_DIR + "/spice.pem"
81 3329f4de Michael Hanselmann
SPICE_CACERT_FILE = DATA_DIR + "/spice-ca.pem"
82 3329f4de Michael Hanselmann
CLUSTER_DOMAIN_SECRET_FILE = DATA_DIR + "/cluster-domain-secret"
83 3329f4de Michael Hanselmann
SSH_KNOWN_HOSTS_FILE = DATA_DIR + "/known_hosts"
84 3329f4de Michael Hanselmann
RAPI_USERS_FILE = DATA_DIR + "/rapi/users"
85 3329f4de Michael Hanselmann
QUEUE_DIR = DATA_DIR + "/queue"
86 3329f4de Michael Hanselmann
CONF_DIR = SYSCONFDIR + "/ganeti"
87 3329f4de Michael Hanselmann
USER_SCRIPTS_DIR = CONF_DIR + "/scripts"
88 3329f4de Michael Hanselmann
VNC_PASSWORD_FILE = CONF_DIR + "/vnc-cluster-password"
89 3329f4de Michael Hanselmann
HOOKS_BASE_DIR = CONF_DIR + "/hooks"
90 fbdac0d9 Michael Hanselmann
FILE_STORAGE_PATHS_FILE = CONF_DIR + "/file-storage-paths"
91 df99f3a9 Michael Hanselmann
REMOTE_COMMANDS_DIR = CONF_DIR + "/remote-commands"
92 df99f3a9 Michael Hanselmann
93 df99f3a9 Michael Hanselmann
#: Locked in exclusive mode while noded verifies a remote command
94 df99f3a9 Michael Hanselmann
REMOTE_COMMANDS_LOCK_FILE = LOCK_DIR + "/ganeti-remote-commands.lock"
95 3329f4de Michael Hanselmann
96 3329f4de Michael Hanselmann
#: Lock file for watcher, locked in shared mode by watcher; lock in exclusive
97 3329f4de Michael Hanselmann
# mode to block watcher (see L{cli._RunWhileClusterStoppedHelper.Call}
98 3329f4de Michael Hanselmann
WATCHER_LOCK_FILE = LOCK_DIR + "/ganeti-watcher.lock"
99 3329f4de Michael Hanselmann
100 3329f4de Michael Hanselmann
#: Status file for per-group watcher, locked in exclusive mode by watcher
101 3329f4de Michael Hanselmann
WATCHER_GROUP_STATE_FILE = DATA_DIR + "/watcher.%s.data"
102 3329f4de Michael Hanselmann
103 3329f4de Michael Hanselmann
#: File for per-group instance status, merged into L{INSTANCE_STATUS_FILE} by
104 3329f4de Michael Hanselmann
#: per-group processes
105 3329f4de Michael Hanselmann
WATCHER_GROUP_INSTANCE_STATUS_FILE = DATA_DIR + "/watcher.%s.instance-status"
106 3329f4de Michael Hanselmann
107 3329f4de Michael Hanselmann
#: File containing Unix timestamp until which watcher should be paused
108 3329f4de Michael Hanselmann
WATCHER_PAUSEFILE = DATA_DIR + "/watcher.pause"
109 3329f4de Michael Hanselmann
110 3329f4de Michael Hanselmann
#: User-provided master IP setup script
111 3329f4de Michael Hanselmann
EXTERNAL_MASTER_SETUP_SCRIPT = USER_SCRIPTS_DIR + "/master-ip-setup"
112 3329f4de Michael Hanselmann
113 3329f4de Michael Hanselmann
#: LUXI socket used for job execution
114 3329f4de Michael Hanselmann
MASTER_SOCKET = SOCKET_DIR + "/ganeti-master"
115 3329f4de Michael Hanselmann
#: LUXI socket used for queries only
116 3329f4de Michael Hanselmann
QUERY_SOCKET = SOCKET_DIR + "/ganeti-query"
117 3329f4de Michael Hanselmann
118 3329f4de Michael Hanselmann
LOG_OS_DIR = LOG_DIR + "/os"
119 3329f4de Michael Hanselmann
120 3329f4de Michael Hanselmann
# Job queue paths
121 3329f4de Michael Hanselmann
JOB_QUEUE_LOCK_FILE = QUEUE_DIR + "/lock"
122 3329f4de Michael Hanselmann
JOB_QUEUE_VERSION_FILE = QUEUE_DIR + "/version"
123 3329f4de Michael Hanselmann
JOB_QUEUE_SERIAL_FILE = QUEUE_DIR + "/serial"
124 3329f4de Michael Hanselmann
JOB_QUEUE_ARCHIVE_DIR = QUEUE_DIR + "/archive"
125 3329f4de Michael Hanselmann
JOB_QUEUE_DRAIN_FILE = QUEUE_DIR + "/drain"
126 3329f4de Michael Hanselmann
127 3329f4de Michael Hanselmann
ALL_CERT_FILES = frozenset([
128 3329f4de Michael Hanselmann
  NODED_CERT_FILE,
129 3329f4de Michael Hanselmann
  RAPI_CERT_FILE,
130 3329f4de Michael Hanselmann
  SPICE_CERT_FILE,
131 3329f4de Michael Hanselmann
  SPICE_CACERT_FILE,
132 3329f4de Michael Hanselmann
  ])
133 3329f4de Michael Hanselmann
134 3329f4de Michael Hanselmann
135 3329f4de Michael Hanselmann
def GetLogFilename(daemon_name):
136 3329f4de Michael Hanselmann
  """Returns the full path for a daemon's log file.
137 3329f4de Michael Hanselmann

138 3329f4de Michael Hanselmann
  """
139 3329f4de Michael Hanselmann
  return "%s/%s.log" % (LOG_DIR, daemon_name)
140 3329f4de Michael Hanselmann
141 3329f4de Michael Hanselmann
142 3329f4de Michael Hanselmann
LOG_WATCHER = GetLogFilename("watcher")
143 3329f4de Michael Hanselmann
LOG_COMMANDS = GetLogFilename("commands")
144 3329f4de Michael Hanselmann
LOG_BURNIN = GetLogFilename("burnin")