#!/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: swift-container-replicator <--once> CONFIG_FILE [once]" sys.exit(1) once = len(args) > 1 and args[1] == 'once' conf = utils.readconf(args[0], 'container-replicator') utils.drop_privileges(conf.get('user', 'swift')) if once or '--once' in [opt[0] for opt in optlist]: ContainerReplicator(conf).replicate_once() else: ContainerReplicator(conf).replicate_forever()