Python logging模块介绍:
http://blog.chinaunix.net/uid-26000296-id-4372063.html

[root@fuel ~]# vi /var/lib/docker/devicemapper/mnt/4da57a0078c9d3f32e819373b67de41da37c34a27ee03f74016427e0223df5f2/rootfs/usr/lib/python2.6/site-packages/nailgun/db/sqlalchemy/models/node.py
     88
     89 class Node(Base):

304     @classmethod
    305     def delete_by_ids(cls, ids):
    306         db.query(Node).filter(Node.id.in_(ids)).delete('fetch')

38 from nailgun.logger import logger
可看出引用了:
/usr/lib/python2.6/site-packages/nailgun/logger.py中的logger变量。

[root@fuel ~]# vi /var/lib/docker/devicemapper/mnt/4da57a0078c9d3f32e819373b67de41da37c34a27ee03f74016427e0223df5f2/rootfs/usr/lib/python2.6/site-packages/nailgun/logger.py
     17 import logging
     18 import sys

57 logger = make_nailgun_logger()

31 def make_nailgun_logger():
     32     """Make logger for nailgun app writes logs to stdout
     33     """
     34     logger = logging.getLogger("nailgun")
     35     logger.setLevel(logging.DEBUG)
     36     handler = logging.StreamHandler(sys.stdout)
     37     handler.setFormatter(formatter)
     38     logger.addHandler(handler)
     39     return logger
     40

28 formatter = logging.Formatter(LOGFORMAT, DATEFORMAT)

可见默认node.py将日志输出到标准输出,且最小日志输出级别是DEBUG级别。稍作改动,输出到日志文件中:
     36 #    handler = logging.StreamHandler(sys.stdout)
     37     handler = logging.FileHandler('/tmp/nailgun.log')

[root@fuel ~]# ls -l /var/lib/docker/devicemapper/mnt/4da57a0078c9d3f32e819373b67de41da37c34a27ee03f74016427e0223df5f2/rootfs/usr/lib/python2.6/site-packages/nailgun/logger.py*
-rwxr-xr-x 1 root root 3936 Jan 27 10:44 /var/lib/docker/devicemapper/mnt/4da57a0078c9d3f32e819373b67de41da37c34a27ee03f74016427e0223df5f2/rootfs/usr/lib/python2.6/site-packages/nailgun/logger.py
-rwxr-xr-x 2 root root 4509 Jun 19  2015 /var/lib/docker/devicemapper/mnt/4da57a0078c9d3f32e819373b67de41da37c34a27ee03f74016427e0223df5f2/rootfs/usr/lib/python2.6/site-packages/nailgun/logger.pyc
-rwxr-xr-x 2 root root 4509 Jun 19  2015 /var/lib/docker/devicemapper/mnt/4da57a0078c9d3f32e819373b67de41da37c34a27ee03f74016427e0223df5f2/rootfs/usr/lib/python2.6/site-packages/nailgun/logger.pyo

改完代码重启nailgun服务:
[root@fuel ~]# docker restart fuel-core-6.1-nailgun

验证日志已经生成:
[root@fuel ~]# ls -l /var/lib/docker/devicemapper/mnt/4da57a0078c9d3f32e819373b67de41da37c34a27ee03f74016427e0223df5f2/rootfs/tmp/nailgun.log

[root@fuel ~]# ls -l /var/lib/docker/devicemapper/mnt/4da57a0078c9d3f32e819373b67de41da37c34a27ee03f74016427e0223df5f2/rootfs/usr/lib/python2.6/site-packages/nailgun/logger.py*
-rwxr-xr-x 1 root root 3936 Jan 27 10:44 /var/lib/docker/devicemapper/mnt/4da57a0078c9d3f32e819373b67de41da37c34a27ee03f74016427e0223df5f2/rootfs/usr/lib/python2.6/site-packages/nailgun/logger.py
-rw-r--r-- 1 root root 4509 Jan 27 10:49 /var/lib/docker/devicemapper/mnt/4da57a0078c9d3f32e819373b67de41da37c34a27ee03f74016427e0223df5f2/rootfs/usr/lib/python2.6/site-packages/nailgun/logger.pyc
-rwxr-xr-x 1 root root 4509 Jun 19  2015 /var/lib/docker/devicemapper/mnt/4da57a0078c9d3f32e819373b67de41da37c34a27ee03f74016427e0223df5f2/rootfs/usr/lib/python2.6/site-packages/nailgun/logger.pyo

制作符号链接:
[root@fuel ~]# ln -s /var/lib/docker/devicemapper/mnt/4da57a0078c9d3f32e819373b67de41da37c34a27ee03f74016427e0223df5f2/rootfs/tmp/nailgun.log /root/nailgun.log

修改node.py源代码:
[root@fuel ~]# vi /var/lib/docker/devicemapper/mnt/4da57a0078c9d3f32e819373b67de41da37c34a27ee03f74016427e0223df5f2/rootfs/usr/lib/python2.6/site-packages/nailgun/db/sqlalchemy/models/node.py
     89 class Node(Base):
     90     logger.logger.warning("____ffff____")

改完代码重启nailgun服务:
[root@fuel ~]# docker restart fuel-core-6.1-nailgun

验证代码被调用:
[root@fuel ~]# grep '____ffff____' nailgun.log
清空日志:
[root@fuel ~]# echo ''>nailgun.log
[root@fuel ~]# cat nailgun.log

