deb-heat/bin/heat-metadata
Tomas Sedovic 67203a5497 Allow engine and metadata server start in any order
When the metadata server starts first, it will wait for the engine to come up
and only then registers it's hostname and port and becomes available.

Signed-off-by: Tomas Sedovic <tomas@sedovic.cz>
2012-05-17 16:49:15 +02:00

76 lines
2.4 KiB
Python
Executable File

#!/usr/bin/env python
# vim: tabstop=4 shiftwidth=4 softtabstop=4
#
# 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.
"""
Heat Metadata Server.
This makes the instance metadata accessible both to the instance and Heat Engine.
"""
import gettext
import os
import sys
# If ../heat/__init__.py exists, add ../ to Python search path, so that
# it will override what happens to be installed in /usr/(local/)lib/python...
possible_topdir = os.path.normpath(os.path.join(os.path.abspath(sys.argv[0]),
os.pardir,
os.pardir))
if os.path.exists(os.path.join(possible_topdir, 'heat', '__init__.py')):
sys.path.insert(0, possible_topdir)
gettext.install('heat', unicode=1)
import logging
from heat import rpc
from heat.common import config
from heat.common import wsgi
from heat import context
from paste import httpserver
LOG = logging.getLogger('heat.metadata')
def send_address_to_engine(host, port):
con = context.get_admin_context()
while True:
try:
resp = rpc.call(con, 'engine',
{'method': 'metadata_register_address',
'args': {'url': 'http://%s:%s' % (host, port)}})
LOG.info('registered the hostname and port with the engine.')
return
except rpc.common.Timeout:
LOG.info('Could not connect to the engine, retrying...')
if __name__ == '__main__':
try:
conf = config.HeatMetadataConfigOpts()
conf()
config.FLAGS = conf
rpc.configure(conf)
config.setup_logging(conf)
app = config.load_paste_app(conf)
port = conf.bind_port
host = conf.bind_host
send_address_to_engine(host, port)
LOG.info(('Starting Heat Metadata on %s:%s') % (host, port))
httpserver.serve(app, host=host, port=port)
except RuntimeError, e:
sys.exit("ERROR: %s" % e)