log4j - คู่มือฉบับย่อ

log4j เป็นเฟรมเวิร์กการบันทึก (API) ที่เชื่อถือได้รวดเร็วและยืดหยุ่นซึ่งเขียนด้วย Java ซึ่งเผยแพร่ภายใต้ใบอนุญาตซอฟต์แวร์ Apache

log4j ถูกย้ายไปยังภาษา C, C ++, C #, Perl, Python, Ruby และ Eiffel

log4j สามารถกำหนดค่าได้สูงผ่านไฟล์คอนฟิกูเรชันภายนอกที่รันไทม์ มันดูกระบวนการบันทึกในแง่ของระดับความสำคัญและเสนอกลไกในการนำข้อมูลการบันทึกไปยังปลายทางที่หลากหลายเช่นฐานข้อมูลไฟล์คอนโซล UNIX Syslog เป็นต้น

log4j มีองค์ประกอบหลักสามส่วน:

  • loggers: รับผิดชอบในการบันทึกข้อมูลการบันทึก

  • appenders: รับผิดชอบในการเผยแพร่ข้อมูลการบันทึกไปยังปลายทางต่างๆที่ต้องการ

  • layouts: รับผิดชอบในการจัดรูปแบบข้อมูลการบันทึกในรูปแบบต่างๆ

ประวัติ log4j

  • เริ่มต้นในต้นปี 2539 โดยใช้ API การติดตามสำหรับโครงการ EU SEMPER (Secure Electronic Marketplace for Europe)

  • หลังจากการปรับปรุงนับไม่ถ้วนและหลาย ๆ ชาติ API เริ่มต้นได้รับการพัฒนาจนกลายเป็น log4j ซึ่งเป็นแพ็คเกจการบันทึกที่เป็นที่นิยมสำหรับ Java

  • แพคเกจนี้จัดจำหน่ายภายใต้สัญญาอนุญาตซอฟต์แวร์ Apache ซึ่งเป็นใบอนุญาตโอเพนซอร์สเต็มรูปแบบที่ได้รับการรับรองโดยโครงการริเริ่มโอเพ่นซอร์ส

  • log4j เวอร์ชันล่าสุดรวมถึงซอร์สโค้ดแบบเต็มไฟล์คลาสและเอกสารประกอบสามารถพบได้ที่ http://logging.apache.org/log4j/.

คุณสมบัติ log4j

  • ปลอดภัยต่อด้าย

  • เหมาะสำหรับความเร็ว

  • ขึ้นอยู่กับลำดับชั้นของคนตัดไม้ที่มีชื่อ

  • รองรับภาคผนวกเอาต์พุตหลายตัวต่อคนตัดไม้

  • รองรับความเป็นสากล

  • ไม่ จำกัด เฉพาะสิ่งอำนวยความสะดวกที่กำหนดไว้ล่วงหน้า

  • พฤติกรรมการบันทึกสามารถตั้งค่าได้ที่รันไทม์โดยใช้ไฟล์คอนฟิกูเรชัน

  • ได้รับการออกแบบมาเพื่อจัดการกับข้อยกเว้นของ Java ตั้งแต่เริ่มต้น

  • มันใช้หลายระดับ ได้แก่ ALL, TRACE, DEBUG, INFO, WARN, ERROR และ FATAL

  • รูปแบบของเอาต์พุตบันทึกสามารถเปลี่ยนแปลงได้อย่างง่ายดายโดยการขยายคลาสLayout

  • เป้าหมายของเอาต์พุตบันทึกตลอดจนกลยุทธ์การเขียนสามารถเปลี่ยนแปลงได้โดยการใช้งานอินเทอร์เฟซ Appender

  • มันล้มเหลว - หยุด อย่างไรก็ตามแม้ว่าจะพยายามอย่างเต็มที่เพื่อให้แน่ใจว่ามีการจัดส่ง log4j ไม่รับประกันว่าคำสั่งบันทึกแต่ละรายการจะถูกส่งไปยังปลายทาง

ข้อดีและข้อเสียของการบันทึก

การบันทึกเป็นองค์ประกอบสำคัญของการพัฒนาซอฟต์แวร์ รหัสการบันทึกที่เขียนไว้อย่างดีช่วยให้สามารถแก้ไขจุดบกพร่องได้อย่างรวดเร็วบำรุงรักษาง่ายและจัดเก็บข้อมูลรันไทม์ของแอปพลิเคชันอย่างมีโครงสร้าง

การบันทึกก็มีข้อเสียเช่นกัน อาจทำให้แอปพลิเคชันช้าลง หากละเอียดเกินไปอาจทำให้ตาบอดในการเลื่อนได้ เพื่อบรรเทาความกังวลเหล่านี้ log4j ได้รับการออกแบบให้เชื่อถือได้รวดเร็วและขยายได้

เนื่องจากการบันทึกไม่ค่อยเป็นจุดสนใจหลักของแอปพลิเคชัน log4j API จึงพยายามเข้าใจและใช้งานได้ง่าย

แพ็คเกจ log4j API จัดจำหน่ายภายใต้ Apache Software License ซึ่งเป็นใบอนุญาตโอเพนซอร์สเต็มรูปแบบที่ได้รับการรับรองโดยโครงการริเริ่มโอเพ่นซอร์ส

log4j เวอร์ชันล่าสุดรวมถึงซอร์สโค้ดแบบเต็มไฟล์คลาสและเอกสารประกอบสามารถพบได้ที่ http://logging.apache.org/log4j/.

ในการติดตั้ง log4j ในระบบของคุณให้ดาวน์โหลด apache-log4j-xxxtar.gz จาก URL ที่ระบุและทำตามขั้นตอนด้านล่าง

ขั้นตอนที่ 1

คลายซิปและคลายไฟล์ที่ดาวน์โหลดในไดเร็กทอรี / usr / local / ดังนี้:

$ gunzip apache-log4j-1.2.15.tar.gz
$ tar -xvf apache-log4j-1.2.15.tar
apache-log4j-1.2.15/tests/input/
apache-log4j-1.2.15/tests/input/xml/
apache-log4j-1.2.15/tests/src/
apache-log4j-1.2.15/tests/src/java/
apache-log4j-1.2.15/tests/src/java/org/
.......................................

ในขณะที่ไม่ตรงประเด็นมันจะสร้างลำดับชั้นของไดเร็กทอรีด้วยชื่อ apache-log4j-xxx ดังนี้:

