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:
parent
a5f978bae3
commit
8cfa3d97c4
@ -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)
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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):
|
||||||
|
@ -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):
|
||||||
|
Loading…
x
Reference in New Issue
Block a user