Fixing the queues to use uuid.

* Added the /etc/guest_info file that has the id of the guest
* Passed uuid in as the host flag in the common config code
* Removed uuid from the dbaas api/guest prepare call
This commit is contained in:
Michael Basnight 2012-03-27 16:46:38 -05:00
parent ba2096a73d
commit f2212511b8
4 changed files with 14 additions and 15 deletions

View File

@ -57,9 +57,13 @@ if __name__ == '__main__':
conf_loc = '%s/%s' % (config.Config.get('here'), 'conf.d/guest_info')
config.Config.append_to_config_values('reddwarf-guestagent',
{'config_file': conf_loc}, None)
# Now do the same for the /etc/guest_info file
# that is injected into the VM
config.Config.append_to_config_values('reddwarf-guestagent',
{'config_file': '/etc/guest_info'}, None)
db_api.configure_db(conf)
server = service.Service.create(binary='reddwarf-guestagent',
host=socket.gethostname())
host=config.Config.get('guest_id'))
service.serve(server)
service.wait()
except RuntimeError as error:

View File

@ -39,9 +39,7 @@ class API(object):
def _get_routing_key(self, context, id):
"""Create the routing key based on the container id"""
# TODO(hub-cap): make this work in a real environment with
# more than one guest
return "guestagent.ubuntu"
return "guestagent.%s" % id
def create_user(self, context, id, users):
"""Make an asynchronous call to create a new database user"""
@ -125,8 +123,7 @@ class API(object):
rpc.cast_with_consumer(context, self._get_routing_key(context, id),
{"method": "prepare",
"args": {"databases": databases,
"memory_mb": memory_mb,
"uuid": id}
"memory_mb": memory_mb}
})
def restart(self, context, id):

View File

@ -256,7 +256,7 @@ class DBaaSAgent(object):
LOG.debug("result = " + str(result))
return result.rowcount != 0
def prepare(self, databases, memory_mb, uuid):
def prepare(self, databases, memory_mb):
"""Makes ready DBAAS on a Guest container."""
global PREPARING
PREPARING = True
@ -267,10 +267,6 @@ class DBaaSAgent(object):
preparer.prepare()
self.create_database(databases)
PREPARING = False
# Writing the UUID to the guest agent guest_info file
conf_loc = '%s/%s' % (config.Config.get('here'), 'conf.d/guest_info')
config.Config.write_config_values('reddwarf-guestagent',
{'config_file': conf_loc}, None, guest_id=uuid)
def update_status(self):
"""Update the status of the MySQL service"""

View File

@ -118,13 +118,15 @@ class Instance(object):
@classmethod
def create(cls, context, name, flavor_ref, image_id):
client = create_nova_client(context)
server = client.servers.create(name, image_id, flavor_ref)
LOG.debug("Created new compute instance %s." % server.id)
db_info = DBInstance.create(name=name,
compute_instance_id=server.id,
task_status=InstanceTasks.BUILDING)
LOG.debug("Created new Reddwarf instance %s..." % db_info.id)
client = create_nova_client(context)
server = client.servers.create(name, image_id, flavor_ref,
files={"/etc/guest_info":"guest_id=%s" % db_info.id})
LOG.debug("Created new compute instance %s." % server.id)
db_info.compute_instance_id = server.id
db_info.save()
service_status = InstanceServiceStatus.create(instance_id=db_info.id,
status=ServiceStatuses.NEW)
# Now wait for the response from the create to do additional work