'''
__author__="Alfonso Tierno, Gerardo Garcia, Pablo Montes"
__date__ ="$26-aug-2014 11:09:29$"
-__version__="0.5.2-r510"
-version_date="Oct 2016"
-database_version="0.16" #expected database schema version
+__version__="0.5.8-r518"
+version_date="Jan 2017"
+database_version="0.19" #expected database schema version
import httpserver
import time
'http_console_host': None,
'log_level': 'DEBUG',
'log_socket_port': 9022,
+ 'auto_push_VNF_to_VIMs': True
}
try:
#Check config file exists
logger.setLevel(logging.DEBUG)
socket_handler = None
file_handler = None
- # Read parameters and configuration file
+ # Read parameters and configuration file
+ httpthread = None
try:
#load parameters and configuration
opts, args = getopt.getopt(sys.argv[1:], "hvc:V:p:P:", ["config=", "help", "version", "port=", "vnf-repository=", "adminport=", "log-socket-host=", "log-socket-port=", "log-file="])
raise LoadConfigurationException("Cannot open logging file '{}': {}. Check folder exist and permissions".format(global_config["log_file"], str(e)) )
#logging.basicConfig(level = getattr(logging, global_config.get('log_level',"debug")))
logger.setLevel(getattr(logging, global_config['log_level']))
- logger.critical("Starting openmano server command: '%s'", sys.argv[0])
+ logger.critical("Starting openmano server version: '%s %s' command: '%s'",
+ __version__, version_date, " ".join(sys.argv))
- for log_module in ("nfvo", "http", "vim", "db"):
+ for log_module in ("nfvo", "http", "vim", "db", "console"):
log_level_module = "log_level_" + log_module
log_file_module = "log_file_" + log_module
logger_module = logging.getLogger('openmano.' + log_module)
exit(-1)
nfvo.global_config=global_config
+ nfvo.start_service(mydb)
httpthread = httpserver.httpserver(mydb, False, global_config['http_host'], global_config['http_port'])
#TODO: Interactive console must be implemented here instead of join or sleep
#httpthread.join()
- #if 'http_admin_port' in global_config:
+ #if 'http_admin_port' in global_config:
# httpthreadadmin.join()
while True:
time.sleep(86400)
- for thread in global_config["console_thread"]:
- thread.terminate = True
except KeyboardInterrupt as e:
logger.info(str(e))
except db_base_Exception as e:
logger.critical(str(e))
exit(-1)
+ nfvo.stop_service()
+ if httpthread:
+ httpthread.join(1)
+ for thread in global_config["console_thread"]:
+ thread.terminate = True