CodedDFS日志配置
本文根据Log4j的配置属性,编写了用于记录BMBR编码的日志
author: zyumeng
Blog: [url] http://www.cnblogs.com/zyumeng/ [/url]
利用配置文件/conf/CodedDFS.properties(放置在工程conf目录下),分别记录CodedDFS中BMBR的编码速率、解码速率和修复速率。
|
## CodedDFS.properties for LOGs in CodedDFS project
## # Define the root logger ## # 连接到根日志记录器的日志记录器,设置为INFO级别,在控制台显示,输出在滚动文件 log4j.rootLogger=INFO, stdout, RFA
## # Console config ## # 设置控制台显示ConsoleAppender log4j.appender.stdout=org.apache.log4j.ConsoleAppender # Log4j的输出布局模式(Layout接口) # 这里用的是PatternLayout,可以灵活的制定布局模式 log4j.appender.stdout.layout=org.apache.log4j.PatternLayout # Pattern format: Date LogLevel; LoggerName; LogMessage; # 输出格式:%d-时间;%p-logger级别;%c-类名{两级};%m-调用logger时设定输出内容;%n-换行 log4j.appender.stdout.layout.ConversionPattern=%d{yy/MM/ddHH:mm:ss}%p%c{2}:%m%n
## # Rolling File Appender = RFA # Add " RFA " to rootlogger above if you want to use this ## # 设置一个滚动日志文件 RollingFileAppender log4j.appender.RFA=org.apache.log4j.RollingFileAppender # Define the output file is logs/BMBRFileSystem.log # 输出到logs/BMBRFileSystem.log log4j.appender.RFA.File=logs/BMBRFileSystem.log log4j.appender.RFA.MaxFileSize=1000KB # Keep one backup file log4j.appender.RFA.MaxBackupIndex=1 log4j.appender.RFA.layout=org.apache.log4j.PatternLayout log4j.appender.RFA.layout.ConversionPattern=%d{yy/MM/ddHH:mm:ss}%p%c{2}:%m%n
# 对不同的类输出不同的文件
## # BMBREncoder # Output the logs of the BMBREncoder.class alone ## # 让edu.pkusz.codec.BMBR.BMBREncoder中的logger使用log4j.appender.EC所做的配置。 log4j.logger.edu.pkusz.codec.BMBR.BMBREncoder=INFO, EC, stdout
# 自定义的日志默认是同时输出到log4j.rootLogger所配置的日志中的 # 只让它们输出到自己指定的日志中:设置是否同时输出到log4j.rootLogger所配置的日志中 # 设为false就不会输出到其它位置 log4j.additivity.edu.pkusz.codec.BMBR.BMBREncoder=false log4j.appender.EC=org.apache.log4j.RollingFileAppender # Define the output file is logs/BMBREncoder.log log4j.appender.EC.File=logs/BMBREncoder.log log4j.appender.EC.MaxFileSize=1000KB log4j.appender.EC.layout=org.apache.log4j.PatternLayout log4j.appender.EC.layout.ConversionPattern=%d{yy/MM/ddHH:mm:ss}%p%c{2}:%m%n
## # BMBRDecoder # Output the logs of the BMBRDecoder.class alone ## # 让edu.pkusz.codec.BMBR. BMBRDecoder中的logger使用log4j.appender.DC所做的配置。 log4j.logger.edu.pkusz.codec.BMBR.BMBRDecoder=INFO,DC,stdout # 设置不同时输出到log4j.rootLogger所配置的日志中 log4j.additivity.edu.pkusz.codec.BMBR.BMBRDecoder=false log4j.appender.DC=org.apache.log4j.RollingFileAppender # Define the output file is logs/BMBRDecoder.log log4j.appender.DC.File=logs/BMBRDecoder.log log4j.appender.DC.MaxFileSize=1000KB log4j.appender.DC.layout=org.apache.log4j.PatternLayout log4j.appender.DC.layout.ConversionPattern=%d{yy/MM/ddHH:mm:ss}%p%c{2}:%m%n
## # BMBRBlockFixer # Output the logs of the BMBRBlockFixer.class and BMBRRegenerator.class alone ## # 让edu.pkusz.codec.BMBR. BMBRBlockFixer和BMBRRegenerator中的logger # 使用log4j.appender.FB所做的配置。 log4j.logger.edu.pkusz.codec.BMBR.BMBRBlockFixer=INFO,BF,stdout log4j.logger.edu.pkusz.codec.BMBR.BMBRRegenerator=INFO,BF,stdout # 设置不同时输出到log4j.rootLogger所配置的日志中 log4j.additivity.edu.pkusz.codec.BMBR.BMBRBlockFixer=false log4j.additivity.edu.pkusz.codec.BMBR.BMBRRegenerator=false log4j.appender.BF=org.apache.log4j.RollingFileAppender # Define the output file is logs/BMBRBlockFixer.log log4j.appender.BF.File=logs/BMBRBlockFixer.log log4j.appender.BF.MaxFileSize=1000KB log4j.appender.BF.layout=org.apache.log4j.PatternLayout log4j.appender.BF.layout.ConversionPattern=%d{yy/MM/ddHH:mm:ss}%p%c{2}:%m%n |
下面是调用的实例SampleLogger类
|
package org.apache.hadoop.fs;
import java.io.File;
import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.apache.log4j.PropertyConfigurator; import org.apache.log4j.config.PropertyPrinter;
publicclass LogTester { privatestatic Log log = LogFactory.getLog(LogTester.class); publicstaticvoid main(String[] arg){ // 注意要利用PropertyConfigurator.configure加载日志配置文件,也可使用相对路径 PropertyConfigurator.configure(System.getProperty("user.dir") + File.separator + "conf" + File.separator + "CodedDFS.properties");
log.info("=======================LogTester======================"); log.debug("DEBUG"); log.error("ERROR"); log.info("INFO"); log.warn("WARM"); log.trace("TRACE");
} } |
直接运行SampleLogger.class
运行结果:

