Rumah > Java > javaTutorial > Cara menguruskan log dalam pembangunan Java dengan berkesan

Cara menguruskan log dalam pembangunan Java dengan berkesan

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Lepaskan: 2023-10-08 17:13:41
asal
897 orang telah melayarinya

Cara menguruskan log dalam pembangunan Java dengan berkesan

Cara mengurus log secara berkesan dalam pembangunan Java

Abstrak: Log adalah bahagian yang sangat penting dalam pembangunan perisian, bukan sahaja ia boleh membantu kita cepat Cari masalah dan sediakan pemantauan dan analisis operasi sistem. Artikel ini akan memperkenalkan cara melaksanakan pengurusan log secara berkesan dalam pembangunan Java dan menyediakan beberapa contoh kod khusus.

1. Memperkenalkan rangka kerja log
Dalam pembangunan Java, kami biasanya memilih untuk menggunakan beberapa rangka kerja log matang, seperti Log4j, Logback, dll. Rangka kerja ini menyediakan fungsi yang kaya dan konfigurasi yang fleksibel, menjadikannya mudah untuk melaksanakan operasi seperti output log, penapisan dan penyimpanan.

  1. Perkenalkan kebergantungan Log4j ke dalam projek Maven:

    <dependency>
     <groupId>log4j</groupId>
     <artifactId>log4j</artifactId>
     <version>1.2.17</version>
    </dependency>
    Salin selepas log masuk
  2. Dalam kod Java yang diimport melalui kod Java semula perpustakaan:

    import org.apache.log4j.Logger;
    Salin selepas log masuk

2. Konfigurasikan keluaran log
Rangka kerja log biasanya menyediakan fail konfigurasi untuk menentukan kaedah dan tahap output log, dsb. Berikut ialah contoh fail konfigurasi Log4j mudah log4j.properties:

log4j.rootLogger = DEBUG, console, file

log4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.Target = System.out
log4j.appender.console.layout = org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %m%n

log4j.appender.file = org.apache.log4j.RollingFileAppender
log4j.appender.file.File = ./logs/mylog.log
log4j.appender.file.MaxFileSize = 10MB
log4j.appender.file.MaxBackupIndex = 5
log4j.appender.file.layout = org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %m%n
Salin selepas log masuk

Dalam fail konfigurasi di atas, kami mentakrifkan dua kaedah output log: konsol dan fail. Tahap log keluaran konsol ialah DEBUG, manakala tahap log keluaran fail ialah INFO. Pada masa yang sama, kami juga boleh menentukan format log melalui fail konfigurasi, yang boleh memenuhi keperluan kami dengan lebih baik.

3 Menggunakan log masuk kod
Dalam kod Java, kami memperoleh objek Logger untuk mengeluarkan log. Objek Logger boleh diperolehi melalui kaedah Logger.getLogger() Parameter kaedah ialah nama kelas atau rentetan yang layak sepenuhnya, yang mewakili lokasi keluaran log.

Berikut ialah contoh penggunaan Log4j untuk output log:

import org.apache.log4j.Logger;

public class Demo {
    private static final Logger logger = Logger.getLogger(Demo.class);
    
    public static void main(String[] args) {
        logger.debug("This is a debug message");
        logger.info("This is an info message");
        logger.warn("This is a warn message");
        logger.error("This is an error message");
    }
}
Salin selepas log masuk

Dengan kod di atas, kita boleh melihat output log yang sepadan dalam konsol dan fail log yang ditentukan. Perlu diingatkan bahawa objek Logger menyediakan pelbagai peringkat kaedah output yang berbeza, dan kita boleh memilih tahap yang sesuai mengikut keperluan sebenar.

4. Penapisan dan penyimpanan log
Selain mengeluarkan log, rangka kerja log juga menyediakan beberapa fungsi lain, seperti penapisan dan penyimpanan.

  1. Penggunaan penapis
    Dalam rangka kerja log, kami boleh mengkonfigurasi penapis kepada log keluaran sahaja yang memenuhi syarat tertentu. Berikut ialah contoh penapis Log4j:

    log4j.appender.file.filter = org.apache.log4j.varia.LevelRangeFilter
    log4j.appender.file.filter.LevelMin = INFO
    log4j.appender.file.filter.LevelMax = WARN
    Salin selepas log masuk

    Konfigurasi di atas menunjukkan bahawa hanya log peringkat INFO dan WARN akan dikeluarkan kepada fail dan peringkat log lain akan ditapis keluar.

  2. Storan dan pengarkiban log
    Rangka kerja log biasanya menyediakan fungsi penyimpanan dan pengarkiban fail log Contohnya, Log4j menyediakan RollingFileAppender untuk merealisasikan rolling fail log. Kita boleh menentukan saiz fail log dan bilangan sandaran melalui fail konfigurasi Apabila fail log mencapai saiz tertentu, fail log baharu akan dibuat secara automatik dan fail log lama akan diarkibkan.

Berikut ialah contoh konfigurasi RollingFileAppender:

log4j.appender.file = org.apache.log4j.RollingFileAppender
log4j.appender.file.File = ./logs/mylog.log
log4j.appender.file.MaxFileSize = 10MB
log4j.appender.file.MaxBackupIndex = 5
log4j.appender.file.layout = org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %m%n
Salin selepas log masuk

Konfigurasi di atas bermakna apabila saiz fail log mencapai 10MB, fail log baharu akan dibuat dan maksimum akan disimpan 5 fail sandaran.

Ringkasnya, dengan memperkenalkan rangka kerja log yang sesuai, mengkonfigurasi kaedah dan tahap output log, menggunakan penapis, penyimpanan dan pengarkiban serta fungsi lain, kami boleh mencapai pengurusan log yang berkesan dalam pembangunan Java. Ini boleh membantu kami mencari masalah dengan cepat dan menyediakan pemantauan dan analisis operasi sistem. Saya berharap kandungan artikel ini dapat membantu pembangun Java dalam pengurusan log.

Rujukan:

  1. Apache Log4j 1.2 - URL Projek Perkhidmatan Pengelogan Apache: https://logging.apache.org/log4j/1.2/#🎜 🎜. #
  2. log4j pengenalan dan ujian fail konfigurasi: https://blog.csdn.net/shen_jz888/article/details/9027607
  3. .

Atas ialah kandungan terperinci Cara menguruskan log dalam pembangunan Java dengan berkesan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Isu terkini
日志管理 - node.js的日志
daripada 1970-01-01 08:00:00
0
0
0
java - tomcat集群后日志怎么进行统一管理?
daripada 1970-01-01 08:00:00
0
0
0
Nginx写日志文件是什么原理
daripada 1970-01-01 08:00:00
0
0
0
php - 后台日志怎么存储
daripada 1970-01-01 08:00:00
0
0
0
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan