artiq/artiq/frontend/artiq_master.py

87 lines
2.6 KiB
Python
Raw Normal View History

#!/usr/bin/env python3
import asyncio
2014-10-25 11:34:52 +08:00
import argparse
2014-12-31 17:41:22 +08:00
import atexit
import os
from artiq.protocols.pc_rpc import Server
2015-07-14 04:08:20 +08:00
from artiq.protocols.sync_struct import Notifier, Publisher, process_mod
from artiq.protocols.file_db import FlatFileDB
2015-01-14 12:16:49 +08:00
from artiq.master.scheduler import Scheduler
2015-07-14 04:08:20 +08:00
from artiq.master.worker_db import get_last_rid
2015-01-26 23:37:33 +08:00
from artiq.master.repository import Repository
2015-01-28 21:44:15 +08:00
from artiq.tools import verbosity_args, init_logger
2015-01-23 00:52:13 +08:00
def get_argparser():
parser = argparse.ArgumentParser(description="ARTIQ master")
group = parser.add_argument_group("network")
group.add_argument(
2014-10-25 11:34:52 +08:00
"--bind", default="::1",
help="hostname or IP address to bind to")
group.add_argument(
"--port-notify", default=3250, type=int,
2015-03-24 03:02:14 +08:00
help="TCP port to listen to for notifications (default: %(default)d)")
group.add_argument(
"--port-control", default=3251, type=int,
2015-03-24 03:02:14 +08:00
help="TCP port to listen to for control (default: %(default)d)")
2015-01-28 21:44:15 +08:00
verbosity_args(parser)
2015-01-23 00:52:13 +08:00
return parser
2014-10-25 11:34:52 +08:00
def main():
2015-01-23 00:52:13 +08:00
args = get_argparser().parse_args()
2015-01-28 21:44:15 +08:00
init_logger(args)
ddb = FlatFileDB("ddb.pyon")
pdb = FlatFileDB("pdb.pyon")
2015-07-14 04:08:20 +08:00
rtr = Notifier(dict())
2014-12-31 17:41:22 +08:00
2015-02-04 14:44:39 +08:00
if os.name == "nt":
loop = asyncio.ProactorEventLoop()
asyncio.set_event_loop(loop)
else:
loop = asyncio.get_event_loop()
2014-12-31 17:41:22 +08:00
atexit.register(lambda: loop.close())
2015-05-17 16:11:00 +08:00
worker_handlers = {
2015-07-14 04:08:20 +08:00
"get_device": ddb.get,
"get_parameter": pdb.get,
2015-01-13 19:12:19 +08:00
"set_parameter": pdb.set,
2015-07-14 04:08:20 +08:00
"update_rt_results": lambda mod: process_mod(rtr, mod),
}
2015-05-17 16:11:00 +08:00
scheduler = Scheduler(get_last_rid() + 1, worker_handlers)
worker_handlers["scheduler_submit"] = scheduler.submit
scheduler.start()
2014-12-31 17:41:22 +08:00
atexit.register(lambda: loop.run_until_complete(scheduler.stop()))
repository = Repository()
repository.scan_async()
2014-12-31 20:13:10 +08:00
server_control = Server({
"master_ddb": ddb,
2015-01-26 23:37:33 +08:00
"master_pdb": pdb,
"master_schedule": scheduler,
"master_repository": repository
2014-12-31 20:13:10 +08:00
})
loop.run_until_complete(server_control.start(
args.bind, args.port_control))
atexit.register(lambda: loop.run_until_complete(server_control.stop()))
2014-12-31 17:41:22 +08:00
2014-12-31 20:13:10 +08:00
server_notify = Publisher({
2015-05-17 16:11:00 +08:00
"schedule": scheduler.notifier,
"devices": ddb.data,
"parameters": pdb.data,
2015-07-14 04:08:20 +08:00
"rt_results": rtr,
"explist": repository.explist
2014-12-31 17:41:22 +08:00
})
2014-12-31 20:13:10 +08:00
loop.run_until_complete(server_notify.start(
args.bind, args.port_notify))
atexit.register(lambda: loop.run_until_complete(server_notify.stop()))
2014-12-31 17:41:22 +08:00
loop.run_forever()
if __name__ == "__main__":
main()