##// END OF EJS Templates
BUG Move setting of log_active flag down...
BUG Move setting of log_active flag down Previously, if there was an error opening the file (e.g., permission denied), then the object would end up in a state where log_active was True, but there was no logfile. The result was constant errors.

File last commit:

r3688:ef471568
r3887:3fdc9a4a
Show More
iploggerapp.py
132 lines | 4.3 KiB | text/x-python | PythonLexer
#!/usr/bin/env python
# encoding: utf-8
"""
A simple IPython logger application
"""
#-----------------------------------------------------------------------------
# Copyright (C) 2011 The IPython Development Team
#
# Distributed under the terms of the BSD License. The full license is in
# the file COPYING, distributed as part of this software.
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
# Imports
#-----------------------------------------------------------------------------
import os
import sys
import zmq
from IPython.parallel.apps.clusterdir import (
ApplicationWithClusterDir,
ClusterDirConfigLoader
)
from IPython.parallel.apps.logwatcher import LogWatcher
#-----------------------------------------------------------------------------
# Module level variables
#-----------------------------------------------------------------------------
#: The default config file name for this application
default_config_file_name = u'iplogger_config.py'
_description = """Start an IPython logger for parallel computing.\n\n
IPython controllers and engines (and your own processes) can broadcast log messages
by registering a `zmq.log.handlers.PUBHandler` with the `logging` module. The
logger can be configured using command line options or using a cluster
directory. Cluster directories contain config, log and security files and are
usually located in your ipython directory and named as "cluster_<profile>".
See the --profile and --cluster-dir options for details.
"""
#-----------------------------------------------------------------------------
# Command line options
#-----------------------------------------------------------------------------
class IPLoggerAppConfigLoader(ClusterDirConfigLoader):
def _add_arguments(self):
super(IPLoggerAppConfigLoader, self)._add_arguments()
paa = self.parser.add_argument
# Controller config
paa('--url',
type=str, dest='LogWatcher.url',
help='The url the LogWatcher will listen on',
)
# MPI
paa('--topics',
type=str, dest='LogWatcher.topics', nargs='+',
help='What topics to subscribe to',
metavar='topics')
# Global config
paa('--log-to-file',
action='store_true', dest='Global.log_to_file',
help='Log to a file in the log directory (default is stdout)')
#-----------------------------------------------------------------------------
# Main application
#-----------------------------------------------------------------------------
class IPLoggerApp(ApplicationWithClusterDir):
name = u'iploggerz'
description = _description
command_line_loader = IPLoggerAppConfigLoader
default_config_file_name = default_config_file_name
auto_create_cluster_dir = True
def create_default_config(self):
super(IPLoggerApp, self).create_default_config()
# The engine should not clean logs as we don't want to remove the
# active log files of other running engines.
self.default_config.Global.clean_logs = False
# If given, this is the actual location of the logger's URL file.
# If not, this is computed using the profile, app_dir and furl_file_name
self.default_config.Global.url_file_name = u'iplogger.url'
self.default_config.Global.url_file = u''
def post_load_command_line_config(self):
pass
def pre_construct(self):
super(IPLoggerApp, self).pre_construct()
def construct(self):
# This is the working dir by now.
sys.path.insert(0, '')
self.start_logging()
try:
self.watcher = LogWatcher(config=self.master_config, logname=self.log.name)
except:
self.log.error("Couldn't start the LogWatcher", exc_info=True)
self.exit(1)
def start_app(self):
try:
self.watcher.start()
self.watcher.loop.start()
except KeyboardInterrupt:
self.log.critical("Logging Interrupted, shutting down...\n")
def launch_new_instance():
"""Create and run the IPython LogWatcher"""
app = IPLoggerApp()
app.start()
if __name__ == '__main__':
launch_new_instance()