summaryrefslogtreecommitdiff
path: root/bin
diff options
context:
space:
mode:
authorMichael Basnight <mbasnight@gmail.com>2012-03-05 07:59:34 -0600
committerMichael Basnight <mbasnight@gmail.com>2012-03-05 08:04:59 -0600
commitf2d09827cdc9a98be945931c9ed7483c6ec312a9 (patch)
treeaf4532ca3875799bba32a6fe74647b2a41409e59 /bin
parentc6a27dc540c0e1ccaa2d88340f3f9826680a501e (diff)
downloadtrove-f2d09827cdc9a98be945931c9ed7483c6ec312a9.tar.gz
Added the taskmanager class with some testing rpc code
* Fixed a bug in rpc kombu w/ a bad durable declaration * Fixed the name of the queue exchange * Added a bit of rpc code to the taskmanager service for consuming * * This is mostly experimental at this point!!! * * This should be refactored into something common!!!
Diffstat (limited to 'bin')
-rwxr-xr-xbin/reddwarf-taskmanager72
1 files changed, 72 insertions, 0 deletions
diff --git a/bin/reddwarf-taskmanager b/bin/reddwarf-taskmanager
new file mode 100755
index 00000000..2699f146
--- /dev/null
+++ b/bin/reddwarf-taskmanager
@@ -0,0 +1,72 @@
+#!/usr/bin/env python
+# vim: tabstop=4 shiftwidth=4 softtabstop=4
+
+# Copyright 2011 OpenStack LLC.
+# All Rights Reserved.
+#
+# 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.
+
+import gettext
+import optparse
+import os
+import sys
+
+
+gettext.install('reddwarf', unicode=1)
+
+
+# If ../reddwarf/__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, 'reddwarf', '__init__.py')):
+ sys.path.insert(0, possible_topdir)
+
+from reddwarf import version
+from reddwarf.common import config
+from reddwarf.common import wsgi
+#from reddwarf.db import db_api
+
+def create_options(parser):
+ """Sets up the CLI and config-file options
+
+ :param parser: The option parser
+ :returns: None
+
+ """
+ parser.add_option('-p', '--port', dest="port", metavar="PORT",
+ type=int, default=8778,
+ help="Port the Reddwarf Work Manager listens on. "
+ "Default: %default")
+ config.add_common_options(parser)
+ config.add_log_options(parser)
+
+
+if __name__ == '__main__':
+ oparser = optparse.OptionParser(version="%%prog %s"
+ % version.version_string())
+ create_options(oparser)
+ (options, args) = config.parse_options(oparser)
+ try:
+ conf, app = config.Config.load_paste_app('reddwarf-taskmanager', options, args)
+ #db_api.configure_db(conf)
+ server = wsgi.Server()
+ server.start(app, options.get('port', conf['bind_port']),
+ conf['bind_host'])
+ server.wait()
+ except RuntimeError as error:
+ import traceback
+ print traceback.format_exc()
+ sys.exit("ERROR: %s" % error)
+