Logging hierarchy vs. root logger?
The Python logging
module organizes loggers in a hierarchy. All loggers are descendants of the root logger. Each logger passes log messages on to its parent.
New loggers are created with the getLogger()
function. The function call logging.getLogger('debug0.x')
creates a logger x
which is a child of debug0
which itself is a child of the root logger. When logging to this logger, it will pass on the message to its parent, and its parent will pass the message to the root logger. You configured the root logger to log to a file by the basicConfig()
function, so your message will end up there.
If you check out the code or the doc:
>>> print logging.basicConfig.__doc__
Do basic configuration for the logging system.
This function does nothing if the root logger already has handlers
configured. ...............
A number of optional keyword arguments may be specified, which can alter
the default behaviour.
filename Specifies that a FileHandler be created, using the specified
filename, rather than a StreamHandler.
filemode Specifies the mode to open the file, if filename is specified
(if filemode is unspecified, it defaults to 'a').
format Use the specified format string for the handler.
datefmt Use the specified date/time format.
level Set the root logger level to the specified level.
stream Use the specified stream to initialize the StreamHandler. Note
that this argument is incompatible with 'filename' - if both
are present, 'stream' is ignored.
logging.basicConfig does not use name argument at all. It initializes the root logger. While getLogger takes a "name" argument
>>> print logging.getLogger.__doc__
Return a logger with the specified name, creating it if necessary.
If no name is specified, return the root logger.