最近散仙在做公司的一个跟搜索有关的数据分析项目,主要就是统计搜索的转化率,目的主要有以下几个: 
(1)通过数据分析挖掘,找出搜索业务在整个平台系统里的GMV里所占份额 
(2)给公司的搜索算法调优,提供可靠的参考依照 
(3)了解从搜索入口到最终交易之间各个阶段的数据比重,主要有搜索点击率,搜索曝光率,搜索添加购物车率,搜索下单率,搜索支付率,以及最终的成交金额等

当然还有其他的一些比较细的数据,这里就不细说了,今天,记录一个比较低级的问题,散仙在自己的web项目发现log4j记录的日志文件竟然找不到了,散仙结构图如下:

 
log4j.properties的配置文件如下:

  1. log4j.rootCategory=INFO,fileout,errorout,stdout
  2. log4j.appender.stdout=org.apache.log4j.ConsoleAppender
  3. log4j.appender.stdout.layout.ConversionPattern=%d{MM-dd HH\:mm\:ss.SSS}[%-30F\:%-5p\:%l] %m%n
  4. log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
  5. log4j.appender.fileout=org.apache.log4j.DailyRollingFileAppender
  6. log4j.appender.errorout.Threshold=ERROR
  7. log4j.appender.fileout.layout.ConversionPattern=%d{MM-dd HH\:mm\:ss.SSS}[%-5p] %m%n
  8. log4j.appender.fileout.layout=org.apache.log4j.PatternLayout
  9. log4j.appender.fileout.File=log/info.log
  10. log4j.appender.fileout.Append=true
  11. log4j.appender.fileout.DatePattern='.'yyyy-MM-dd
  12. log4j.appender.errorout=org.apache.log4j.RollingFileAppender
  13. log4j.appender.errorout.File=log/error.log
  14. log4j.appender.errorout.MaxFileSize=100000KB
  15. log4j.appender.errorout.MaxBackupIndex=10
  16. log4j.appender.errorout.Append=true
  17. log4j.appender.errorout.layout=org.apache.log4j.PatternLayout
  18. log4j.appender.errorout.layout.ConversionPattern=%d{MM-dd HH\:mm\:ss.SSS}[%-30F\:%-5p\:%l] %m%n

程序运行出异常(测试使用)之后,发现这个log目录里空空如也,什么也没记,后来直接在控制台运行,发现log却生效了,比较奇怪,但既然log4j配置了记录日志,这功能肯定是有的,为什么没有记录下我指定的目录下呢?

后来查资料后,发现散仙犯了一个比较低级的错误,web工程里的日志记录路径和普通的java的日志记录路径是不一样的,web工程的日志是在web容器里的,普通的工程就在根目录下,所以散仙在这里使用MyEclipse启动Web项目后,其实是看不到日志的,因为编译后的工程是在MyEclipse集成的(自己可指定)tomcat里的路径下的,所以直接在MyEclipse下找日志文件是肯定不行的。

知道这个原因后,散仙就去该项目的根目录下的log文件夹里找log文件,结果依旧没有找到,后来在tomcat的bin目录下,找到了可爱的log文件夹,真是不容易,我擦,那么为什么会出现在这里呢?

因为我们的tomcat的启动脚本是在bin目录下的,而默认也会去把路径作为根目录,所以散仙在上面代码里配置的log/xxx.log结果自然而然就进入了该目录,知道这个原因后,我们只需要加上相对路径配置,便可以解决这个问题,当然也可以使用绝对路径,看自己的业务吧,散仙比较推荐使用相对路径,因为这样当我们下一次切换tomcat的路径时,我们不需要再改动路径,而如果你是绝对路径,则需要改动路径才行。

下面看下几种在web工程里配置路径方法:

(1)log4j.appender.file.File=${catalina.home}/webapps/xxx项目路名/log/xxx.log,代表使用${catalina.home}引用当前的tomcat目录,这个变量无需在我们的环境变量里设置。 
(2)log4j.appender.file.File=../webapps/xxx项目路名/log/xxx.log 
使用相对路径,这个更简洁

最终的log4j.properties的配置如下:

  1. log4j.rootCategory=INFO,fileout,errorout,stdout
  2. log4j.appender.stdout=org.apache.log4j.ConsoleAppender
  3. log4j.appender.stdout.layout.ConversionPattern=%d{MM-dd HH\:mm\:ss.SSS}[%-30F\:%-5p\:%l] %m%n
  4. log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
  5. log4j.appender.fileout=org.apache.log4j.DailyRollingFileAppender
  6. log4j.appender.errorout.Threshold=ERROR
  7. log4j.appender.fileout.layout.ConversionPattern=%d{MM-dd HH\:mm\:ss.SSS}[%-5p] %m%n
  8. log4j.appender.fileout.layout=org.apache.log4j.PatternLayout
  9. #log4j.appender.errorout.File=${catalina.home}/webapps/DataShow/log/info.log
  10. log4j.appender.fileout.File=../webapps/DataShow/log/info.log
  11. log4j.appender.fileout.Append=true
  12. log4j.appender.fileout.DatePattern='.'yyyy-MM-dd
  13. log4j.appender.errorout=org.apache.log4j.RollingFileAppender
  14. #log4j.appender.errorout.File=${catalina.home}/webapps/DataShow/log/error.log
  15. log4j.appender.errorout.File=../webapps/DataShow/log/error.log
  16. log4j.appender.errorout.MaxFileSize=100000KB
  17. log4j.appender.errorout.MaxBackupIndex=10
  18. log4j.appender.errorout.Append=true
  19. log4j.appender.errorout.layout=org.apache.log4j.PatternLayout
  20. log4j.appender.errorout.layout.ConversionPattern=%d{MM-dd HH\:mm\:ss.SSS}[%-30F\:%-5p\:%l] %m%n