[root@fuel ~]# fuel node
DEPRECATION WARNING: /etc/fuel/client/config.yaml exists and will be used as the source for settings. This behavior is deprecated. Please specify the path to your custom settings file in the FUELCLIENT_CUSTOM_SETTINGS environment variable.
id | status       | name  | cluster | ip           | mac               | roles                     | pending_roles | online | group_id
---|--------------|-------|---------|--------------|-------------------|---------------------------|---------------|--------|---------
10 | provisioning | RD530 | 1       | 168.5.21.106 | a0:36:9f:8d:40:88 | compute                   |               | True   | 1
2  | ready        | UCS2  | 1       | 168.5.21.101 | 00:25:b5:00:00:21 | cinder, controller, mongo |               | True   | 1
4  | ready        | R720  | 1       | 168.5.21.103 | c8:1f:66:d0:33:83 | compute                   |               | True   | 1
1  | ready        | UCS1  | 1       | 168.5.21.100 | 00:25:b5:00:00:11 | cinder, controller, mongo |               | True   | 1
3  | ready        | R420  | 1       | 168.5.21.102 | 00:1b:78:5a:9e:46 | cinder, controller, mongo |               | True   | 1
[root@fuel ~]# cat nailgun.log

[root@fuel ~]#
说明“fuel node”命令没调用到node.py。

修改Python文件日志输出位置的更多相关文章

  1. python logging日志输出个文件中

    # -*- coding:utf-8 -*- import logging # 引入logging模块 import os.path import time # 第一步,创建一个logger logg ...

  2. Python模块:日志输出—logging模块

    1. logging介绍 Python的logging模块提供了通用的日志系统,可以方便第三方模块或者是应用使用.这个模块提供不同的日志级别,并可以采用不同的方式记录日志,比如文件,HTTP GET/ ...

  3. oracle修改闪回日志的位置

    改变闪回日志位置的步骤: A.Change the value of the DB_RECOVERY_FILE_DEST initialization parameter to a new value ...

  4. Eclipse设置控制台日志输出位置

    1.选择服务器配置 2.设置输出文件路径

  5. IDEA指定.class文件输出位置

    1.File > Project Structure > Project > Project compiler output  项目中的默认编译输出总目录 2.我习惯于把.class ...

  6. log4j日志输出到web项目指定文件夹

    感谢 eric2500 的这篇文章:http://www.cxyclub.cn/n/27860/ 摘要:尝试将log4j的文件日志输出到web工程制定目录,遇到了很多问题,最终在eric2500的指导 ...

  7. Python之日志处理(logging模块)

    本节内容 日志相关概念 logging模块简介 使用logging提供的模块级别的函数记录日志 logging模块日志流处理流程 使用logging四大组件记录日志 配置logging的几种方式 向日 ...

  8. 【转】Python之日志处理(logging模块)

    [转]Python之日志处理(logging模块) 本节内容 日志相关概念 logging模块简介 使用logging提供的模块级别的函数记录日志 logging模块日志流处理流程 使用logging ...

  9. Python logging(日志)模块

    python日志模块 内容简介 1.日志相关概念 2.logging模块简介 3.logging模块函数使用 4.logging模块日志流处理流程 5.logging模块组件使用 6.logging配 ...

随机推荐

  1. [转载]C#控制台应用程序里调用自己写的函数的方法

    (2011-08-15 15:52:13) 转载▼ 标签: 转载 分类: 技术类 原文地址:C#控制台应用程序里调用自己写的函数的方法作者:萧儿 最近写程序,遇到了一个很白痴的问题,记录下来,免得下次 ...

  2. Codeforces Round #364 (Div. 2) D. As Fast As Possible

     D. As Fast As Possible time limit per test 1 second memory limit per test 256 megabytes input stand ...

  3. OPENWRT make defconfig错误之一

    make defconfig rm: cannot remove `tmp/.host.mk': Permission denied 退到trunk上级目录 su root sudo chown -R ...

  4. Linq第一讲

    在说LINQ之前必须先说说几个重要的C#语言特性 一:与LINQ有关的语言特性 1.隐式类型 (1)源起 在隐式类型出现之前,在声明一个变量的时候, 总是要为一个变量指定他的类型甚至在foreach一 ...

  5. centos装openoffice

    一.安装openOffice1.使用tar -xzvf OOo_3.2.0_LinuxIntel_install_wJRE_en-US.tar.gz解压缩后,会得到OOO320_m12_native_ ...

  6. 常见B2C网站购物车的设计

    对于大部分B2C网站来说,购物车是网站的咽喉之地,订单是白花花的银子,所有银子都必然流经购物车,购物车不能有失.优秀的购物车设计至少需要完成两项使命:一是方便用户多买货多掏银子:二是帮用户保管好待购的 ...

  7. 桥接 NAT HOST-ONLY

    无论是vmware,virtual box,virtual pc等虚拟机软件,一般来说,虚拟机有三种网络模式: 1.桥接 2.NAT 3.Host-Only 桥接 桥接网络是指本地物理网卡和虚拟网卡通 ...

  8. XStream的使用方法、简单使用方法、xml的解析方法

    下面介绍的是在Android Studio中的使用 Android Studio中目前支持的Xstream最高版本是xstream-1.4.7.jar,大家可以在网上下载,我的是在开源中国项目中有这个 ...

  9. table新增空白行到首行

    var str=""; str+="<tr bordercolor='#DEDEDE' bgcolor='#ffffff'>"; str+=&quo ...

  10. shell中exec解析

    参考:<linux命令.编辑器与shell编程> <unix环境高级编程> exec和source都属于bash内部命令(builtins commands),在bash下输入 ...