zoukankan      html  css  js  c++  java
  • 关于log4j知识

    今天下午接触到log4j知识,花了几个小时,百度了一圈,总算是懂了一些。

    log4j的作用:log4j是一个日志输出的插件专门用来进行日志管理的,根据我的理解就是用来执行我们用来检测程序bug的System.out.println()语句的,不过更为简洁,格式也更好判断,利用相关的符号,可以精确到某一行的问题点。

    在log4j中,我们刚开始是要利用到log4j的jar包,可以去Apache官网下载,http://www.apache.org/  ,下载后进入到到java中执行build path 加入jar包即可。

    log4j有两种使用的形式,一种是利用我们建立的log4j.properties文件进行相关的配置,另外一种是利用log4j2.xml文件进行配置。配置好之后我们就可以写程序了。

     1 package com.sxt.Log4j;
     2 
     3 import org.apache.logging.log4j.LogManager;
     4 import org.apache.logging.log4j.Logger;
     5 
     6 public class TestLog4j {
     7         private static Logger logger = LogManager.getLogger(TestLog4j.class.getName());
     8     
     9         public void getTestLog4j() {
    10             
    11             logger.info("我是info信息");
    12             logger.error("我是error");
    13             logger.fatal("我是fatal");
    14         }
    15         
    16         public static void main(String[] args) {
    17             new TestLog4j().getTestLog4j();
    18         }
    19 }

    log4j,可以利用properties的配置语句实现大的功能。

     1 #OFF,systemOut,logFile,logDailyFile,logRollingFile,logMail,logDB,ALL,socket,im 
     2 log4j.rootLogger =ALL,systemOut,logFile,logDailyFile,logRollingFile,logMail,logDB,socket,im
     3  
     4 #输出到控制台 
     5 log4j.appender.systemOut = org.apache.log4j.ConsoleAppender 
     6 log4j.appender.systemOut.layout = org.apache.log4j.PatternLayout 
     7 log4j.appender.systemOut.layout.ConversionPattern = [%-5p][%-22d{yyyy-MM-dd HH:mm:ss S}][%l]%n%m%n 
     8 log4j.appender.systemOut.Threshold = DEBUG 
     9 log4j.appender.systemOut.ImmediateFlush = TRUE 
    10 log4j.appender.systemOut.Target = System.out 
    11  
    12 #输出到文件 
    13 log4j.appender.logFile = org.apache.log4j.FileAppender 
    14 log4j.appender.logFile.layout = org.apache.log4j.PatternLayout 
    15 log4j.appender.logFile.layout.ConversionPattern = [%-5p][%-22d{yyyy-MM-dd HH:mm:ss S}][%l]%n%m%n 
    16 log4j.appender.logFile.Threshold = DEBUG 
    17 log4j.appender.logFile.ImmediateFlush = TRUE 
    18 log4j.appender.logFile.Append = TRUE 
    19 log4j.appender.logFile.File = D://opt/ftp/vtm-om/logs/FileAppender.log
    20 log4j.appender.logFile.Encoding = UTF-8 
    21  
    22 #定期回滚日志文件(logDailyFile)
    23 log4j.appender.logDailyFile = org.apache.log4j.DailyRollingFileAppender 
    24 log4j.appender.logDailyFile.layout = org.apache.log4j.PatternLayout 
    25 log4j.appender.logDailyFile.layout.ConversionPattern = [%-5p][%-22d{yyyy-MM-dd HH:mm:ss S}][%l]%n%m%n 
    26 log4j.appender.logDailyFile.Threshold = DEBUG 
    27 log4j.appender.logDailyFile.ImmediateFlush = TRUE 
    28 log4j.appender.logDailyFile.Append = TRUE 
    29 log4j.appender.logDailyFile.File = D://opt/ftp/vtm-om/logs/DailyRollingFileAppender
    30 log4j.appender.logDailyFile.DatePattern = '.'yyyyMMddHHmmss'.log' 
    31 log4j.appender.logDailyFile.Encoding = UTF-8 
    32  
    33 #回滚文件(logRollingFile)
    34 log4j.appender.logRollingFile = org.apache.log4j.RollingFileAppender 
    35 log4j.appender.logRollingFile.layout = org.apache.log4j.PatternLayout 
    36 log4j.appender.logRollingFile.layout.ConversionPattern = [%-5p][%-22d{yyyy-MM-dd HH:mm:ss S}][%l]%n%m%n 
    37 log4j.appender.logRollingFile.Threshold = DEBUG 
    38 log4j.appender.logRollingFile.ImmediateFlush = TRUE 
    39 log4j.appender.logRollingFile.Append = TRUE 
    40 log4j.appender.logRollingFile.File = D://opt/ftp/vtm-om/logs/RollingFileAppender.log
    41 log4j.appender.logRollingFile.MaxFileSize = 1MB 
    42 log4j.appender.logRollingFile.MaxBackupIndex = 10 
    43 log4j.appender.logRollingFile.Encoding = UTF-8 
    44  
    45 #发送日志到指定邮件
    46 log4j.appender.logMail = org.apache.log4j.net.SMTPAppender 
    47 log4j.appender.logMail.layout = org.apache.log4j.HTMLLayout 
    48 log4j.appender.logMail.layout.LocationInfo = TRUE 
    49 log4j.appender.logMail.layout.Title = Struts2 Mail LogFile 
    50 log4j.appender.logMail.Threshold = DEBUG 
    51 log4j.appender.logMail.SMTPDebug = FALSE 
    52 log4j.appender.logMail.SMTPHost = smtp.163.com
    53 log4j.appender.logMail.From = ****@163.com
    54 log4j.appender.logMail.To = ****@qq.com 
    55 #log4j.appender.logMail.Cc = ****@qq.com
    56 log4j.appender.logMail.Bcc = ****@qq.com 
    57 log4j.appender.logMail.SMTPUsername = ****@163.com
    58 log4j.appender.logMail.SMTPPassword = ****
    59 log4j.appender.logMail.Subject = Log4j Log Messages
    60 log4j.appender.logMail.BufferSize = 1024 
    61 log4j.appender.logMail.SMTPAuth = TRUE 
    62  
    63 #将日志登录到MySQL数据库 
    64 log4j.appender.logDB = org.apache.log4j.jdbc.JDBCAppender 
    65 log4j.appender.logDB.layout = org.apache.log4j.PatternLayout 
    66 log4j.appender.logDB.Driver = com.mysql.jdbc.Driver
    67 log4j.appender.logDB.URL = jdbc:mysql://192.168.1.71:3306/test
    68 log4j.appender.logDB.User = root
    69 log4j.appender.logDB.Password = 123456
    70 log4j.appender.logDB.Sql = INSERT log_info(project_name,create_date,level,category,file_name,thread_name,line,all_category,message)values('souvc','%d{yyyy-MM-dd HH:mm:ss}','%p','%c','%F','%t','%L','%l','%m')
    71  
    72 # 应用于socket
    73 log4j.appender.socket=org.apache.log4j.RollingFileAppender
    74 log4j.appender.socket.RemoteHost=localhost
    75 log4j.appender.socket.Port=5001
    76 log4j.appender.socket.LocationInfo=true
    77 # Set up for Log Factor 5
    78 log4j.appender.socket.layout=org.apache.log4j.PatternLayout
    79 log4j.appender.socket.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n
    80 # Log Factor 5 Appender
    81 log4j.appender.LF5_APPENDER=org.apache.log4j.lf5.LF5Appender
    82 log4j.appender.LF5_APPENDER.MaxNumberOfRecords=2000
    83  
    84  
    85 # 自定义Appender
    86 log4j.appender.im = com.souvc.logger.appender.IMAppender
    87 log4j.appender.im.host = localhost
    88 log4j.appender.im.username = username
    89 log4j.appender.im.password = password
    90 log4j.appender.im.recipient = souvc@souvc.com
    91 log4j.appender.im.layout=org.apache.log4j.PatternLayout
    92 log4j.appender.im.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n
  • 相关阅读:
    [收藏转贴]struct探索·extern "C"含义探索 ·C++与C的混合编程·C 语言高效编程的几招
    [收藏转贴]构建RESTful风格的WCF服务
    [转贴] C/C++中动态链接库的创建和调用
    [转贴]WebService的简单实现 C++
    谷歌已经对Android的开源严防死守
    如何成为一名黑客?
    当程序员思路被打断
    编辑语言是这样的
    开发者需要掌握多少门语言?
    程序员的六大优势
  • 原文地址:https://www.cnblogs.com/caoxixi/p/9852443.html
Copyright © 2011-2022 走看看