-rw-r--r--  1 root root   3565 2007-08-25 00:09 BUILD-INFO.txt
-rw-r--r--  1 root root   2607 2007-08-25 00:09 build.properties.sample
-rw-r--r--  1 root root  32619 2007-08-25 00:09 build.xml
drwxr-xr-x 14 root root   4096 2010-02-04 14:09 contribs
drwxr-xr-x  5 root root   4096 2010-02-04 14:09 examples
-rw-r--r--  1 root root   2752 2007-08-25 00:09 INSTALL
-rw-r--r--  1 root root   4787 2007-08-25 00:09 KEYS
-rw-r--r--  1 root root  11366 2007-08-25 00:09 LICENSE
-rw-r--r--  1 root root 391834 2007-08-25 00:29 log4j-1.2.15.jar
-rw-r--r--  1 root root    160 2007-08-25 00:09 NOTICE
-rwxr-xr-x  1 root root  10240 2007-08-25 00:27 NTEventLogAppender.dll
-rw-r--r--  1 root root  17780 2007-08-25 00:09 pom.xml
drwxr-xr-x  7 root root   4096 2007-08-25 00:13 site
drwxr-xr-x  8 root root   4096 2010-02-04 14:08 src
drwxr-xr-x  6 root root   4096 2010-02-04 14:09 tests

ขั้นตอนที่ 2

ขั้นตอนนี้เป็นทางเลือกและขึ้นอยู่กับคุณสมบัติที่คุณจะใช้จากกรอบงาน log4j หากคุณมีแพ็คเกจต่อไปนี้ที่ติดตั้งไว้ในเครื่องของคุณอยู่แล้วก็ใช้ได้ไม่เช่นนั้นคุณต้องติดตั้งเพื่อให้ log4j ใช้งานได้

  • JavaMail API:คุณลักษณะการเข้าสู่ระบบอีเมลที่อยู่ใน log4j ต้องใช้ Java จดหมาย API (mail.jar) จะติดตั้งบนเครื่องของคุณจากglassfish.dev

  • JavaBeans Activation Framework: Java Mail API ยังต้องการให้ติดตั้ง JavaBeans Activation Framework (activation.jar) บนเครื่องของคุณจาก http://java.sun.com/products/javabeans/jaf/index.jsp.

  • Java Message Service: คุณสมบัติที่เข้ากันได้กับ JMS ของ log4j จะกำหนดให้ติดตั้งทั้ง JMS และ Java Naming และ Directory Interface JNDI บนเครื่องของคุณจาก http://java.sun.com/products/jms.

  • XML Parser:คุณต้องมีตัวแยกวิเคราะห์ XML ที่เข้ากันได้กับ JAXP เพื่อใช้ log4j ตรวจสอบให้แน่ใจว่าคุณได้ติดตั้ง Xerces.jar บนเครื่องของคุณจากไฟล์http://xerces.apache.org/xerces-j/install.html.

ขั้นตอนที่ 3

ตอนนี้คุณต้องตั้งค่าไฟล์ CLASSPATH และ PATHตัวแปรอย่างเหมาะสม ที่นี่เราจะตั้งค่าสำหรับไฟล์ log4j.xxxjar

$ pwd
/usr/local/apache-log4j-1.2.15
$ export CLASSPATH= \
      $CLASSPATH:/usr/local/apache-log4j-1.2.15/log4j-1.2.15.jar
$ export PATH=$PATH:/usr/local/apache-log4j-1.2.15/

log4j API เป็นไปตามสถาปัตยกรรมแบบเลเยอร์ที่แต่ละเลเยอร์มีอ็อบเจ็กต์ที่แตกต่างกันเพื่อทำงานที่แตกต่างกัน สถาปัตยกรรมแบบเลเยอร์นี้ทำให้การออกแบบมีความยืดหยุ่นและง่ายต่อการขยายในอนาคต

มีอ็อบเจ็กต์สองประเภทพร้อมใช้งานกับ log4j framework

  • Core Objects:สิ่งเหล่านี้เป็นวัตถุบังคับของกรอบ พวกเขาจำเป็นต้องใช้กรอบ

  • Support Objects:สิ่งเหล่านี้เป็นอ็อบเจ็กต์ทางเลือกของเฟรมเวิร์ก พวกเขาสนับสนุนวัตถุหลักเพื่อทำงานเพิ่มเติม แต่สำคัญ

วัตถุหลัก

วัตถุหลักประกอบด้วยวัตถุประเภทต่อไปนี้:

วัตถุ Logger

เลเยอร์ระดับบนสุดคือ Logger ซึ่งจัดเตรียมอ็อบเจ็กต์ Logger อ็อบเจ็กต์ Logger มีหน้าที่ในการบันทึกข้อมูลการบันทึกและถูกเก็บไว้ในลำดับชั้นของเนมสเปซ

เค้าโครงวัตถุ

เลเยอร์โครงร่างจัดเตรียมอ็อบเจ็กต์ที่ใช้ในการจัดรูปแบบข้อมูลการบันทึกในสไตล์ต่างๆ ให้การสนับสนุนวัตถุ appender ก่อนที่จะเผยแพร่ข้อมูลการบันทึก

ออบเจ็กต์เค้าโครงมีบทบาทสำคัญในการเผยแพร่ข้อมูลการบันทึกด้วยวิธีที่มนุษย์อ่านได้และนำกลับมาใช้ใหม่ได้

วัตถุ Appender

นี่คือเลเยอร์ระดับล่างที่ให้วัตถุ Appender วัตถุ Appender มีหน้าที่ในการเผยแพร่ข้อมูลการบันทึกไปยังปลายทางต่างๆที่ต้องการเช่นฐานข้อมูลไฟล์คอนโซล UNIX Syslog เป็นต้น

แผนภาพเสมือนต่อไปนี้แสดงส่วนประกอบของกรอบงาน log4J:

สนับสนุนวัตถุ

มีวัตถุสำคัญอื่น ๆ ในกรอบงาน log4j ที่มีบทบาทสำคัญในกรอบการบันทึก:

วัตถุระดับ

วัตถุระดับกำหนดรายละเอียดและลำดับความสำคัญของข้อมูลการบันทึกใด ๆ มีการบันทึกเจ็ดระดับที่กำหนดไว้ภายใน API: OFF, DEBUG, INFO, ERROR, WARN, FATAL และ ALL

กรองวัตถุ

อ็อบเจ็กต์ตัวกรองใช้เพื่อวิเคราะห์ข้อมูลการบันทึกและทำการตัดสินใจเพิ่มเติมว่าข้อมูลนั้นควรถูกบันทึกหรือไม่

