charm-swift-storage/hooks/swift_storage_hooks.py

189 lines
5.3 KiB
Python
Raw Normal View History

2013-07-16 21:27:06 -07:00
#!/usr/bin/python
import os
import sys
from swift_storage_utils import (
PACKAGES,
RESTART_MAP,
2013-07-16 21:27:06 -07:00
determine_block_devices,
do_openstack_upgrade,
ensure_swift_directories,
fetch_swift_rings,
register_configs,
save_script_rc,
2013-07-16 21:27:06 -07:00
setup_storage,
2014-09-26 19:20:43 +01:00
assert_charm_supports_ipv6
2013-07-16 21:27:06 -07:00
)
from charmhelpers.core.hookenv import (
2013-07-19 13:44:37 -07:00
Hooks, UnregisteredHookError,
2013-07-16 21:27:06 -07:00
config,
log,
relation_get,
relation_set,
relations_of_type,
local_unit,
2013-07-16 21:27:06 -07:00
)
from charmhelpers.fetch import (
apt_install,
apt_update,
filter_installed_packages
)
from charmhelpers.core.host import restart_on_change, rsync
from charmhelpers.payload.execd import execd_preinstall
2013-07-16 21:27:06 -07:00
from charmhelpers.contrib.openstack.utils import (
configure_installation_source,
openstack_upgrade_available,
)
2014-08-13 14:50:51 +08:00
from charmhelpers.contrib.network.ip import (
2014-09-18 21:36:03 +08:00
get_ipv6_addr
2014-08-13 14:50:51 +08:00
)
from swift_storage_utils import (
PACKAGES,
RESTART_MAP,
SWIFT_SVCS,
determine_block_devices,
do_openstack_upgrade,
ensure_swift_directories,
fetch_swift_rings,
register_configs,
save_script_rc,
setup_storage,
concat_rsync_fragments,
)
from charmhelpers.contrib.charmsupport.nrpe import NRPE
2013-07-16 21:27:06 -07:00
hooks = Hooks()
CONFIGS = register_configs()
NAGIOS_PLUGINS = '/usr/local/lib/nagios/plugins'
SUDOERS_D = '/etc/sudoers.d'
2013-07-16 21:27:06 -07:00
@hooks.hook()
2013-07-16 21:27:06 -07:00
def install():
execd_preinstall()
configure_installation_source(config('openstack-origin'))
2013-07-16 21:27:06 -07:00
apt_update()
apt_install(PACKAGES, fatal=True)
2013-07-16 21:27:06 -07:00
setup_storage()
ensure_swift_directories()
@hooks.hook('config-changed')
@restart_on_change(RESTART_MAP)
2013-07-16 21:27:06 -07:00
def config_changed():
2014-09-18 21:36:03 +08:00
if config('prefer-ipv6'):
2014-09-26 19:20:43 +01:00
assert_charm_supports_ipv6()
2014-09-18 21:36:03 +08:00
ensure_swift_directories()
2013-07-16 21:27:06 -07:00
if openstack_upgrade_available('swift'):
do_openstack_upgrade(configs=CONFIGS)
CONFIGS.write_all()
# If basenode is not installed and managing rsyncd.conf, replicate
# its core functionality. Otherwise concat files
if not os.path.exists('/etc/rsyncd.d/001-baseconfig'):
with open('/etc/rsyncd.d/001-baseconfig') as _in:
rsync_header = _in.read()
with open('/etc/rsyncd.d/050-swift-storage') as _in:
rsync_fragment = _in.read()
with open('/etc/rsyncd.conf', 'w') as out:
out.write(rsync_header + rsync_fragment)
else:
concat_rsync_fragments()
save_script_rc()
if relations_of_type('nrpe-external-master'):
update_nrpe_config()
2013-07-16 21:27:06 -07:00
@hooks.hook('upgrade-charm')
def upgrade_charm():
apt_install(filter_installed_packages(PACKAGES), fatal=True)
update_nrpe_config()
2013-07-16 21:27:06 -07:00
@hooks.hook()
def swift_storage_relation_joined():
devs = [os.path.basename(dev) for dev in determine_block_devices()]
rel_settings = {
'zone': config('zone'),
'object_port': config('object-server-port'),
'container_port': config('container-server-port'),
'account_port': config('account-server-port'),
'device': ':'.join(devs),
}
2014-08-13 14:50:51 +08:00
if config('prefer-ipv6'):
2014-09-20 00:59:42 +08:00
rel_settings['private-address'] = get_ipv6_addr()[0]
2014-08-13 14:50:51 +08:00
2013-07-16 21:27:06 -07:00
relation_set(**rel_settings)
@hooks.hook('swift-storage-relation-changed')
@restart_on_change(RESTART_MAP)
2013-07-16 21:27:06 -07:00
def swift_storage_relation_changed():
rings_url = relation_get('rings_url')
swift_hash = relation_get('swift_hash')
if '' in [rings_url, swift_hash] or None in [rings_url, swift_hash]:
2013-07-16 21:27:06 -07:00
log('swift_storage_relation_changed: Peer not ready?')
sys.exit(0)
CONFIGS.write('/etc/swift/swift.conf')
fetch_swift_rings(rings_url)
2013-07-19 13:44:37 -07:00
@hooks.hook('nrpe-external-master-relation-joined')
@hooks.hook('nrpe-external-master-relation-changed')
def update_nrpe_config():
log('Refreshing nrpe checks')
rsync(os.path.join(os.getenv('CHARM_DIR'), 'files', 'nrpe-external-master',
'check_swift_storage.py'),
os.path.join(NAGIOS_PLUGINS, 'check_swift_storage.py'))
rsync(os.path.join(os.getenv('CHARM_DIR'), 'files', 'nrpe-external-master',
'check_swift_service'),
os.path.join(NAGIOS_PLUGINS, 'check_swift_service'))
rsync(os.path.join(os.getenv('CHARM_DIR'), 'files', 'sudo',
'swift-storage'),
os.path.join(SUDOERS_D, 'swift-storage'))
# Find out if nrpe set nagios_hostname
hostname = None
for rel in relations_of_type('nrpe-external-master'):
if 'nagios_hostname' in rel:
hostname = rel['nagios_hostname']
host_context = rel['nagios_host_context']
break
nrpe = NRPE(hostname=hostname)
current_unit = "%s:%s" % (host_context, local_unit())
# check the rings and replication
nrpe.add_check(
shortname='swift_storage',
description='Check swift storage ring hashes and replication {%s}' % current_unit,
check_cmd='check_swift_storage.py {}'.format(
config('nagios-check-params'))
)
# check services are running
for service in SWIFT_SVCS:
nrpe.add_check(
shortname=service,
description='service {%s}' % current_unit,
check_cmd = 'check_swift_service %s' % service,
)
nrpe.write()
2013-07-19 13:44:37 -07:00
def main():
try:
hooks.execute(sys.argv)
except UnregisteredHookError as e:
log('Unknown hook {} - skipping.'.format(e))
if __name__ == '__main__':
main()