步骤1:创建新应用程序
启动Netbeans并选择创建新的项目。我们要创建一个Maven项目。
选择Java Maven项目后,为您的项目命名。我叫我的MyFirstLoggingApplication。
步骤2:添加主类-使之可执行
您现在应该拥有一个全新的干净应用程序。我们首先需要创建一个简单的Java类,并添加main方法使其可执行。我们将使其保持简单,并添加一些附加内容以向控制台编写一些内容。
创建一个新的Java类
命名它。我的示例是MyLoggingApplication
接下来,我们使用以下代码添加main方法:
/*
* My application header
*/
package com.thegeekbiker.myfirstloggingapplication;
/**
* @author LordFluffyGoggles
*/
public class MyLoggingApp {
//main method
public static void main(String[] args) {
System.out.println(“Application starting processes here.”); // Display the string.
System.out.println(“Application do more stuff here.”);
System.out.println(“Application end processes here.”);
}
}
运行此应用程序时,您将看到三行内容输出。第一个代表启动过程,主要应用程序运行,最后一个代表应用程序完成。
步骤3:添加Log4J日志记录模块并配置
我们将使用Log4J模块。在该站点上:
将日志语句插入代码中是调试它的技术含量较低的方法。这也可能是唯一的方法,因为调试器并不总是可用或不适用。对于多线程应用程序和整个分布式应用程序通常是这种情况。
打开pom.xml文件。此文件是Maven如何下载所需的软件包和模块供我们使用的方式。
添加以下代码:
log4j
log4j
1.2.17
如果您现在启动应用程序,您将看到应用程序抱怨log4j没有可用的配置,因此未启用日志记录。
有多种配置log4j的方法。我们将使用属性文件。
在应用程序的根文件夹中创建一个名为log4j.properties的文件。这不是理想的选择,但是在以后的文章中,我将介绍有关移动资源文件的信息。
现在,我们希望我们的应用程序仍将所有日志记录写入控制台,但是我们将继续它也可以写入日志文件。以防万一您以后需要调查问题。
将以下部分添加到您的log4j.properties文件中:
# Root logger option
log4j.rootLogger=DEBUG, stdout, file
# Redirect log messages to console
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
# Redirect log messages to a log file, support file rolling.
log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=C:logsMyLoggingApp.log
log4j.appender.file.MaxFileSize=5MB
log4j.appender.file.MaxBackupIndex=10
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
步骤4:将日志记录添加到应用程序中
我们需要通过我们的应用程序中的错误来知道哪个类。因此,我们需要将记录器实例与写入日志文件的类相关联。对于我们的测试应用程序,它非常简单,因为我们只有一个类。
在该类中添加以下行:
final static Logger logger = Logger.getLogger(MyLoggingApp.class);
现在我们需要将log4j配置为读取我们创建的属性文件。幸运的是,这仅需要一次,而不是每个班级都需要。
main方法中的以下代码应该足以加载属性文件:
PropertyConfigurator.configure(“log4j.properties”);
如果您现在运行应用程序,但仍然抱怨找不到文件,那么您可能需要将文件复制到pom.xml文件所在的目录。如前所述,在以后的文章中,我将讨论如何确切指定这些文件的类型。
您可以在应用程序的各个级别进行登录。错误,警告,调试,信息等。
我将在此处和此处添加一些信息和调试信息,以便您了解如何以及在何处使用它。
public class MyLoggingApp {
final static Logger logger = Logger.getLogger(MyLoggingApp.class);
//main method
public static void main(String[] args) {
PropertyConfigurator.configure(“log4j.properties”);
if(logger.isInfoEnabled()) logger.info(“Application starting.。.”);
System.out.println(“Application starting processes here.”);
if(logger.isInfoEnabled()) logger.info(“Application started successfully”);
try{
System.out.println(“Application do more stuff here.”);
if(logger.isDebugEnabled()) logger.debug((“Application did something”));
} catch (Exception e){
logger.error(“Something went wrong :”+e);
}
if(logger.isInfoEnabled()) logger.info(“Application finishing up.。.”);
System.out.println(“Application end processes here.”);
if(logger.isInfoEnabled()) logger.info(“Application finished.。.”);
}
}
步骤5:运行应用程序
剩下的就是运行应用程序并检查日志文件。
2015-10-31 22:00:30 INFO MyLoggingApp:18 - Application starting.。.
2015-10-31 22:00:30 INFO MyLoggingApp:20 - Application started successfully
2015-10-31 22:00:30 DEBUG MyLoggingApp:23 - Application did something
2015-10-31 22:00:30 INFO MyLoggingApp:27 - Application finishing up.。.
2015-10-31 22:00:30 INFO MyLoggingApp:29 - Application finished.。.
由于我们的应用程序没有发生任何错误,因此没有显示ERROR行。
-
JAVA
+关注
关注
19文章
2978浏览量
105293
发布评论请先 登录
相关推荐
TMETRIC:简单步骤将工作区连接到时间跟踪应用程序
![TMETRIC:简单步骤<b class='flag-5'>将</b>工作区连接到时间跟踪<b class='flag-5'>应用程序</b>](https://file1.elecfans.com/web3/M00/05/09/wKgZPGd8gnqAc6-4AAAzKnEj59Q270.png)
KiCad 7中添加网络类(一)
![KiCad 7中<b class='flag-5'>添加</b>网络类(一)](https://file1.elecfans.com//web1/M00/F4/DB/wKgaoWcy2M6AMELQABYnfwBW4zM085.png)
日志框架简介-Slf4j+Logback入门实践
![<b class='flag-5'>日志</b>框架简介-Slf4j+Logback入门实践](https://file1.elecfans.com//web2/M00/FF/2D/wKgZomandamADVaeAADrIxKpkeI928.jpg)
华纳云:java web和java有什么区别java web和java有什么区别
![华纳云:<b class='flag-5'>java</b> web和<b class='flag-5'>java</b>有什么区别<b class='flag-5'>java</b> web和<b class='flag-5'>java</b>有什么区别](https://file1.elecfans.com/web2/M00/FD/AC/wKgaomaWBouAMAnAAAAglmvluP4293.png)
如何通过ESP8266上的命令将此网关添加到路由器?
请问如何将cURL库添加到ESP8266_RTOS_SDK项目中?
请问如何将.C的图片文件添加到VScode(PlatfromIO)生成的lvgh项目中?
使用Linux CLI应用程序进行批量传输,无法执行写入/读取操作怎么解决?
STM32F746 QSPI的Flash扩展后,添加到工程下载发现报错,为什么?
怎么把stlink server添加到keil里?
TC399 adc能添加到同一个队列中并得到结果吗?加入队列是否有任何限制?
如何将F-RAM™添加到现有的PSoC™ Creator项目?
基于RA4M2工程将IAR Compiler添加到e2 Studio中相关操作的介绍
![基于RA4M2工程<b class='flag-5'>将</b>IAR Compiler<b class='flag-5'>添加到</b>e2 Studio中相关操作的介绍](https://file1.elecfans.com/web2/M00/C1/4A/wKgZomXdd6OASOrSAAAZE1r7fFQ805.png)
评论