Getting the guest status update working.

* Added the db calls to the guest code
* Changed the default for the confs to use MySQL
* Added HACKISH uuid as a global var for status lookups
* * This is because the ip is no longer saved
    in the reddwarf db. We can do something
    better in the future since this does
    not persist if the agent stops.
This commit is contained in:
Michael Basnight 2012-03-21 23:15:46 -05:00
parent a5f978bae3
commit 8cfa3d97c4
5 changed files with 28 additions and 26 deletions

View File

@ -40,7 +40,7 @@ from reddwarf import version
from reddwarf.common import config from reddwarf.common import config
from reddwarf.common import service from reddwarf.common import service
# TODO(hub-cap): find out why the db api isint being imported properly # TODO(hub-cap): find out why the db api isint being imported properly
#from reddwarf.db import db_api from reddwarf.db import db_api
if __name__ == '__main__': if __name__ == '__main__':
@ -53,7 +53,7 @@ if __name__ == '__main__':
try: try:
conf, app = config.Config.load_paste_app('reddwarf-guestagent', conf, app = config.Config.load_paste_app('reddwarf-guestagent',
options, args) options, args)
# db_api.configure_db(conf) db_api.configure_db(conf)
server = service.Service.create(binary='reddwarf-guestagent', server = service.Service.create(binary='reddwarf-guestagent',
host=socket.gethostname()) host=socket.gethostname())
service.serve(server) service.serve(server)

View File

@ -17,8 +17,8 @@ rabbit_password=f7999d1955c5014aa32c
# SQLAlchemy connection string for the reference implementation # SQLAlchemy connection string for the reference implementation
# registry server. Any valid SQLAlchemy connection string is fine. # registry server. Any valid SQLAlchemy connection string is fine.
# See: http://www.sqlalchemy.org/docs/05/reference/sqlalchemy/connections.html#sqlalchemy.create_engine # See: http://www.sqlalchemy.org/docs/05/reference/sqlalchemy/connections.html#sqlalchemy.create_engine
sql_connection = sqlite:///reddwarf_test.sqlite #sql_connection = sqlite:///reddwarf_test.sqlite
# sql_connection = mysql://root:root@localhost/reddwarf sql_connection = mysql://root:e1a2c042c828d3566d0a@10.0.0.1/reddwarf
#sql_connection = postgresql://reddwarf:reddwarf@localhost/reddwarf #sql_connection = postgresql://reddwarf:reddwarf@localhost/reddwarf
# Period in seconds after which SQLAlchemy should reestablish its connection # Period in seconds after which SQLAlchemy should reestablish its connection

View File

@ -17,8 +17,8 @@ rabbit_password=f7999d1955c5014aa32c
# SQLAlchemy connection string for the reference implementation # SQLAlchemy connection string for the reference implementation
# registry server. Any valid SQLAlchemy connection string is fine. # registry server. Any valid SQLAlchemy connection string is fine.
# See: http://www.sqlalchemy.org/docs/05/reference/sqlalchemy/connections.html#sqlalchemy.create_engine # See: http://www.sqlalchemy.org/docs/05/reference/sqlalchemy/connections.html#sqlalchemy.create_engine
sql_connection = sqlite:///reddwarf_test.sqlite # sql_connection = sqlite:///reddwarf_test.sqlite
# sql_connection = mysql://root:root@localhost/reddwarf sql_connection = mysql://root:e1a2c042c828d3566d0a@localhost/reddwarf
#sql_connection = postgresql://reddwarf:reddwarf@localhost/reddwarf #sql_connection = postgresql://reddwarf:reddwarf@localhost/reddwarf
# Period in seconds after which SQLAlchemy should reestablish its connection # Period in seconds after which SQLAlchemy should reestablish its connection

View File

@ -125,7 +125,8 @@ class API(object):
rpc.cast_with_consumer(context, self._get_routing_key(context, id), rpc.cast_with_consumer(context, self._get_routing_key(context, id),
{"method": "prepare", {"method": "prepare",
"args": {"databases": databases, "args": {"databases": databases,
"memory_mb": memory_mb} "memory_mb": memory_mb,
"uuid": id}
}) })
def restart(self, context, id): def restart(self, context, id):

View File

@ -38,13 +38,11 @@ from sqlalchemy import exc
from sqlalchemy import interfaces from sqlalchemy import interfaces
from sqlalchemy.sql.expression import text from sqlalchemy.sql.expression import text
# from nova.compute import power_state from reddwarf import db
# from nova.exception import ProcessExecutionError
# from reddwarf.db import api as dbapi
from reddwarf.common.exception import ProcessExecutionError from reddwarf.common.exception import ProcessExecutionError
from reddwarf.common import utils from reddwarf.common import utils
# from reddwarf.guestagent import utils as guest_utils
from reddwarf.guestagent.db import models from reddwarf.guestagent.db import models
from reddwarf.instance import models
ADMIN_USER_NAME = "os_admin" ADMIN_USER_NAME = "os_admin"
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
@ -53,6 +51,7 @@ FLUSH = text("""FLUSH PRIVILEGES;""")
ENGINE = None ENGINE = None
MYSQLD_ARGS = None MYSQLD_ARGS = None
PREPARING = False PREPARING = False
UUID = False
def generate_random_password(): def generate_random_password():
@ -256,7 +255,7 @@ class DBaaSAgent(object):
LOG.debug("result = " + str(result)) LOG.debug("result = " + str(result))
return result.rowcount != 0 return result.rowcount != 0
def prepare(self, databases, memory_mb): def prepare(self, databases, memory_mb, uuid):
"""Makes ready DBAAS on a Guest container.""" """Makes ready DBAAS on a Guest container."""
global PREPARING global PREPARING
PREPARING = True PREPARING = True
@ -267,46 +266,48 @@ class DBaaSAgent(object):
preparer.prepare() preparer.prepare()
self.create_database(databases) self.create_database(databases)
PREPARING = False PREPARING = False
# TODO(hub-cap):fix this UGLY hack!
global UUID
UUID = uuid
def update_status(self): def update_status(self):
"""Update the status of the MySQL service""" """Update the status of the MySQL service"""
global MYSQLD_ARGS global MYSQLD_ARGS
global PREPARING global PREPARING
# TODO(hub-cap):fix this UGLY hack!
global UUID
# instance_id = guest_utils.get_instance_id() # instance_id = guest_utils.get_instance_id()
status = models.InstanceServiceStatus.find_by(instance_id=UUID)
if PREPARING: if PREPARING:
#TODO(hub-cap): Fix the guest_status_update status.set_status(models.ServiceStatuses.BUILDING)
# dbapi.guest_status_update(instance_id, power_state.BUILDING) status.save()
return return
try: try:
out, err = utils.execute("/usr/bin/mysqladmin", "ping", out, err = utils.execute("/usr/bin/mysqladmin", "ping",
run_as_root=True) run_as_root=True)
#TODO(hub-cap): Fix the guest_status_update status.set_status(models.ServiceStatuses.RUNNING)
# dbapi.guest_status_update(instance_id, power_state.RUNNING) status.save()
except ProcessExecutionError as e: except ProcessExecutionError as e:
try: try:
out, err = utils.execute("ps", "-C", "mysqld", "h") out, err = utils.execute("ps", "-C", "mysqld", "h")
pid = out.split()[0] pid = out.split()[0]
# TODO(rnirmal): Need to create new statuses for instances # TODO(rnirmal): Need to create new statuses for instances
# where the mysql service is up, but unresponsive # where the mysql service is up, but unresponsive
#TODO(hub-cap): Fix the guest_status_update status.set_status(models.ServiceStatuses.BLOCKED)
# dbapi.guest_status_update(instance_id, power_state.BLOCKED) status.save()
except ProcessExecutionError as e: except ProcessExecutionError as e:
if not MYSQLD_ARGS: if not MYSQLD_ARGS:
MYSQLD_ARGS = load_mysqld_options() MYSQLD_ARGS = load_mysqld_options()
pid_file = MYSQLD_ARGS.get('pid-file', pid_file = MYSQLD_ARGS.get('pid-file',
'/var/run/mysqld/mysqld.pid') '/var/run/mysqld/mysqld.pid')
if os.path.exists(pid_file): if os.path.exists(pid_file):
pass status.set_status(models.ServiceStatuses.CRASHED)
#TODO(hub-cap): Fix the guest_status_update status.save()
# dbapi.guest_status_update(instance_id,
# power_state.CRASHED)
else: else:
pass status.set_status(models.ServiceStatuses.SHUTDOWN)
#TODO(hub-cap): Fix the guest_status_update status.save()
# dbapi.guest_status_update(instance_id,
# power_state.SHUTDOWN)
class LocalSqlClient(object): class LocalSqlClient(object):