ออบเจ็กต์ Appender สามารถมีอ็อบเจ็กต์ตัวกรองหลายตัวที่เชื่อมโยง หากข้อมูลการบันทึกถูกส่งผ่านไปยังวัตถุ Appender เฉพาะวัตถุตัวกรองทั้งหมดที่เกี่ยวข้องกับ Appender นั้นจะต้องอนุมัติข้อมูลการบันทึกก่อนจึงจะสามารถเผยแพร่ไปยังปลายทางที่แนบมาได้

ObjectRenderer

อ็อบเจ็กต์ ObjectRenderer มีความเชี่ยวชาญในการจัดเตรียมการแสดงสตริงของอ็อบเจ็กต์ต่าง ๆ ที่ส่งผ่านไปยังเฟรมเวิร์กการบันทึก วัตถุนี้ถูกใช้โดยอ็อบเจ็กต์ Layout เพื่อเตรียมข้อมูลการบันทึกขั้นสุดท้าย

LogManager

อ็อบเจ็กต์ LogManager จัดการเฟรมเวิร์กการบันทึก มีหน้าที่อ่านพารามิเตอร์คอนฟิกูเรชันเริ่มต้นจากไฟล์คอนฟิกูเรชันทั้งระบบหรือคลาสคอนฟิกูเรชัน

บทที่แล้วอธิบายส่วนประกอบหลักของ log4j บทนี้อธิบายวิธีกำหนดค่าส่วนประกอบหลักโดยใช้ไฟล์คอนฟิกูเรชัน การกำหนดค่า log4j เกี่ยวข้องกับการกำหนดระดับการกำหนด Appender และการระบุอ็อบเจ็กต์ Layout ในไฟล์คอนฟิกูเรชัน

log4j.propertiesไฟล์เป็นไฟล์การกำหนดค่า log4j ซึ่งช่วยให้คุณสมบัติในคู่ค่าคีย์ โดยดีฟอลต์ LogManager จะค้นหาไฟล์ที่ชื่อlog4j.propertiesในไฟล์CLASSPATH.

  • ระดับของ root logger ถูกกำหนดให้เป็น DEBUG DEBUG แนบ appender ชื่อ X เข้ากับมัน

  • ตั้ง appender ชื่อ X เป็น appender ที่ถูกต้อง

  • ตั้งค่าเค้าโครงสำหรับ appender X

log4j.properties ไวยากรณ์:

ต่อไปนี้เป็นไวยากรณ์ของไฟล์log4j.propertiesสำหรับ appender X:

# Define the root logger with appender X
log4j.rootLogger = DEBUG, X

# Set the appender named X to be a File appender
log4j.appender.X=org.apache.log4j.FileAppender

# Define the layout for X appender
log4j.appender.X.layout=org.apache.log4j.PatternLayout
log4j.appender.X.layout.conversionPattern=%m%n

log4j.properties ตัวอย่าง

โดยใช้ไวยากรณ์ข้างต้นเรากำหนดสิ่งต่อไปนี้ในไฟล์log4j.properties :

  • ระดับของ root logger ถูกกำหนดให้เป็น DEBUG, The DEBUG appender ที่ชื่อ FILE

  • แฟ้ม appender ถูกกำหนดให้เป็นorg.apache.log4j.FileAppender เขียนไปยังไฟล์ชื่อ "log.out" ที่อยู่ในไฟล์log ไดเรกทอรี

  • รูปแบบเค้าโครงที่กำหนดไว้คือ% m% nซึ่งหมายความว่าข้อความบันทึกที่พิมพ์จะตามด้วยอักขระขึ้นบรรทัดใหม่

# Define the root logger with appender file
log4j.rootLogger = DEBUG, FILE

# Define the file appender
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File=${log}/log.out

# Define the layout for file appender
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n

สิ่งสำคัญคือต้องทราบว่า log4j รองรับการแทนที่ตัวแปรสไตล์ UNIX เช่น $ {variableName}

ระดับดีบัก

เราได้ใช้ DEBUG กับทั้งภาคผนวก ตัวเลือกที่เป็นไปได้ทั้งหมดคือ:

  • TRACE
  • DEBUG
  • INFO
  • WARN
  • ERROR
  • FATAL
  • ALL

ระดับเหล่านี้จะได้รับการอธิบายในlog4j ระดับการเข้าสู่ระบบ

ภาคผนวก

Apache log4j มีอ็อบเจ็กต์ Appender ซึ่งมีหน้าที่หลักในการพิมพ์ข้อความบันทึกไปยังปลายทางต่างๆเช่นคอนโซลไฟล์ซ็อกเก็ตบันทึกเหตุการณ์ NT เป็นต้น

แต่ละวัตถุ Appender มีคุณสมบัติที่แตกต่างกันที่เกี่ยวข้องและคุณสมบัติเหล่านี้บ่งชี้ลักษณะการทำงานของวัตถุนั้น

ทรัพย์สิน คำอธิบาย
เค้าโครง Appender ใช้วัตถุเค้าโครงและรูปแบบการแปลงที่เกี่ยวข้องเพื่อจัดรูปแบบข้อมูลการบันทึก
เป้าหมาย เป้าหมายอาจเป็นคอนโซลไฟล์หรือรายการอื่นขึ้นอยู่กับ appender
ระดับ ระดับจำเป็นในการควบคุมการกรองข้อความบันทึก
เกณฑ์ Appender สามารถมีระดับเกณฑ์ที่เชื่อมโยงโดยไม่ขึ้นกับระดับคนตัดไม้ Appender จะละเว้นข้อความบันทึกใด ๆ ที่มีระดับต่ำกว่าระดับขีด จำกัด
กรอง อ็อบเจ็กต์ตัวกรองสามารถวิเคราะห์ข้อมูลการบันทึกนอกเหนือจากการจับคู่ระดับและตัดสินใจว่าควรจัดการคำขอบันทึกโดย Appender เฉพาะหรือละเว้น

เราสามารถเพิ่มวัตถุ Appender ให้กับ Logger โดยรวมการตั้งค่าต่อไปนี้ในไฟล์กำหนดค่าด้วยวิธีการต่อไปนี้:

log4j.logger.[logger-name]=level, appender1,appender..n

คุณสามารถเขียนคอนฟิกูเรชันเดียวกันในรูปแบบ XML ได้ดังนี้:

<logger name="com.apress.logging.log4j" additivity="false">
   <appender-ref ref="appender1"/>
   <appender-ref ref="appender2"/>
</logger>

หากคุณต้องการเพิ่มวัตถุ Appender ภายในโปรแกรมของคุณคุณสามารถใช้วิธีการต่อไปนี้:

