aboutsummaryrefslogtreecommitdiffstats
path: root/moonv4/moon_router/moon_router/server.py
blob: 40e2b9459d6acac5c370e61847f962499680d056 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# Copyright 2015 Open Platform for NFV Project, Inc. and its contributors
# This software is distributed under the terms and conditions of the 'Apache-2.0'
# license which can be found in the file 'LICENSE' in this package distribution
# or at 'http://www.apache.org/licenses/LICENSE-2.0'.

import os
import threading
import signal
from oslo_config import cfg
from oslo_log import log as logging
from moon_utilities import options  # noqa
from moon_router.messenger import Server


class AsyncServer(threading.Thread):

    def __init__(self, add_master_cnx):
        threading.Thread.__init__(self)
        self.server = Server(add_master_cnx=add_master_cnx)

    def run(self):
        self.server.run()

LOG = logging.getLogger(__name__)
CONF = cfg.CONF
DOMAIN = "moon_router"

__CWD__ = os.path.dirname(os.path.abspath(__file__))

background_threads = []


def stop_thread():
    for _t in background_threads:
        _t.stop()


def main():
    global background_threads
    LOG.info("Starting server with IP {}".format(CONF.security_router.host))
    signal.signal(signal.SIGALRM, stop_thread)
    signal.signal(signal.SIGTERM, stop_thread)
    signal.signal(signal.SIGABRT, stop_thread)
    background_master = None
    if CONF.slave.slave_name:
        background_master = AsyncServer(add_master_cnx=True)
        background_threads.append(background_master)
    background_slave = AsyncServer(add_master_cnx=False)
    background_threads.append(background_slave)
    if CONF.slave.slave_name:
        background_master.start()
    background_slave.start()
    if CONF.slave.slave_name:
        background_master.join()
    background_slave.join()


if __name__ == '__main__':
    main()