1
0
forked from M-Labs/artiq
artiq/artiq/frontend/artiq_ctlmgr.py

89 lines
3.0 KiB
Python
Raw Normal View History

#!/usr/bin/env python3.5
2015-02-06 12:17:51 +08:00
import asyncio
import atexit
2015-02-06 12:17:51 +08:00
import argparse
import os
import logging
2015-10-17 10:58:15 +08:00
import platform
2015-02-06 12:17:51 +08:00
from artiq.protocols.pc_rpc import Server
from artiq.protocols.logging import LogForwarder, SourceFilter
from artiq.tools import (simple_network_args, atexit_register_coroutine,
bind_address_from_args)
from artiq.devices.ctlmgr import ControllerManager
2015-02-06 12:17:51 +08:00
2015-02-07 23:52:05 +08:00
2015-10-16 18:35:58 +08:00
def get_argparser():
parser = argparse.ArgumentParser(description="ARTIQ controller manager")
group = parser.add_argument_group("verbosity")
group.add_argument("-v", "--verbose", default=0, action="count",
2015-10-16 20:08:11 +08:00
help="increase logging level of the manager process")
2015-10-16 18:35:58 +08:00
group.add_argument("-q", "--quiet", default=0, action="count",
2015-10-16 20:08:11 +08:00
help="decrease logging level of the manager process")
2015-10-16 18:35:58 +08:00
parser.add_argument(
"-s", "--server", default="::1",
help="hostname or IP of the master to connect to")
parser.add_argument(
"--port-notify", default=3250, type=int,
help="TCP port to connect to for notifications")
parser.add_argument(
"--port-logging", default=1066, type=int,
help="TCP port to connect to for logging")
parser.add_argument(
"--retry-master", default=5.0, type=float,
help="retry timer for reconnecting to master")
simple_network_args(parser, [("control", "control", 3249)])
2015-10-16 18:35:58 +08:00
return parser
2015-02-07 23:52:05 +08:00
def main():
args = get_argparser().parse_args()
2015-10-16 18:35:58 +08:00
root_logger = logging.getLogger()
2015-10-16 20:08:11 +08:00
root_logger.setLevel(logging.NOTSET)
source_adder = SourceFilter(logging.WARNING +
args.quiet*10 - args.verbose*10,
2015-10-17 10:58:15 +08:00
"ctlmgr({})".format(platform.node()))
2015-10-16 18:35:58 +08:00
console_handler = logging.StreamHandler()
console_handler.setFormatter(logging.Formatter(
"%(levelname)s:%(source)s:%(name)s:%(message)s"))
console_handler.addFilter(source_adder)
root_logger.addHandler(console_handler)
2015-02-08 21:44:49 +08:00
2015-02-07 23:52:05 +08:00
if os.name == "nt":
loop = asyncio.ProactorEventLoop()
asyncio.set_event_loop(loop)
else:
loop = asyncio.get_event_loop()
atexit.register(loop.close)
2015-02-08 21:44:49 +08:00
2015-10-16 18:35:58 +08:00
logfwd = LogForwarder(args.server, args.port_logging,
args.retry_master)
logfwd.addFilter(source_adder)
root_logger.addHandler(logfwd)
logfwd.start()
atexit_register_coroutine(logfwd.stop)
2015-10-16 18:35:58 +08:00
ctlmgr = ControllerManager(args.server, args.port_notify,
args.retry_master)
ctlmgr.start()
atexit_register_coroutine(ctlmgr.stop)
class CtlMgrRPC:
retry_now = ctlmgr.retry_now
rpc_target = CtlMgrRPC()
rpc_server = Server({"ctlmgr": rpc_target}, builtin_terminate=True)
loop.run_until_complete(rpc_server.start(bind_address_from_args(args),
args.port_control))
atexit_register_coroutine(rpc_server.stop)
loop.run_until_complete(rpc_server.wait_terminate())
2015-02-08 21:44:49 +08:00
2015-02-07 23:52:05 +08:00
2015-02-06 12:17:51 +08:00
if __name__ == "__main__":
main()