上面,二种写法都可以,大家可以根据自己习惯定义,改成完成之后,再次测试,发现log4j,终于如愿以偿的如何我们的要求了,另外建议大家在配置log4j时,最好把不同的log级别给分离开,这样便于快速定位查找问题,大部分情况下,我们只需要2个级别,info和error,当然你可以定义的更细,根据自己的业务,进行定制!


想了解更多有关电商互联网公司的搜索技术和大数据技术的使用,请欢迎扫码关注微信公众号:我是攻城师(woshigcs) 
本公众号的内容是有关搜索和大数据技术和互联网等方面内容的分享,也是一个温馨的技术互动交流的小家园,有什么问题随时都可以留言,欢迎大家来访!


记一次log4j日志文件小事故的更多相关文章

  1. 记一次log4j日志文件输出错误的解决

    log4j错误信息:log4j:ERROR Failed to rename [D:/logs/wmts_] to [D:/logs/wmts_2015-12-21.log ]. 起因:部门网站使用B ...

  2. Log4j 输出的日志中时间比系统时间少了8小时的解决方法,log4j日志文件重复输出

    1. 第一个问题:时间少了8小时 Log4j 输出的日志中,时间比系统时间少了8小时,但是 eclipse 控制台输出的日志的时间却是对的. log4j配置如下: #all logger output ...

  3. log4j 日志文件(Day_19)

    详细  :   https://www.cnblogs.com/liaojie970/p/7634838.html log4j  日志文件 1 log4j.rootLogger=debug,CONSO ...

  4. log4j日志文件 log4j.xml log4j.properties配置

    1,导入log4j  jar包; 2,配置log4j.xml或log4j.properties文件; ------------------------------------------------- ...

  5. 【lucene系列学习四】log4j日志文件实现多线程的测试

    参考资料:http://nudtgk2000.iteye.com/blog/1716379 首先,在http://www.apache.org/dyn/closer.cgi/logging/log4j ...

  6. [ log4j ]-日志文件的使用

    在java文件中通过 log4j 输出日志信息 1,先引入 log4j-xx.x.jar 包 2,新建一个日志类 PrintLog4j.java: package com.stu.log4j; imp ...

  7. log4j日志文件路径设置

    假设有如下标准化的目录结构: $HOME |-- log |-- conf |-- bin |-- lib |-- data jar包放在lib目录,启动脚本放在bin目录,日志文件放在log目录,配 ...

  8. java log4j 日志文件

    开发中经常会用到log日志文件,根据业务需要可能不产生很大日志文件给维护和[排错带来了麻烦.所以我们希望能够每天或每个月产生一个日志文件,这样文件不至于过大. 或者根据日志文件大小来判断,超过规定大小 ...

  9. log4j日志文件输出保存

    og4j.appender.A1=org.apache.log4j.DailyRollingFileAppender log4j.appender.A1.File=app.log log4j.appe ...

随机推荐

  1. python实现操作excel,数据写入excel的一行或者一列

    # _*_ coding:utf-8 _*_ import random import xlwt,string class ImportData(object): def create_num(sel ...

  2. CSIC_716_20191111【函数对象、名称空间、作用域、global 和nonlocal】

    函数名是可以被引用,传递的是函数的内存地址.函数名赋值给变量后,只需要在变量后加上括号即可调用函数. 名称空间 内置名称空间:在python解释器中提前定义完的名字 全局名称空间:if.while.f ...

  3. 数据提取--JSON

    什么是数据提取? 简单的来说,数据提取就是从响应中获取我们想要的数据的过程 非结构化的数据:html等 结构化数据:json,xml等 处理方法:正则表达式.xpath 处理方法:转化为python数 ...

  4. 期望dp+高斯消元优化——uvalive4297好题

    非常好的题!期望+建矩阵是简单的,但是直接套高斯消元会T 所以消元时要按照矩阵的形态 进行优化 #include<bits/stdc++.h> using namespace std; ; ...

  5. python中循环引用导致内存泄漏小案例

    首先定义一个Person类和一个Dog类,然后分别实例化对象p和d,给p对象添加一个pet属性 给d对象添加一个master属性此时Person和Dog的应用计数都为2,当del p 和del d后P ...

  6. ASP.NET自定义Validform的datatype

    1.定义 <script type="text/javascript"> $(function () { $("#aa").Validform({ ...

  7. java获取服务器路径

    java获取服务器一些信息的方法(服务器地址/相对路径/端口/项目名字 request.getServletContext().getRealPath("/")  获取项目所在服务 ...

  8. Django的日常-模型层(1)

    目录 Django的日常-模型层(1) 模型层 django测试环境 ORM查询 Django的日常-模型层(1) 模型层 模型层其实就是我们应用名下的models.py文件,我们在里面写入想要创建的 ...

  9. 论文阅读-(CVPR 2017) Kernel Pooling for Convolutional Neural Networks

    在这篇论文中,作者提出了一种更加通用的池化框架,以核函数的形式捕捉特征之间的高阶信息.同时也证明了使用无参数化的紧致清晰特征映射,以指定阶形式逼近核函数,例如高斯核函数.本文提出的核函数池化可以和CN ...

  10. mysql的建表约束

    主键约束(primary key) 主键约束能够唯一确定一张表中的记录,也就是可以通过某个字段添加约束,就可以是的该字段不重复,且不为空 create table user (id int prima ...