neomaster.py 1.97 KB
Newer Older
1 2
#!/usr/bin/env python
#
3 4
# neomaster - run a master node of NEO
#
5
# Copyright (C) 2006-2015  Nexedi SA
6
#
7 8 9 10
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
11
#
12 13 14 15 16 17
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
18
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
19

20
from neo.lib import logging
21
from neo.lib.config import getServerOptionParser, ConfigurationManager
22

23
parser = getServerOptionParser()
24 25 26
parser.add_option('-u', '--uuid', help='the node UUID (testing purpose)')
parser.add_option('-r', '--replicas', help = 'replicas number')
parser.add_option('-p', '--partitions', help = 'partitions number')
27 28 29 30
parser.add_option('-A', '--autostart',
    help='minimum number of pending storage nodes to automatically start'
         ' new cluster (to avoid unwanted recreation of the cluster,'
         ' this should be the total number of storage nodes)')
31 32 33 34
parser.add_option('-C', '--upstream-cluster',
    help='the name of cluster to backup')
parser.add_option('-M', '--upstream-masters',
    help='list of master nodes in cluster to backup')
35 36 37 38 39 40 41 42 43 44 45

defaults = dict(
    bind = '127.0.0.1:10000',
    masters = '',
    replicas = 0,
    partitions = 100,
)

def main(args=None):
    # build configuration dict from command line options
    (options, args) = parser.parse_args(args=args)
46
    config = ConfigurationManager(defaults, options, 'master')
47 48

    # setup custom logging
49
    logging.setup(config.getLogfile())
50 51 52 53 54 55

    # and then, load and run the application
    from neo.master.app import Application
    app = Application(config)
    app.run()