Matteo Scandolo | d2044a4 | 2017-08-07 16:08:28 -0700 | [diff] [blame] | 1 | |
| 2 | # Copyright 2017-present Open Networking Foundation |
| 3 | # |
| 4 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | # you may not use this file except in compliance with the License. |
| 6 | # You may obtain a copy of the License at |
| 7 | # |
| 8 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | # |
| 10 | # Unless required by applicable law or agreed to in writing, software |
| 11 | # distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | # See the License for the specific language governing permissions and |
| 14 | # limitations under the License. |
| 15 | |
| 16 | |
Scott Baker | c8bbe9e | 2018-01-16 17:48:59 -0800 | [diff] [blame] | 17 | import argparse |
Scott Baker | 268bc2a | 2017-03-03 18:02:12 -0800 | [diff] [blame] | 18 | import os |
| 19 | import sys |
| 20 | import time |
| 21 | |
Scott Baker | de57642 | 2018-02-23 09:53:37 -0800 | [diff] [blame] | 22 | from grpc_server import XOSGrpcServer |
Scott Baker | 268bc2a | 2017-03-03 18:02:12 -0800 | [diff] [blame] | 23 | |
Sapan Bhatia | 06de76b | 2017-08-22 16:53:50 -0400 | [diff] [blame] | 24 | from xosconfig import Config |
| 25 | from multistructlog import create_logger |
Scott Baker | 268bc2a | 2017-03-03 18:02:12 -0800 | [diff] [blame] | 26 | |
Sapan Bhatia | 06de76b | 2017-08-22 16:53:50 -0400 | [diff] [blame] | 27 | log = create_logger(Config().get('logging')) |
Matteo Scandolo | 6bc017c | 2017-05-25 18:37:42 -0700 | [diff] [blame] | 28 | |
Zack Williams | 73a1285 | 2018-09-05 15:33:35 -0700 | [diff] [blame^] | 29 | # create an single kafka producer connection for the core |
| 30 | from xoskafka import XOSKafkaProducer |
| 31 | XOSKafkaProducer.init() |
| 32 | |
Scott Baker | c8bbe9e | 2018-01-16 17:48:59 -0800 | [diff] [blame] | 33 | def parse_args(): |
| 34 | parser = argparse.ArgumentParser() |
| 35 | parser.add_argument("--model_status", dest="model_status", type=int, default=0, help="status of model prep") |
| 36 | parser.add_argument("--model_output", dest="model_output", type=file, default=None, help="file containing output of model prep step") |
| 37 | args = parser.parse_args() |
| 38 | |
| 39 | if args.model_output: |
| 40 | args.model_output = args.model_output.read() |
| 41 | else: |
| 42 | args.model_output = "" |
| 43 | |
| 44 | return args |
| 45 | |
Scott Baker | b06e3e0 | 2017-12-12 11:05:53 -0800 | [diff] [blame] | 46 | def init_reaper(): |
| 47 | reaper = None |
| 48 | try: |
| 49 | from reaper import ReaperThread |
| 50 | reaper = ReaperThread() |
| 51 | reaper.start() |
| 52 | except: |
Scott Baker | c8bbe9e | 2018-01-16 17:48:59 -0800 | [diff] [blame] | 53 | log.exception("Failed to initialize reaper") |
Scott Baker | b06e3e0 | 2017-12-12 11:05:53 -0800 | [diff] [blame] | 54 | |
| 55 | return reaper |
| 56 | |
Scott Baker | 268bc2a | 2017-03-03 18:02:12 -0800 | [diff] [blame] | 57 | if __name__ == '__main__': |
Scott Baker | c8bbe9e | 2018-01-16 17:48:59 -0800 | [diff] [blame] | 58 | args = parse_args() |
| 59 | |
| 60 | server = XOSGrpcServer(model_status = args.model_status, |
| 61 | model_output = args.model_output) |
Scott Baker | b06e3e0 | 2017-12-12 11:05:53 -0800 | [diff] [blame] | 62 | server.start() |
Matteo Scandolo | d920855 | 2017-06-21 14:15:16 -0700 | [diff] [blame] | 63 | |
Scott Baker | c8bbe9e | 2018-01-16 17:48:59 -0800 | [diff] [blame] | 64 | if server.django_initialized: |
| 65 | reaper = init_reaper() |
| 66 | else: |
| 67 | log.warning("Skipping reaper as django is not initialized") |
| 68 | reaper = None |
Scott Baker | 268bc2a | 2017-03-03 18:02:12 -0800 | [diff] [blame] | 69 | |
Sapan Bhatia | 06de76b | 2017-08-22 16:53:50 -0400 | [diff] [blame] | 70 | log.info("XOS core entering wait loop") |
Scott Baker | 268bc2a | 2017-03-03 18:02:12 -0800 | [diff] [blame] | 71 | _ONE_DAY_IN_SECONDS = 60 * 60 * 24 |
| 72 | try: |
Scott Baker | b06e3e0 | 2017-12-12 11:05:53 -0800 | [diff] [blame] | 73 | while True: |
| 74 | if server.exit_event.wait(_ONE_DAY_IN_SECONDS): |
| 75 | break |
Scott Baker | 268bc2a | 2017-03-03 18:02:12 -0800 | [diff] [blame] | 76 | except KeyboardInterrupt: |
Sapan Bhatia | 06de76b | 2017-08-22 16:53:50 -0400 | [diff] [blame] | 77 | log.info("XOS core terminated by keyboard interrupt") |
Scott Baker | 268bc2a | 2017-03-03 18:02:12 -0800 | [diff] [blame] | 78 | |
Scott Baker | b06e3e0 | 2017-12-12 11:05:53 -0800 | [diff] [blame] | 79 | server.stop() |
Scott Baker | c8bbe9e | 2018-01-16 17:48:59 -0800 | [diff] [blame] | 80 | |
| 81 | if reaper: |
| 82 | reaper.stop() |