因为配置文件中定义的是INFO级别,所以不输出DEBUG和TRACE信息
修改为log4j.rootLogger=DEBUG, stdout, RFA
运行结果:

参考资料:
http://zhangjunhd.blog.51cto.com/113473/21014/
http://blog.csdn.net/wiwipetter/article/details/4390579
CodedDFS日志配置的更多相关文章
- django 1.8 日志配置
django 1.8 日志配置 以下为setings配置logging代码片段 BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(_ ...
- nginx日志配置
nginx日志配置 http://www.ttlsa.com/linux/the-nginx-log-configuration/ 日志对于统计排错来说非常有利的.本文总结了nginx日志相关的配置如 ...
- 日志配置logback
在选择项目日志框架时,发现log4j的作者开发了新的日志框架,据说性能提高不少,那就选它了,不过,除了配置上有点不习惯外,最重要的一点 ,打印线程号这个功能依然没有(打印线程名这个东西是在是个鸡肋). ...
- 服务器是windows时tomcat无法打印所有日志配置修改
Tomcat运行仅一天磁盘空间突然就增加了很多,发现是日志文件太大了,修改tomcat的日志配置即可. 查看目录所占空间大小: ? 1 [root@XXX webapps]du -sh 清理方法: ? ...
- [译]Stairway to Integration Services Level 12 - 高级日志配置
介绍 本文中,我们将结合之前学习的时间冒泡,日志记录,以及复制模型.建立一个自定义的SSIS包日志模型. SSIS Task事件回顾 Reviewing SSIS Task Events 在做实 ...
- [译]Stairway to Integration Services Level 11 - 日志配置
介绍 在前一个章节我们讨论了事先行为,分享了如何操作默认的行为和时间冒泡,并且介绍了父子模型. 本文中,我们会配置SSIS日志. 进行简单及高级日志配置,存储,和检索的实验.并且生成自定义日志信息. ...
- Nginx日志配置及日志切割
日志配置 日志对于统计排错来说非常有利的.本文总结了nginx日志相关的配置如access_log.log_format.open_log_file_cache.log_not_found.log_s ...
- SpringBoot之简单日志配置
我的目的指定一个文件夹输出:(不采用指定文件的原因是一个文件的大小时间长了会很大,不利于处理) logging: level: root: INFO org.sselab: controller: I ...
- springboot 入门六-多环境日志配置
在应用项目开发阶段,需要对日志进入很详细的输出便于排查问题原因,上线发布之后又只需要输出核心的日志信息的场景.springboot也提供多环境的日志配置.使用springProfile属性来标识使用那 ...
随机推荐
- UE标签排列方式
UE是一款很顺手的文件编辑软件.打开文本,都会有个标签.根据个人喜好,我喜欢标签都展开,方便快速选取指定文本. 设置如下: 高级>配置>应用程序布局>可停靠窗口>类型 ...
- Fetcher类的工作流程
Fetcher类工作流程: FileInputFormat.addInputPath(job, new Path(segment, CrawlDatum.GENERATE_DIR_NAME)); jo ...
- 基于MINA框架快速开发网络应用程序
1.MINA框架简介 MINA(Multipurpose Infrastructure for Network Applications)是用于开发高性能和高可用性的网络应用程序的基础框架.通过使用M ...
- 【转】VS调试技巧
[转自]http://blog.csdn.net/ghttzsqgm/article/details/5326894 http://blog.csdn.net/cadcisdhht/article/d ...
- TCP协议下Socket的基础编程类型
套接字的基本操作有: 创建(socket).命名(bind).侦听(listen).连接(accept).关闭(shutdown).发送(send).接受(recv). 下面逐个分析: 一.创建(so ...
- 逆向思维Stock Maximize
题目出处 题目描述: 这个题的意思是: 给出一段时间内 某个股票的每天的价格 每天可以进行的操作有:买一股,卖掉所有股,不作为 问在给定的序列里怎样让价值最大 数据规模: 每组数据包含case数 T( ...
- (Relax 水题1.2)POJ 1032 Parliament(将n分解成若干个互不相等的整数的和,并且是这些整数的乘积最大)
题意:给出一个数n,将其拆分为若干个互不相等的数字的和,要求这些数字的乘积最大. 分析:我们可以发现任何一个数字,只要能拆分成两个大于1的数字之和,那么这两个数字的乘积一定大于等于原数.也就是说,对于 ...
- Java做acm所需要的基础知识之排序问题
Java做acm所需要的基础知识. 以前做acm的题都是用C/C++来写代码的,在学习完Java之后突然感觉Java中的方法比C/C++丰富很多,所以就整理一下平时做题需要用到的Java基础知识. 1 ...
- POJ Farm Tour
Farm Tour 题目: 约翰有N块地,家在1号,而N号是个仓库.农场内有M条道路(双向的),道路i连接这ai号地和bi号地,长度为ci. 约翰希望依照从家里出发,经过若干地后达到仓库.然后再返回家 ...
- UITableView显示不全
先上图(不全图片): 正确图片: 原因例如以下: 1.在tableView的父视图的freme问题. 2.tableView本身的frame问题.大小依据自己的实际情况改过来就OK了 希望能够帮助到你 ...