public void addAppender(Appender appender);

addAppender () วิธีการเพิ่ม Appender ไปยังวัตถุ Logger ตามตัวอย่างการกำหนดค่าที่แสดงให้เห็นเป็นไปได้ที่จะเพิ่มวัตถุ Appender จำนวนมากให้กับคนตัดไม้ในรายการที่คั่นด้วยเครื่องหมายจุลภาคแต่ละรายการบันทึกการพิมพ์ไปยังปลายทางที่แยก

เราใช้ appender FileAppenderเพียงตัวเดียวในตัวอย่างด้านบน ตัวเลือก appender ที่เป็นไปได้ทั้งหมดมีดังนี้:

  • AppenderSkeleton
  • AsyncAppender
  • ConsoleAppender
  • DailyRollingFileAppender
  • ExternallyRolledFileAppender
  • FileAppender
  • JDBCAppender
  • JMSAppender
  • LF5Appender
  • NTEventLogAppender
  • NullAppender
  • RollingFileAppender
  • SMTPAppender
  • SocketAppender
  • SocketHubAppender
  • SyslogAppender
  • TelnetAppender
  • WriterAppender

เราจะครอบคลุม FileAppender ในการเข้าสู่ระบบไฟล์และ JDBC appender จะได้รับการคุ้มครองในการบันทึกข้อมูลในฐานข้อมูล

เค้าโครง

เราใช้ PatternLayout กับ appender ของเราแล้ว ตัวเลือกที่เป็นไปได้ทั้งหมดคือ:

  • DateLayout
  • HTMLLayout
  • PatternLayout
  • SimpleLayout
  • XMLLayout

การใช้ HTMLLayout และ XMLLayout คุณสามารถสร้างบันทึกใน HTML และในรูปแบบ XML ได้เช่นกัน

การจัดรูปแบบเค้าโครง

คุณจะได้เรียนรู้วิธีการจัดรูปแบบข้อความเข้าสู่ระบบในบท: เข้าสู่ระบบการจัดรูปแบบ

เราได้เห็นวิธีสร้างไฟล์กำหนดค่า บทนี้อธิบายวิธีการสร้างข้อความดีบักและบันทึกในไฟล์ข้อความธรรมดา

ต่อไปนี้เป็นไฟล์คอนฟิกูเรชันง่ายๆที่สร้างขึ้นสำหรับตัวอย่างของเรา ให้เราแก้ไขอีกครั้ง:

  • ระดับของ root logger ถูกกำหนดเป็น DEBUG และแนบ appender ชื่อ FILE เข้ากับมัน

  • appender FILE ถูกกำหนดให้เป็น org.apache.log4j.FileAppender และเขียนไปยังไฟล์ชื่อ "log.out" ที่อยู่ใน log ไดเรกทอรี

  • รูปแบบเค้าโครงที่กำหนดไว้คือ% m% n ซึ่งหมายความว่าข้อความบันทึกที่พิมพ์จะตามด้วยอักขระขึ้นบรรทัดใหม่

เนื้อหาของไฟล์log4j.propertiesมีดังนี้:

# Define the root logger with appender file
log = /usr/home/log4j
log4j.rootLogger = DEBUG, FILE

# Define the file appender
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File=${log}/log.out

# Define the layout for file appender
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n

ใช้ log4j ในโปรแกรม Java

คลาส Java ต่อไปนี้เป็นตัวอย่างง่ายๆที่เริ่มต้นแล้วใช้ไลบรารีการบันทึก Log4J สำหรับแอ็พพลิเคชัน Java

import org.apache.log4j.Logger;

import java.io.*;
import java.sql.SQLException;
import java.util.*;

public class log4jExample{
   /* Get actual class name to be printed on */
   static Logger log = Logger.getLogger(log4jExample.class.getName());
   
   public static void main(String[] args)throws IOException,SQLException{
      log.debug("Hello this is a debug message");
      log.info("Hello this is an info message");
   }
}

รวบรวมและดำเนินการ

นี่คือขั้นตอนในการคอมไพล์และรันโปรแกรมที่กล่าวถึงข้างต้น ตรวจสอบให้แน่ใจว่าคุณได้ตั้งค่าPATH และ CLASSPATH อย่างเหมาะสมก่อนดำเนินการรวบรวมและดำเนินการ

ไลบรารีทั้งหมดควรมีอยู่ใน CLASSPATHและไฟล์log4j.propertiesของคุณควรพร้อมใช้งานใน PATH ทำตามขั้นตอนด้านล่าง:

  • สร้าง log4j.properties ดังที่แสดงด้านบน

  • สร้าง log4jExample.java ตามที่แสดงด้านบนและคอมไพล์

  • ดำเนินการ log4jExample ไบนารีเพื่อรันโปรแกรม

คุณจะได้รับผลลัพธ์ต่อไปนี้ภายในไฟล์ /usr/home/log4j/log.out:

Hello this is a debug message
Hello this is an info message

คลาส Logger มีวิธีการที่หลากหลายในการจัดการกิจกรรมการบันทึก คลาส Logger ไม่อนุญาตให้เราสร้างอินสแตนซ์อินสแตนซ์ Logger ใหม่ แต่มีวิธีการแบบคงที่สองวิธีในการรับอ็อบเจ็กต์ Logger:

  • public static Logger getRootLogger();
  • public static Logger getLogger(String name);

วิธีแรกในสองวิธีนี้จะคืนค่า root logger ของแอปพลิเคชันและไม่มีชื่อ

อินสแตนซ์อ็อบเจ็กต์ Logger ที่มีชื่ออื่น ๆ จะได้รับผ่านวิธีที่สองโดยส่งชื่อของตัวบันทึก ชื่อของคนตัดไม้สามารถเป็นสตริงใดก็ได้ที่คุณสามารถส่งผ่านได้โดยปกติจะเป็นคลาสหรือชื่อแพ็กเกจตามที่เราใช้ในบทสุดท้ายและจะกล่าวถึงด้านล่าง:

static Logger log = Logger.getLogger(log4jExample.class.getName());

วิธีการบันทึก

เมื่อเราได้รับอินสแตนซ์ของคนตัดไม้ที่มีชื่อแล้วเราสามารถใช้วิธีการต่างๆของคนตัดไม้ในการบันทึกข้อความ คลาส Logger มีวิธีการพิมพ์ข้อมูลการบันทึกดังต่อไปนี้

ซีเนียร์ No วิธีการและคำอธิบาย
1 public void debug(Object message)

พิมพ์ข้อความที่มีระดับ Level.DEBUG

2 public void error(Object message)

