JAVA log4j日誌文件使用

来源:http://www.cnblogs.com/wumianjing/archive/2017/05/05/6814979.html
-Advertisement-
Play Games

//1.導入jar包,log4j-1.2.17.jar//2.src下創建log4j.properties文件//3.配置properties文件/*log4j.rootLogger(預設是對整個工程生效)=DEBUG,stdout(控制台),a, b, …日誌級別(ALL<DEBUG<INFO<W ...


//1.導入jar包,log4j-1.2.17.jar
//2.src下創建log4j.properties文件
//3.配置properties文件
/*
log4j.rootLogger(預設是對整個工程生效)=DEBUG,stdout(控制台),a, b, …
日誌級別(ALL<DEBUG<INFO<WARN<ERROR<FATAL<OFF)
log4j.logger.com.hutu=info, stdout,表示該日誌只對package com.hutu生效

log4j.appender.a=org.apache.log4j.日誌輸出到哪兒
ConsoleAppender(控制台)
FileAppender(文件)
DailyRollingFileAppender(每天產生一個日誌文件)
RollingFileAppender(文件大小到達指定尺寸時產生一個新的文件)
WriteAppender(將日誌信息以流格式發送到任意指定的地方)
JDBCAppender(將日誌信息保存到資料庫中)
log4j.appender.a.File=文件目錄及文件路徑${user.home}/logs/...
log4j.appender.a.MaxFileSize=最大文件大小100m
log4j.appender.a.MaxBackupIndex=備份文件個數10
log4j.appender.ServerDailyRollingFile.DatePattern='.'yyyy-MM-dd 日誌尾碼格式
log4j.appender.a.layout=org.apache.log4j.日誌佈局格式
HTMLLayout(以HTML表格形式佈局)
SimpleLayout(包含日誌信息的級別和信息字元串)
TTCCLayout(包含日誌產生的時間,執行緒,類別等信息)
PatternLayout(可以靈活的指定佈局格式,常用)
log4j.appender.a.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %p [%c] %m%n日誌輸出格式
log4j.appender.ServerDailyRollingFile.Append=true

#Log4j配置文件實現了輸出到控制台、文件、回滾文件、發送日誌郵件、輸出到資料庫日誌表、自定義標簽等功能直接拷貝。
log4j.rootLogger=DEBUG,console,logFile,rollingFile,dailyFile,socket.......
log4j.additivity.org.apache=true


# 控制台(console)
log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.Threshold=DEBUG
log4j.appender.console.ImmediateFlush=true
log4j.appender.console.Target=System.err
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n

# 日誌文件(logFile)
log4j.appender.logFile=org.apache.log4j.FileAppender
log4j.appender.logFile.Threshold=DEBUG
log4j.appender.logFile.ImmediateFlush=true
log4j.appender.logFile.Append=true
log4j.appender.logFile.File=D:/logs/log.log4j
log4j.appender.logFile.layout=org.apache.log4j.PatternLayout
log4j.appender.logFile.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n

# 回滾文件(rollingFile)
log4j.appender.rollingFile=org.apache.log4j.RollingFileAppender
log4j.appender.rollingFile.Threshold=DEBUG
log4j.appender.rollingFile.ImmediateFlush=true
log4j.appender.rollingFile.Append=true
log4j.appender.rollingFile.File=D:/logs/log.log4j
log4j.appender.rollingFile.MaxFileSize=200KB
log4j.appender.rollingFile.MaxBackupIndex=50
log4j.appender.rollingFile.layout=org.apache.log4j.PatternLayout
log4j.appender.rollingFile.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n

# 定期回滾日誌文件(dailyFile)
log4j.appender.dailyFile=org.apache.log4j.DailyRollingFileAppender
log4j.appender.dailyFile.Threshold=DEBUG
log4j.appender.dailyFile.ImmediateFlush=true
log4j.appender.dailyFile.Append=true
log4j.appender.dailyFile.File=D:/logs/log.log4j
log4j.appender.dailyFile.DatePattern='.'yyyy-MM-dd
log4j.appender.dailyFile.layout=org.apache.log4j.PatternLayout
log4j.appender.dailyFile.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n

# 應用於socket
log4j.appender.socket=org.apache.log4j.RollingFileAppender
log4j.appender.socket.RemoteHost=localhost
log4j.appender.socket.Port=5001
log4j.appender.socket.LocationInfo=true
# Set up for Log Factor 5
log4j.appender.socket.layout=org.apache.log4j.PatternLayout
log4j.appender.socket.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n
# Log Factor 5 Appender
log4j.appender.LF5_APPENDER=org.apache.log4j.lf5.LF5Appender
log4j.appender.LF5_APPENDER.MaxNumberOfRecords=2000

# 發送日誌到指定郵件
log4j.appender.mail=org.apache.log4j.net.SMTPAppender
log4j.appender.mail.Threshold=FATAL
log4j.appender.mail.BufferSize=10
log4j.appender.mail.From = [email protected]
log4j.appender.mail.SMTPHost=mail.com
log4j.appender.mail.Subject=Log4J Message
log4j.appender.mail.To= [email protected]
log4j.appender.mail.layout=org.apache.log4j.PatternLayout
log4j.appender.mail.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n

# 應用於資料庫
log4j.appender.database=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.database.URL=jdbc:mysql://localhost:3306/test
log4j.appender.database.driver=com.mysql.jdbc.Driver
log4j.appender.database.user=root
log4j.appender.database.password=
log4j.appender.database.sql=INSERT INTO LOG4J (Message) VALUES('=[%-5p] %d(%r) --> [%t] %l: %m %x %n')
log4j.appender.database.layout=org.apache.log4j.PatternLayout
log4j.appender.database.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n

# 自定義Appender
log4j.appender.im = net.cybercorlin.util.logger.appender.IMAppender
log4j.appender.im.host = mail.cybercorlin.net
log4j.appender.im.username = username
log4j.appender.im.password = password
log4j.appender.im.recipient = [email protected]
log4j.appender.im.layout=org.apache.log4j.PatternLayout
log4j.appender.im.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n

//4.java類中
private static Logger logger = Logger.getLogger(Log.class.getName());
PropertyConfigurator.configure("src//log4j.properties");//src下可以省略


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 對數據的提取和收集也是數據分析中一大重點,所以,學習爬蟲是非常有用的。完成數據採集,對後面的數據分析做下基礎。 今天,要介紹的是來自《Web Scraping With Python》中的一個示例——鏈接爬蟲。對於此類進行了簡單的總結,便於相互學習。 ...
  • 本文用來記憶整了兩天的lamp環境,如果對PHP沒有要求建議全部用yum 一鍵安裝,純屬個人經驗,主要作用是用來參考的。 yum install httpd #yum 安裝Apache。 php編譯安裝 安裝前記得安裝php依賴環境 yum安裝PHP5.6的依賴環境 yum -y install g ...
  • 1. 何為裝飾器? 官方定義:裝飾器是一個很著名的設計模式,經常被用於有切麵需求的場景,較為經典的有插入日誌、性能測試、事務處理等。裝飾器是解決這類問題的絕佳設計,有了裝飾器,我們就可以抽離出大量函數中與函數功能本身無關的雷同代碼並繼續重用。概括的講,裝飾器的作用就是為已經存在的對象添加額外的功能。 ...
  • Connection介面介紹 Connection介面是java集合的root介面,沒有實現類,只有子介面和實現子介面的各種容器。主要用來表示java集合這一大的抽象概念。 Connection介面要求,所有實現此介面的容器,必須提供至少兩種構造方法:無參構造方法、參數為Connection類的構造 ...
  • File類 1.只用於表示文件(目錄)的信息(名稱、大小等),不能用於文件內容的訪問。 2.遍歷目錄 ...
  • 這兩個函數比較簡單,我這裡直接寫例子,但是有一點一定要註意,json數據只支持utf-8格式,GBK格式的數據轉換為json會報錯! json_encode()用法: <?php$data =array(‘name’=>’jianqingwang’,‘sex’=>’man’,‘title’=>’PH ...
  • 文件的編碼 執行結果: 文本文件就是位元組序列,可以是任意編碼的位元組序列。 如果我們在中文機器上直接創建文本文件,那麼該文本文件只認識ansi編碼(中文系統下,ansi編碼代表gbk編碼) ...
  • explode()函數的作用:使用一個字元串分割另一個字元串,打散為數組。 例如: 字元串 根據空格分割後:$pieces = explode(” “, $pizza); $pieces是分割後的數組,我們列印出來看下 piece1piece2piece3piece4piece5piece6 例子2 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...