summaryrefslogtreecommitdiff
path: root/bin/swift-container-replicator.py
diff options
context:
space:
mode:
Diffstat (limited to 'bin/swift-container-replicator.py')
-rwxr-xr-xbin/swift-container-replicator.py57
1 files changed, 57 insertions, 0 deletions
diff --git a/bin/swift-container-replicator.py b/bin/swift-container-replicator.py
new file mode 100755
index 000000000..db2ffc8b2
--- /dev/null
+++ b/bin/swift-container-replicator.py
@@ -0,0 +1,57 @@
+#!/usr/bin/python
+# Copyright (c) 2010 OpenStack, LLC.
+#
+# 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 sys
+from ConfigParser import ConfigParser
+import getopt
+
+from swift.container import server as container_server
+from swift.common import db, db_replicator, utils
+
+class ContainerReplicator(db_replicator.Replicator):
+ server_type = 'container'
+ ring_file = 'container.ring.gz'
+ brokerclass = db.ContainerBroker
+ datadir = container_server.DATADIR
+ default_port = 6001
+
+if __name__ == '__main__':
+ optlist, args = getopt.getopt(sys.argv[1:], '', ['once'])
+
+ if not args:
+ print "Usage: container-replicator <--once> CONFIG_FILE [once]"
+ sys.exit()
+
+ c = ConfigParser()
+ if not c.read(args[0]):
+ print "Unable to read config file."
+ sys.exit(1)
+ once = len(args) > 1 and args[1] == 'once'
+
+ server_conf = dict(c.items('container-server'))
+ if c.has_section('container-replicator'):
+ replicator_conf = dict(c.items('container-replicator'))
+ else:
+ print "Unable to find container-replicator config section in %s." % \
+ args[0]
+ sys.exit(1)
+
+ utils.drop_privileges(server_conf.get('user', 'swift'))
+ if once or '--once' in [opt[0] for opt in optlist]:
+ ContainerReplicator(server_conf, replicator_conf).replicate_once()
+ else:
+ ContainerReplicator(server_conf, replicator_conf).replicate_forever()
+