Merge "Refactor service readiness notification"
This commit is contained in:
commit
8249ed170f
@ -34,10 +34,10 @@ from oslo.config import cfg
|
||||
|
||||
from heat.common import config
|
||||
from heat.common import messaging
|
||||
from heat.common import notify
|
||||
from heat.common import wsgi
|
||||
from heat.openstack.common import gettextutils
|
||||
from heat.openstack.common import log as logging
|
||||
from heat.openstack.common import systemd
|
||||
|
||||
gettextutils.enable_lazy()
|
||||
gettextutils.install('heat', lazy=True)
|
||||
@ -58,7 +58,7 @@ if __name__ == '__main__':
|
||||
{'host': host, 'port': port})
|
||||
server = wsgi.Server()
|
||||
server.start(app, cfg.CONF.heat_api, default_port=port)
|
||||
notify.startup_notify(cfg.CONF.onready)
|
||||
systemd.notify_once()
|
||||
server.wait()
|
||||
except RuntimeError as e:
|
||||
sys.exit("ERROR: %s" % e)
|
||||
|
@ -36,10 +36,11 @@ from oslo.config import cfg
|
||||
|
||||
from heat.common import config
|
||||
from heat.common import messaging
|
||||
from heat.common import notify
|
||||
from heat.common import wsgi
|
||||
from heat.openstack.common import gettextutils
|
||||
|
||||
from heat.openstack.common import log as logging
|
||||
from heat.openstack.common import systemd
|
||||
|
||||
gettextutils.enable_lazy()
|
||||
gettextutils.install('heat', lazy=True)
|
||||
@ -60,7 +61,7 @@ if __name__ == '__main__':
|
||||
{'host': host, 'port': port})
|
||||
server = wsgi.Server()
|
||||
server.start(app, cfg.CONF.heat_api_cfn, default_port=port)
|
||||
notify.startup_notify(cfg.CONF.onready)
|
||||
systemd.notify_once()
|
||||
server.wait()
|
||||
except RuntimeError as e:
|
||||
sys.exit("ERROR: %s" % e)
|
||||
|
@ -36,10 +36,11 @@ from oslo.config import cfg
|
||||
|
||||
from heat.common import config
|
||||
from heat.common import messaging
|
||||
from heat.common import notify
|
||||
from heat.common import wsgi
|
||||
from heat.openstack.common import gettextutils
|
||||
|
||||
from heat.openstack.common import log as logging
|
||||
from heat.openstack.common import systemd
|
||||
|
||||
gettextutils.enable_lazy()
|
||||
gettextutils.install('heat', lazy=True)
|
||||
@ -60,7 +61,7 @@ if __name__ == '__main__':
|
||||
{'host': host, 'port': port})
|
||||
server = wsgi.Server()
|
||||
server.start(app, cfg.CONF.heat_api_cloudwatch, default_port=port)
|
||||
notify.startup_notify(cfg.CONF.onready)
|
||||
systemd.notify_once()
|
||||
server.wait()
|
||||
except RuntimeError as e:
|
||||
sys.exit("ERROR: %s" % e)
|
||||
|
@ -35,10 +35,10 @@ if os.path.exists(os.path.join(POSSIBLE_TOPDIR, 'heat', '__init__.py')):
|
||||
from oslo.config import cfg
|
||||
|
||||
from heat.common import messaging
|
||||
from heat.common import notify
|
||||
from heat.openstack.common import gettextutils
|
||||
from heat.openstack.common import log as logging
|
||||
from heat.openstack.common import service
|
||||
|
||||
from heat.rpc import api as rpc_api
|
||||
|
||||
gettextutils.enable_lazy()
|
||||
@ -59,5 +59,4 @@ if __name__ == '__main__':
|
||||
# We create the periodic tasks here, which mean they are created
|
||||
# only in the parent process when num_engine_workers>1 is specified
|
||||
srv.create_periodic_tasks()
|
||||
notify.startup_notify(cfg.CONF.onready)
|
||||
launcher.wait()
|
||||
|
@ -70,12 +70,7 @@
|
||||
# stack locking. (integer value)
|
||||
#engine_life_check_timeout=2
|
||||
|
||||
# onready allows you to send a notification when the heat
|
||||
# processes are ready to serve. This is either a module with
|
||||
# the notify() method or a shell command. To enable
|
||||
# notifications with systemd, one may use the 'systemd-notify
|
||||
# --ready' shell command or the 'heat.common.systemd'
|
||||
# notification module. (string value)
|
||||
# Deprecated. (string value)
|
||||
#onready=<None>
|
||||
|
||||
|
||||
|
@ -138,12 +138,7 @@ engine_opts = [
|
||||
help=_('RPC timeout for the engine liveness check that is used'
|
||||
' for stack locking.')),
|
||||
cfg.StrOpt('onready',
|
||||
help=_('onready allows you to send a notification when the'
|
||||
' heat processes are ready to serve. This is either a'
|
||||
' module with the notify() method or a shell command. '
|
||||
' To enable notifications with systemd, one may use'
|
||||
' the \'systemd-notify --ready\' shell command or'
|
||||
' the \'heat.common.systemd\' notification module.'))]
|
||||
help=_('Deprecated.'))]
|
||||
|
||||
rpc_opts = [
|
||||
cfg.StrOpt('host',
|
||||
|
@ -1,40 +0,0 @@
|
||||
#
|
||||
# Copyright 2014 Red Hat, Inc.
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||
# not use this file except in compliance with the License. You may obtain
|
||||
# a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
"""
|
||||
Startup notification using a shell script or systemd NOTIFY_SOCKET
|
||||
style notification
|
||||
"""
|
||||
|
||||
|
||||
from heat.openstack.common import importutils
|
||||
from heat.openstack.common import log as logging
|
||||
from heat.openstack.common import processutils
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
def startup_notify(notify_param):
|
||||
if not notify_param or notify_param == "":
|
||||
return
|
||||
try:
|
||||
notifier = importutils.import_module(notify_param)
|
||||
except ImportError:
|
||||
try:
|
||||
processutils.execute(notify_param, shell=True)
|
||||
except Exception as e:
|
||||
LOG.error(_('Failed to execute onready command: %s') % e)
|
||||
else:
|
||||
notifier.notify()
|
@ -1,45 +0,0 @@
|
||||
#
|
||||
# Copyright 2012 Red Hat, Inc.
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||
# not use this file except in compliance with the License. You may obtain
|
||||
# a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
"""
|
||||
Helper module for systemd start-up completion notification.
|
||||
Used for "onready" configuration parameter in heat.conf
|
||||
"""
|
||||
|
||||
import os
|
||||
import socket
|
||||
|
||||
from heat.openstack.common import log as logging
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
def _sd_notify(msg):
|
||||
sysd = os.getenv('NOTIFY_SOCKET')
|
||||
if sysd:
|
||||
sock = socket.socket(socket.AF_UNIX, socket.SOCK_DGRAM)
|
||||
if sysd.startswith('@'):
|
||||
# abstract namespace socket
|
||||
sysd = '\0%s' % sysd[1:]
|
||||
sock.connect(sysd)
|
||||
sock.sendall(msg)
|
||||
sock.close()
|
||||
else:
|
||||
LOG.warning(_('Unable to notify systemd of startup completion:'
|
||||
' NOTIFY_SOCKET not set'))
|
||||
|
||||
|
||||
def notify():
|
||||
_sd_notify('READY=1')
|
Loading…
Reference in New Issue
Block a user