log4j日志输出路径会变?

whos2002110 2014-02-27 05:19:28
String userDir = System.getProperty("user.dir");
System.setProperty("pm.logout", userDir);
log = Logger.getLogger(NetUtilTest.class);


# Output pattern : date [thread] priority category - message
log4j.rootLogger=INFO, RollingFile

#Console
#log4j.appender.Console=org.apache.log4j.ConsoleAppender
#log4j.appender.Console.layout=org.apache.log4j.PatternLayout
#log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n

#RollingFile
log4j.appender.RollingFile=org.apache.log4j.DailyRollingFileAppender
log4j.appender.RollingFile.File=${pm.logout}/csv.log
log4j.appender.RollingFile.layout=org.apache.log4j.PatternLayout
log4j.appender.RollingFile.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n



这里我使用${pm.logout}引用System.setProperty("pm.logout", userDir);设置的路径


System.setProperty("pm.logout", userDir);
log = Logger.getLogger(NetUtilTest.class);
long t0 = System.currentTimeMillis();
JsonToCsvNetUtil.create(rcurl, rdurl, csvpath);
long t1 = System.currentTimeMillis();

log.info("操作成功,耗时: " + (t1 - t0) / 1000 + "秒");


其中JsonToCsvNetUtil.create(rcurl, rdurl, csvpath);是个很耗时的操作,这样跑log.info信息记录在了没个盘的根目录下.
我工作空间在f盘xx/workplace/xxx/xxx很深的地方,我断点userDir的值也没错是f:/xx/workplace/xxx/xxx
但是日志csv.log却在f盘根目录下。注释掉JsonToCsvNetUtil.create(rcurl, rdurl, csvpath);输出与项目同级也就是userDir值的位置是我想要的效果
我把项目打包方在e:/xxx/xxx/xx的地方时与上面相同注释掉JsonToCsvNetUtil.create(rcurl, rdurl, csvpath);的时候是正常的输出到userDir下面,加上后就在e盘的根目录下面
...全文
199 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
whos2002110 2014-02-28
  • 打赏
  • 举报
回复
引用 1 楼 defonds 的回复:
这个可以配置哦。它没有按照你配置的路径进行输出吗? 最好是配置绝对路径吧
程序是要打个jar包给别人使用,我想把日志输出到jar所在目录
Defonds 2014-02-27
  • 打赏
  • 举报
回复
这个可以配置哦。它没有按照你配置的路径进行输出吗? 最好是配置绝对路径吧

81,092

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