PiG*_*iGG 1 java rest logging tomcat jersey
我已经跟随HelloWorld示例并成功完成了我的拳头REST.现在,我想在代码中添加日志记录功能.例如,我想拥有任何日志框架(Log4j,JUL)并能够登录代码,并输出到文件.如何实现我的REST代码的日志记录?
@Path("/hello")
public class HelloWorldService {
Logger log = Logger.getLogger("className");
@GET
@Path("/{param}")
public Response getMsg(@PathParam("param") String msg) {
String output = "Jersey say : " + msg;
//for example, here. hopefully to a file
log.info("Log Jersey say : " + msg);
return Response.status(200).entity(output).build();
}
}
Run Code Online (Sandbox Code Playgroud)
我正在使用Jersey 1.19,Tomcat 8
您可以使用开源Apache Log4j库.在您的pom中添加以下依赖项或从此处下载它.
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
Run Code Online (Sandbox Code Playgroud)
log4j.properties
# Root logger option
log4j.rootLogger=INFO, file
# Direct log messages to a log file
log4j.appender.file=org.apache.log4j.RollingFileAppender
#Redirect to Tomcat logs folder
#log4j.appender.file.File=${catalina.home}/logs/logging.log
log4j.appender.file.File=C:\\logigng.log
log4j.appender.file.MaxFileSize=10MB
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
Run Code Online (Sandbox Code Playgroud)
使用此配置,所有日志记录都将重定向到指定的日志文件.
资料来源:http://www.mkyong.com/logging/log4j-log4j-properties-examples/
如何使用Log4j记录消息?
private static final Logger logger = Logger.getLogger(HelloWorldService.class);
Run Code Online (Sandbox Code Playgroud)
日志消息与不同的优先级,例如,debug,info,warn,error和fatal.通常,您只需要使用调试或错误.
//logs a debug message
if(logger.isDebugEnabled()){
logger.debug("This is debug");
}
//logs an error message with parameter
logger.error("This is error : " + parameter);
//logs an exception thrown from somewhere
logger.error("This is error", exception);
Run Code Online (Sandbox Code Playgroud)
要在debug模式下设置记录器,请在属性文件中更改此设置
log4j.rootLogger=DEBUG, file
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5342 次 |
| 最近记录: |