พิมพ์ข้อความที่มีระดับ Level.ERROR

3 public void fatal(Object message);

พิมพ์ข้อความที่มีระดับระดับ FATAL

4 public void info(Object message);

พิมพ์ข้อความที่มีระดับ Level.INFO

5 public void warn(Object message);

มันพิมพ์ข้อความที่มีระดับระดับคำเตือน

6 public void trace(Object message);

พิมพ์ข้อความที่มีระดับ Level.TRACE

ระดับทั้งหมดถูกกำหนดไว้ในคลาส org.apache.log4j.Level และวิธีการใด ๆ ที่กล่าวถึงข้างต้นสามารถเรียกได้ดังนี้:

import org.apache.log4j.Logger;

public class LogClass {
   private static org.apache.log4j.Logger log = Logger.getLogger(LogClass.class);
   
   public static void main(String[] args) {
      log.trace("Trace Message!");
      log.debug("Debug Message!");
      log.info("Info Message!");
      log.warn("Warn Message!");
      log.error("Error Message!");
      log.fatal("Fatal Message!");
   }
}

เมื่อคุณคอมไพล์และรันโปรแกรม LogClass โปรแกรมจะสร้างผลลัพธ์ต่อไปนี้:

Debug Message!
Info Message!
Warn Message!
Error Message!
Fatal Message!

ข้อความดีบักทั้งหมดมีเหตุผลมากขึ้นเมื่อใช้ร่วมกับระดับ เราจะกล่าวถึงระดับต่างๆในบทถัดไปจากนั้นคุณจะมีความเข้าใจเป็นอย่างดีเกี่ยวกับวิธีใช้วิธีการเหล่านี้ร่วมกับการดีบักในระดับต่างๆ

คลาส org.apache.log4j.Level มีระดับต่อไปนี้ คุณยังสามารถกำหนดระดับที่กำหนดเองของคุณได้โดยการแบ่งคลาสระดับย่อย

ระดับ คำอธิบาย
ทั้งหมด ทุกระดับรวมถึงระดับที่กำหนดเอง
แก้ปัญหา กำหนดเหตุการณ์ที่ให้ข้อมูลอย่างละเอียดซึ่งมีประโยชน์มากที่สุดในการดีบักแอปพลิเคชัน
ข้อมูล กำหนดข้อความแสดงข้อมูลที่เน้นความคืบหน้าของแอปพลิเคชันในระดับหยาบ
เตือน กำหนดสถานการณ์ที่อาจเป็นอันตราย
ข้อผิดพลาด กำหนดเหตุการณ์ข้อผิดพลาดที่อาจทำให้แอปพลิเคชันทำงานต่อไปได้
FATAL กำหนดเหตุการณ์ข้อผิดพลาดที่รุนแรงมากซึ่งอาจทำให้แอปพลิเคชันยกเลิกได้
ปิด อันดับสูงสุดที่เป็นไปได้และมีวัตถุประสงค์เพื่อปิดการบันทึก
ติดตาม กำหนดเหตุการณ์ที่ให้ข้อมูลละเอียดกว่า DEBUG

ระดับทำงานอย่างไร

คำขอบันทึกระดับ p ในคนตัดไม้ที่มีระดับ qเปิดใช้งานถ้า p> = q กฎนี้เป็นหัวใจสำคัญของ log4j จะถือว่ามีการเรียงลำดับระดับ สำหรับระดับมาตรฐานเรามี <DEBUG <INFO <WARN <ERROR <FATAL <OFF ทั้งหมด

ตัวอย่างต่อไปนี้แสดงให้เห็นว่าเราสามารถกรองข้อความ DEBUG และ INFO ทั้งหมดของเราได้อย่างไร โปรแกรมนี้ใช้เมธอด logger setLevel (Level.X) เพื่อกำหนดระดับการบันทึกที่ต้องการ:

ตัวอย่างนี้จะพิมพ์ข้อความทั้งหมดยกเว้น Debug และ Info:

import org.apache.log4j.*;

public class LogClass {
   private static org.apache.log4j.Logger log = Logger.getLogger(LogClass.class);
   
   public static void main(String[] args) {
      log.setLevel(Level.WARN);

      log.trace("Trace Message!");
      log.debug("Debug Message!");
      log.info("Info Message!");
      log.warn("Warn Message!");
      log.error("Error Message!");
      log.fatal("Fatal Message!");
   }
}

เมื่อคุณคอมไพล์และรันโปรแกรม LogClass โปรแกรมจะสร้างผลลัพธ์ต่อไปนี้:

Warn Message!
Error Message!
Fatal Message!

การตั้งค่าระดับโดยใช้ไฟล์กำหนดค่า

log4j จัดเตรียมการตั้งค่าระดับไฟล์คอนฟิกูเรชันซึ่งตั้งค่าให้คุณเป็นอิสระจากการเปลี่ยนซอร์สโค้ดเมื่อคุณต้องการเปลี่ยนระดับการดีบัก

ต่อไปนี้เป็นไฟล์คอนฟิกูเรชันตัวอย่างซึ่งจะทำงานเหมือนกับที่เราทำโดยใช้เมธอด log.setLevel (Level.WARN)ในตัวอย่างด้านบน

# Define the root logger with appender file
log = /usr/home/log4j
log4j.rootLogger = WARN, FILE

# Define the file appender
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File=${log}/log.out

# Define the layout for file appender
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n

ให้เราใช้โปรแกรมต่อไปนี้ของเรา:

import org.apache.log4j.*;

public class LogClass {
   private static org.apache.log4j.Logger log = Logger.getLogger(LogClass.class);
   public static void main(String[] args) {
      log.trace("Trace Message!");
      log.debug("Debug Message!");
      log.info("Info Message!");
      log.warn("Warn Message!");
      log.error("Error Message!");
      log.fatal("Fatal Message!");
   }
}

ตอนนี้รวบรวมและเรียกใช้โปรแกรมข้างต้นและคุณจะได้รับผลลัพธ์ต่อไปนี้ในไฟล์ /usr/home/log4j/log.out:

Warn Message!
Error Message!
Fatal Message!

Apache log4j มีออบเจ็กต์ Layout ต่างๆซึ่งแต่ละอันสามารถจัดรูปแบบข้อมูลการบันทึกตามเค้าโครงต่างๆ นอกจากนี้ยังสามารถสร้างออบเจ็กต์ Layout ที่จัดรูปแบบข้อมูลการบันทึกด้วยวิธีเฉพาะแอปพลิเคชัน

อ็อบเจ็กต์ Layout ทั้งหมดได้รับอ็อบเจ็กต์ LoggingEvent จากอ็อบเจ็กต์ Appender จากนั้นวัตถุ Layout จะดึงอาร์กิวเมนต์ข้อความจาก LoggingEvent และใช้ ObjectRenderer ที่เหมาะสมเพื่อรับการแสดงสตริงของข้อความ

ประเภทเค้าโครง

คลาสระดับบนสุดในลำดับชั้นคือคลาสนามธรรม org.apache.log4j.Layout นี่คือคลาสพื้นฐานสำหรับคลาส Layout อื่น ๆ ทั้งหมดใน log4j API

คลาส Layout ถูกกำหนดให้เป็นนามธรรมภายในแอปพลิเคชันเราไม่เคยใช้คลาสนี้โดยตรง เราทำงานกับคลาสย่อยของมันแทนซึ่งมีดังนี้:

  • DateLayout

  • HTMLLayout

  • PatternLayout.

  • SimpleLayout

  • XMLLayout

วิธีการจัดวาง

คลาสนี้จัดเตรียมการใช้โครงกระดูกของการดำเนินการทั่วไปในวัตถุโครงร่างอื่น ๆ ทั้งหมดและประกาศวิธีนามธรรมสองวิธี

ซีเนียร์ วิธีการและคำอธิบาย
1 public abstract boolean ignoresThrowable()

ระบุว่าข้อมูลการบันทึกจัดการกับอ็อบเจ็กต์ java.lang.Throwable ที่ส่งผ่านไปยังเป็นส่วนหนึ่งของเหตุการณ์การบันทึกหรือไม่ หากวัตถุ Layout จัดการกับวัตถุ Throwable วัตถุ Layout จะไม่เพิกเฉยและส่งกลับเท็จ

2 public abstract String format(LoggingEvent event)

คลาสย่อยของโครงร่างส่วนบุคคลใช้วิธีนี้สำหรับการจัดรูปแบบเฉพาะโครงร่าง

นอกเหนือจากวิธีนามธรรมเหล่านี้คลาส Layout ยังมีการนำไปใช้อย่างเป็นรูปธรรมสำหรับวิธีการที่ระบุไว้ด้านล่าง:

ซีเนียร์ วิธีการและคำอธิบาย
1 public String getContentType()

ส่งคืนชนิดเนื้อหาที่ใช้โดยวัตถุโครงร่าง คลาสฐานส่งคืนข้อความ / ธรรมดาเป็นชนิดเนื้อหาเริ่มต้น

2 public String getFooter()

ระบุข้อมูลส่วนท้ายของข้อความบันทึก

3 public String getHeader()

ระบุข้อมูลส่วนหัวของข้อความบันทึก

แต่ละคลาสย่อยสามารถส่งคืนข้อมูลเฉพาะคลาสได้โดยการลบล้างการนำวิธีการเหล่านี้ไปใช้อย่างเป็นรูปธรรม

ในการเขียนข้อมูลการเข้าสู่ระบบของคุณลงในไฟล์ที่คุณจะต้องใช้org.apache.log4j.FileAppender

การกำหนดค่า FileAppender

FileAppender มีพารามิเตอร์ที่กำหนดค่าได้ดังต่อไปนี้:

ทรัพย์สิน คำอธิบาย
ทันที แฟล็กนี้ถูกตั้งค่าเป็นค่าเริ่มต้นเป็นจริงซึ่งหมายถึงสตรีมเอาต์พุตไปยังไฟล์ที่ถูกล้างด้วยการดำเนินการผนวกแต่ละครั้ง
การเข้ารหัส เป็นไปได้ที่จะใช้การเข้ารหัสอักขระใด ๆ ตามค่าเริ่มต้นเป็นรูปแบบการเข้ารหัสเฉพาะแพลตฟอร์ม
เกณฑ์ ระดับขีด จำกัด สำหรับ appender นี้
ชื่อไฟล์ ชื่อของล็อกไฟล์
fileAppend โดยค่าเริ่มต้นจะตั้งค่าเป็น true ซึ่งหมายถึงข้อมูลการบันทึกที่ต่อท้ายไฟล์เดียวกัน
บัฟเฟอร์ แฟล็กนี้ระบุว่าเราต้องการเปิดใช้งานการเขียนบัฟเฟอร์หรือไม่ โดยค่าเริ่มต้นจะตั้งค่าเป็นเท็จ
bufferSize หากเปิดใช้งาน I / O ที่บัฟเฟอร์ไว้จะระบุขนาดบัฟเฟอร์ โดยค่าเริ่มต้นจะตั้งไว้ที่ 8kb

ต่อไปนี้เป็นไฟล์คอนฟิกูเรชันตัวอย่างlog4j.propertiesสำหรับ FileAppender

# Define the root logger with appender file
log4j.rootLogger = DEBUG, FILE

# Define the file appender
log4j.appender.FILE=org.apache.log4j.FileAppender

# Set the name of the file
log4j.appender.FILE.File=${log}/log.out

# Set the immediate flush to true (default)
log4j.appender.FILE.ImmediateFlush=true

# Set the threshold to debug mode
log4j.appender.FILE.Threshold=debug

# Set the append to false, overwrite
log4j.appender.FILE.Append=false

# Define the layout for file appender
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n

หากคุณต้องการมีไฟล์คอนฟิกูเรชัน XML เทียบเท่ากับไฟล์log4j.propertiesด้านบนนี่คือเนื้อหา:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration>

<appender name="FILE" class="org.apache.log4j.FileAppender">
   <param name="file" value="${log}/log.out"/>
   <param name="immediateFlush" value="true"/>
   <param name="threshold" value="debug"/>
   <param name="append" value="false"/>
   <layout class="org.apache.log4j.PatternLayout">
      <param name="conversionPattern" value="%m%n"/>
   </layout>
</appender>

<logger name="log4j.rootLogger" additivity="false">
   <level value="DEBUG"/>
   <appender-ref ref="FILE"/>
</logger>

</log4j:configuration>

คุณสามารถลองใช้log4j - โปรแกรมตัวอย่างด้วยการกำหนดค่าข้างต้น

เข้าสู่ระบบหลายไฟล์

คุณอาจต้องการเขียนข้อความบันทึกของคุณลงในไฟล์หลาย ๆ ไฟล์ด้วยเหตุผลบางประการเช่นหากขนาดไฟล์ถึงเกณฑ์ที่กำหนด

ในการเขียนข้อมูลการบันทึกของคุณลงในไฟล์หลายไฟล์คุณจะต้องใช้คลาสorg.apache.log4j.RollingFileAppenderซึ่งขยายคลาสFileAppenderและสืบทอดคุณสมบัติทั้งหมด

