0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

怎样将日志添加到Java应用程序

454398 来源:wv 2019-09-27 10:22 次阅读

步骤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

    文章

    2903

    浏览量

    102978
收藏 人收藏

    评论

    相关推荐

    如何F-RAM™添加到现有的PSoC™ Creator项目?

    我们在PSoC™ Creator 中有一个 PSoC6 项目,并希望 QSPI F-RAM™存储器添加到TDA5235_868_5_BOARD中。我很难找到如何在F-RAM™ PSoC
    发表于 03-01 12:14

    FCX3是否具有PTS或SCR添加到映像帧的功能?

    问题 1) FCX3是否具有PTS或SCR添加到映像帧的功能,如随附的USB规范中所述? 如果可能,请提供有关如何配置每个 PTS 和 SCR 的详细信息。 问题 2) CAN FCX3 支持1080x1280@120fps传输带宽? 如果这很困难,请让我知道实际使用
    发表于 02-26 08:23

    如何TC1798器件添加到MDK KEIL?

    我正在尝试使用 KEIL MDK(µVision)为英飞凌TC1798编程,但我不确定如何TC1798器件添加到MDK KEIL。 谁能帮我拿到 .pack 或者.zip 对于 TC1798?
    发表于 02-01 08:18

    开发java应用程序的基本步骤是

    ava是一种面向对象的编程语言,广泛用于开发各种类型的应用程序。在开发Java应用程序时,有一些基本步骤需要遵循,以确保应用程序的正确性和可靠性。 1.确定需求:这是开发任何
    的头像 发表于 11-28 16:52 640次阅读

    安装python怎么添加到环境变量

    Python是一种简单易学的脚本语言,广泛应用于开发各种类型的应用程序。为了在Windows操作系统上使用Python的命令行工具,需要将Python添加到系统的环境变量中。本文将向您详细介绍如何在
    的头像 发表于 11-23 16:40 742次阅读

    西门子博途S7-1200:将模块添加到机架的方法

    在网络视图中将设备从硬件目录添加到组态后,即可向设备中添加模块。
    的头像 发表于 09-04 15:22 3787次阅读
    西门子博途S7-1200:将模块<b class='flag-5'>添加到</b>机架的方法

    UART接口添加到DALI命令以控制AS7221模块

    应用程序: 这个示例代码是要将 UART 接口添加到 最初的 DALI 应用项目中, 用于与 AS7221 进行通信, 以便 DALI命令可以控制 AS7221 模块 。 BSP 版本
    发表于 08-22 07:51

    将2D/3D图表和图形添加到WindowsForms应用程序

      将2D/3D图表和图形添加到WindowsForms应用程序中 包括您可能需要的所有功能,并以100%托管代码编写。很好地集成到仪表板和商业智能软件中。由响应迅速的支持团队提供支持。 14种主要
    的头像 发表于 06-15 11:45 416次阅读

    如何将溶解氧添加到WiFi水培套件

    电子发烧友网站提供《如何将溶解氧添加到WiFi水培套件.zip》资料免费下载
    发表于 06-14 10:00 0次下载
    如何将溶解氧<b class='flag-5'>添加到</b>WiFi水培套件

    使Struts2应用程序更安全:不要包含配置浏览器

    Struts2 插件包含扩展、替换或添加到现有 Struts 框架功能的类和配置。除了 JAR 文件之外,还可以通过将其 JAR 文件添加到应用程序的类路径来安装插件,以满足插件本身可能具有的任何
    的头像 发表于 05-25 15:08 233次阅读

    赛昉科技成功将EDK II支持添加到VisionFive 2中

    近日,赛昉科技成功将EDK II支持添加到VisionFive 2(昉·星光 2)中。VisionFive 2是赛昉科技推出的高性能RISC-V单板计算机(SBC),自发布以来,在生态伙伴、社区开发者及赛昉科技的共同努力下,VisionFive2的软件生态已取得长足的发展。
    的头像 发表于 05-19 15:30 749次阅读
    赛昉科技成功将EDK II支持<b class='flag-5'>添加到</b>VisionFive 2中

    如何构建自定义版本的包并将其添加到rootfs映像?

    所以我在寻找如何在构建实际的 rootfs 映像之前添加特定版本的包,准确地说是 libmbim?问题是如果我 libmbim-glib-dev 和 libmbim-utils 添加到 /configs/ubuntu/addi
    发表于 05-18 09:56

    如何RTSP视频源添加到我的“RainGauge”项目网站?

    RTSP 视频源添加到我的“RainGauge”项目网站: 视频由“Wyse Cam 3”捕获,提供给在 Windows PC 上运行的“虚幻媒体服务器”。HTML5文件内嵌WebRTC
    发表于 05-11 07:41

    如何check() API公开添加到SPIFFS?

    SPIFFS.remove() 失败。我在 c api 中看到有一个 spiffs_check.c,但我认为它没有暴露在 SPIFFS obj 模型中。有点让我头疼,但现在我认为我目前唯一的办法是重新格式化 spiff, check() API 公开添加到 SPIFF
    发表于 05-08 07:00

    Yocto S32G添加新层,如何添加到图像?

    meta-mylayer 路径添加到 bblayers.conf。 然后我构建 fsl-image-auto,我测试它,关于层的代码不起作用。 我搜索问题,我需要将图层添加到图像中。我没有找到 hello.ko
    发表于 04-25 09:59