เรามีพารามิเตอร์ที่กำหนดค่าได้ดังต่อไปนี้นอกเหนือจากพารามิเตอร์ที่กล่าวถึงข้างต้นสำหรับ FileAppender:

ทรัพย์สิน คำอธิบาย
maxFileSize นี่คือขนาดสำคัญของไฟล์ด้านบนที่จะรีดไฟล์ ค่าดีฟอลต์คือ 10 MB
maxBackupIndex คุณสมบัตินี้แสดงถึงจำนวนไฟล์สำรองที่จะสร้าง ค่าดีฟอลต์คือ 1

ต่อไปนี้เป็นไฟล์คอนฟิกูเรชันตัวอย่างlog4j.propertiesสำหรับ RollingFileAppender

# Define the root logger with appender file
log4j.rootLogger = DEBUG, FILE

# Define the file appender
log4j.appender.FILE=org.apache.log4j.RollingFileAppender

# Set the name of the file
log4j.appender.FILE.File=${log}/log.out

# Set the immediate flush to true (default)
log4j.appender.FILE.ImmediateFlush=true

# Set the threshold to debug mode
log4j.appender.FILE.Threshold=debug

# Set the append to false, should not overwrite
log4j.appender.FILE.Append=true

# Set the maximum file size before rollover
log4j.appender.FILE.MaxFileSize=5MB

# Set the the backup index
log4j.appender.FILE.MaxBackupIndex=2

# Define the layout for file appender
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n

หากคุณต้องการที่จะมีการตั้งค่าไฟล์ XML คุณสามารถสร้างเช่นเดียวกับที่กล่าวไว้ในส่วนเริ่มต้นและเพิ่มพารามิเตอร์เท่านั้นเพิ่มเติมที่เกี่ยวข้องกับRollingFileAppender

ตัวอย่างการกำหนดค่านี้แสดงให้เห็นว่าขนาดสูงสุดที่อนุญาตของไฟล์บันทึกแต่ละไฟล์คือ 5 MB เมื่อเกินขนาดสูงสุดไฟล์บันทึกใหม่จะถูกสร้างขึ้น เนื่องจากmaxBackupIndexถูกกำหนดเป็น 2 เมื่อไฟล์บันทึกที่สองมีขนาดสูงสุดไฟล์บันทึกแรกจะถูกลบและหลังจากนั้นข้อมูลการบันทึกทั้งหมดจะถูกย้อนกลับไปที่ไฟล์บันทึกแรก

คุณสามารถลองใช้log4j - โปรแกรมตัวอย่างด้วยการกำหนดค่าข้างต้น

การสร้างไฟล์บันทึกรายวัน

อาจมีข้อกำหนดในการสร้างไฟล์บันทึกของคุณเป็นประจำทุกวันเพื่อให้บันทึกข้อมูลการบันทึกของคุณได้อย่างชัดเจน

ในการเขียนข้อมูลการบันทึกของคุณลงในไฟล์ในแต่ละวันคุณจะต้องใช้คลาสorg.apache.log4j.DailyRollingFileAppenderซึ่งขยายคลาสFileAppenderและสืบทอดคุณสมบัติทั้งหมด

มีพารามิเตอร์ที่กำหนดค่าได้ที่สำคัญเพียงพารามิเตอร์เดียวนอกเหนือจากพารามิเตอร์ที่กล่าวถึงข้างต้นสำหรับ FileAppender:

ทรัพย์สิน คำอธิบาย
DatePattern สิ่งนี้ระบุว่าเมื่อใดควรวางซ้อนไฟล์และหลักการตั้งชื่อที่จะปฏิบัติตาม โดยค่าเริ่มต้นการวางจำหน่ายจะดำเนินการในเวลาเที่ยงคืนของแต่ละวัน

DatePattern ควบคุมกำหนดการโรลโอเวอร์โดยใช้หนึ่งในรูปแบบต่อไปนี้:

DatePattern คำอธิบาย
'.' yyyy-MM เลื่อนไปทุกสิ้นเดือนและต้นเดือนถัดไป
'.' yyyy-MM-dd เกลือกกลิ้งตอนเที่ยงคืนของแต่ละวัน นี่คือค่าเริ่มต้น
'.' yyyy-MM-dd-a เกลือกกลิ้งเที่ยงวันและเที่ยงคืนของแต่ละวัน
'.' yyyy-MM-dd-HH เกลือกกลิ้งที่ด้านบนของทุก ๆ ชั่วโมง
'.' yyyy-MM-dd-HH-mm เกลือกกลิ้งทุกนาที
'.' yyyy-ww เกลือกกลิ้งในวันแรกของแต่ละสัปดาห์ขึ้นอยู่กับสถานที่

ต่อไปนี้เป็นไฟล์คอนฟิกูเรชันlog4j.propertiesตัวอย่างเพื่อสร้างล็อกไฟล์ในช่วงเที่ยงและเที่ยงคืนของแต่ละวัน

# Define the root logger with appender file
log4j.rootLogger = DEBUG, FILE

# Define the file appender
log4j.appender.FILE=org.apache.log4j.DailyRollingFileAppender

# Set the name of the file
log4j.appender.FILE.File=${log}/log.out

# Set the immediate flush to true (default)
log4j.appender.FILE.ImmediateFlush=true

# Set the threshold to debug mode
log4j.appender.FILE.Threshold=debug

# Set the append to false, should not overwrite
log4j.appender.FILE.Append=true

# Set the DatePattern
log4j.appender.FILE.DatePattern='.' yyyy-MM-dd-a

# Define the layout for file appender
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n

หากคุณต้องการที่จะมีการตั้งค่าไฟล์ XML คุณสามารถสร้างเช่นเดียวกับที่กล่าวไว้ในส่วนเริ่มต้นและเพิ่มพารามิเตอร์เท่านั้นเพิ่มเติมที่เกี่ยวข้องกับDailyRollingFileAppender

คุณสามารถลองใช้log4j - โปรแกรมตัวอย่างด้วยการกำหนดค่าข้างต้น

log4j API จัดเตรียมอ็อบเจ็กต์org.apache.log4j.jdbc.JDBCAppenderซึ่งสามารถใส่ข้อมูลการบันทึกในฐานข้อมูลที่ระบุ

การกำหนดค่า JDBCAppender

ทรัพย์สิน คำอธิบาย
bufferSize ตั้งค่าขนาดบัฟเฟอร์ ขนาดเริ่มต้นคือ 1
คนขับ ตั้งค่าคลาสไดรเวอร์เป็นสตริงที่ระบุ หากไม่ได้ระบุคลาสไดรเวอร์จะมีค่าเริ่มต้นเป็น sun.jdbc.odbc.JdbcOdbcDriver
เค้าโครง ตั้งค่าเค้าโครงที่จะใช้ เค้าโครงเริ่มต้นคือ org.apache.log4j.PatternLayout
รหัสผ่าน ตั้งรหัสผ่านฐานข้อมูล
sql ระบุคำสั่ง SQL ที่จะดำเนินการทุกครั้งที่เกิดเหตุการณ์การบันทึก อาจเป็น INSERT, UPDATE หรือ DELETE
URL ตั้งค่า JDBC URL
ผู้ใช้ ตั้งค่าชื่อผู้ใช้ฐานข้อมูล

การกำหนดค่าตารางบันทึก

ก่อนที่คุณจะเริ่มใช้การบันทึกโดยใช้ JDBC คุณควรสร้างตารางเพื่อรักษาข้อมูลบันทึกทั้งหมด ต่อไปนี้เป็นคำสั่ง SQL สำหรับสร้างตาราง LOGS:

CREATE TABLE LOGS
   (USER_ID VARCHAR(20) NOT NULL,
    DATED   DATE NOT NULL,
    LOGGER  VARCHAR(50) NOT NULL,
    LEVEL   VARCHAR(10) NOT NULL,
    MESSAGE VARCHAR(1000) NOT NULL
   );

ไฟล์การกำหนดค่าตัวอย่าง

ต่อไปนี้เป็นไฟล์คอนฟิกูเรชันตัวอย่างlog4j.propertiesสำหรับ JDBCAppender ซึ่งจะใช้เพื่อบันทึกข้อความไปยังตาราง LOGS

# Define the root logger with appender file
log4j.rootLogger = DEBUG, DB

# Define the DB appender
log4j.appender.DB=org.apache.log4j.jdbc.JDBCAppender

# Set JDBC URL
log4j.appender.DB.URL=jdbc:mysql://localhost/DBNAME

# Set Database Driver
log4j.appender.DB.driver=com.mysql.jdbc.Driver

# Set database user name and password
log4j.appender.DB.user=user_name
log4j.appender.DB.password=password

# Set the SQL statement to be executed.
log4j.appender.DB.sql=INSERT INTO LOGS VALUES('%x','%d','%C','%p','%m')

# Define the layout for file appender
log4j.appender.DB.layout=org.apache.log4j.PatternLayout

สำหรับฐานข้อมูล MySQL คุณจะต้องใช้ DBNAME ID ผู้ใช้และรหัสผ่านจริงซึ่งคุณได้สร้างตาราง LOGS คำสั่ง SQL คือการดำเนินการคำสั่ง INSERT ด้วยชื่อตาราง LOGS และค่าที่จะป้อนลงในตาราง

JDBCAppender ไม่จำเป็นต้องกำหนดโครงร่างอย่างชัดเจน แทนคำสั่ง SQL ที่ส่งผ่านไปยังใช้ PatternLayout

หากคุณต้องการมีไฟล์คอนฟิกูเรชัน XML เทียบเท่ากับไฟล์log4j.propertiesด้านบนนี่คือเนื้อหา:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration>

<appender name="DB" class="org.apache.log4j.jdbc.JDBCAppender">
   <param name="url" value="jdbc:mysql://localhost/DBNAME"/>
   <param name="driver" value="com.mysql.jdbc.Driver"/>
   <param name="user" value="user_id"/>
   <param name="password" value="password"/>
   <param name="sql" value="INSERT INTO LOGS VALUES('%x','%d','%C','%p','%m')"/>
   <layout class="org.apache.log4j.PatternLayout">
   </layout>
</appender>

<logger name="log4j.rootLogger" additivity="false">
   <level value="DEBUG"/>
   <appender-ref ref="DB"/>
</logger>

</log4j:configuration>

โปรแกรมตัวอย่าง

คลาส Java ต่อไปนี้เป็นตัวอย่างง่ายๆที่เริ่มต้นแล้วใช้ไลบรารีการบันทึก Log4J สำหรับแอ็พพลิเคชัน Java

import org.apache.log4j.Logger;
import java.sql.*;
import java.io.*;
import java.util.*;

public class log4jExample{
   /* Get actual class name to be printed on */
   static Logger log = Logger.getLogger(log4jExample.class.getName());
   
   public static void main(String[] args)throws IOException,SQLException{
      log.debug("Debug");
      log.info("Info");
   }
}

รวบรวมและดำเนินการ

นี่คือขั้นตอนในการคอมไพล์และรันโปรแกรมที่กล่าวถึงข้างต้น ตรวจสอบให้แน่ใจว่าคุณได้ตั้งค่าPATH และ CLASSPATH อย่างเหมาะสมก่อนดำเนินการรวบรวมและดำเนินการ

ไลบรารีทั้งหมดควรมีอยู่ใน CLASSPATHและไฟล์log4j.propertiesของคุณควรพร้อมใช้งานใน PATH ทำตามขั้นตอนที่กำหนด:

  • สร้าง log4j.properties ดังที่แสดงด้านบน
  • สร้าง log4jExample.java ตามที่แสดงด้านบนและคอมไพล์
  • ดำเนินการ log4jExample ไบนารีเพื่อรันโปรแกรม

ตรวจสอบตาราง LOGS ของคุณในฐานข้อมูล DBNAME แล้วคุณจะพบรายการต่อไปนี้:

mysql >  select * from LOGS;
+---------+------------+--------------+-------+---------+
| USER_ID | DATED      | LOGGER       | LEVEL | MESSAGE |
+---------+------------+--------------+-------+---------+
|         | 2010-05-13 | log4jExample | DEBUG | Debug   |
|         | 2010-05-13 | log4jExample | INFO  | Info    |
+---------+------------+--------------+-------+---------+
2 rows in set (0.00 sec)

Note:ที่นี่ x ใช้เพื่อเอาต์พุต Nested diagnostic Context (NDC) ที่เชื่อมโยงกับเธรดที่สร้างเหตุการณ์การบันทึก เราใช้ NDC เพื่อแยกความแตกต่างของไคลเอนต์ในส่วนประกอบฝั่งเซิร์ฟเวอร์ที่จัดการกับไคลเอนต์หลายตัว ตรวจสอบคู่มือ Log4J สำหรับข้อมูลเพิ่มเติมเกี่ยวกับเรื่องนี้