linux日志文件存放目录,Log4j 日志文件Linux/Mac/Windows通用存放位置设置方法
log4j1/log4j2中category的配置以及log的输出位置(windows和linux通用的log输出位置)
一、场景和需求
假设我现在有3个独立的用project(暂时用maven关联起来,当然也可以不用maven),一个是提供公共服务的infrastructure,一个是提供存储的persister,一个是提供搜索的searcher,其中提供基础服务的所有的类,例如DateUtils,HttpUtils等工具类都位于目录com.chuanliu.platform.activity下,而提供存储服务的所有类都位于com.chuanliu.platform.activity.persist目录下,提供搜索服务的所有类都位于com.chuanliu.platform.activity.solr下。
现在项目的需求是有一个log文件叫full.log,需要记录所有的日志,不管是infrastructure下的,还是persister下的,还是seracher下的,另外还需要一个日志文件叫solr.log,记录所有发生在搜索目录下的日志。当然将来还应该将searcher目录下的日志放在searcer.log中。
除此之外还应该支持根据不同的部署环境设置不同的log输出位置,因为windows和linux具有不同的目录结构。
二、无论是log4j1还是log4j2中,都可以使用如下配置:
log4j.rootLogger = info
log4j.debug = false
log4j.category.com.chuanliu.platform.activity = info, full, stdout
#The child logger appender will not inherit the parent logger's appender, or the logs will be output twice in the file
log4j.additivity.com.chuanliu.platform.activity.platform.activity = false
log4j.category.com.chuanliu.platform.activity.solr = info, solr
log4j.additivity.com.chuanliu.platform.activity.platform.activity.solr = false
###### activity full log: contains all of the log ####
#full
log4j.appender.full = org.apache.log4j.DailyRollingFileAppender
log4j.appender.full.File = ${LogFile.Location}/full.log
log4j.appender.full.DatePattern = '.'yyyy-MM-dd
log4j.appender.full.layout = org.apache.log4j.PatternLayout
log4j.appender.full.layout.conversionPattern = %d [%t] %-5p %c{1} - %m%n
log4j.appender.full.ImmediateFlush = true
log4j.appender.full.append = true
######activity full log ####
######activity solr log : only contain the log in searcher####
#solr
log4j.appender.solr = org.apache.log4j.DailyRollingFileAppender
log4j.appender.solr.File = ${LogFile.Location}/solr.log
log4j.appender.solr.DatePattern = '.'yyyy-MM-dd
log4j.appender.solr.layout = org.apache.log4j.PatternLayout
log4j.appender.solr.layout.conversionPattern = %d [%t] %-5p %c{1} - %m%n
log4j.appender.solr.ImmediateFlush = true
log4j.appender.solr.append = true
######activity solr log ####
# Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=[%d][%p]%t: %m%n
# log sql for mybatis
log4j.logger.mybatis =TRACE
org.springframework.web=debug
这样经过测试,你会发现,所有的log都进入了full.log中,而只有com.chuanliu.platform.activity.solr下的日志输出进入了solr.log.
另外对于日志的输出位置, ${LogFile.Location},我们可以在不同环境的配置文件中自定义LogFile.Location的值,比如在代表本地环境的dev.properties中,定义LogFile.Location=C://logs
代表测试环境的qa.properties中,定义LogFile.Location=/usr/local/var/logs,同样在生产环境中定义相同的值为:LogFile.Location=/usr/local/var/logs,这样在不同环境下就会在不同路径下生成不同的log文件。
其实,经过测试后,没有这么麻烦,我们可以统一将windows和linux的log输出配置到同一个地方,即上面我们可以统一的将输出设置为/usr/local/var/logs,这样的设置在linux中,大家都能理解,但在windows中,可能不是那么好理解,在windows中,/usr/local/var/log有2层含义:
1、如果是在eclipse中执行这些日志输出的类的方法,那么将在workspace所在的磁盘,例如E盘中创建目录/usr/local/var/log,并输出full.log和solr.log.
2、如果是在tomcat中应用执行日志的输出,那边就是在tomcat所在的磁盘中,例如D盘中创建目录/usr/local/var/log,并输出full.log和solr.log,即便是在eclipse中启动tomcat,这时tomcat的wtpapps目录是在eclipse所在的目录,如E盘中,但是真正使用的tomcat是在D盘中的,那么同样是在/usr/local/var/logs中输出如上的日志文件。
以上这篇Log4j 日志文件Linux/Mac/Windows通用存放位置设置方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
linux日志文件存放目录,Log4j 日志文件Linux/Mac/Windows通用存放位置设置方法相关推荐
- Linux文件、目录——鸟哥的Linux私房菜
鸟哥的Linux私房菜第六章--Linux文件和目录管理 文章目录 第六章:Linux文件和目录管理 一.目录和路径 1. 相对路径和绝对路径 2. 目录相关操作 3. $PATH 二.文件和目录管理 ...
- linux下循环读取目录文件,linux循环递归读取目录指定类型文件及计算阶乘脚本...
linux循环读取目录指定类型文件脚本 ergodic.sh #!/bin/bash function ergodic { for file in ` ls $1` do if [ -d $1&quo ...
- php获取目录文件 排序输出,php实现对文件夹目录中的文件进行排序的方法
php实现对文件夹目录中的文件按照时间.名称.大小进行排序的方法 函数介绍: opendir() 函数打开目录句柄. readdir() 函数返回目录中下一个文件的文件名. array_multiso ...
- C#中拷贝指定文件夹下的所有文件夹目录到指定文件夹中的方法
原文地址:http://www.biye5u.com/article/Csharp/fileprog/2011/4198.html 本文给出了一个在C#中拷贝指定文件夹下的所有文件夹目录到指定文件夹中 ...
- php scandir 目录树,使用php scandir函数遍历文件夹目录和所有文件
使用php scandir函数遍历文件夹目录和所有文件 $dir = "."; //当前目录 list_file($dir); function list_file($dir){ ...
- php如何将读取到的mysql内容按发布的日期分割显示_php如何读取文件夹目录里的文件并按照日期,大小,名称排序...
最近用到的php读取文件夹目录里的文件,并按照日期,大小,名称排序,所以写了一个方法,备用. function dir_size($dir,$url){ $dh = @opendir($dir); ...
- Objective-C文件和目录操作,IOS文件操作,NSFileManager使用文件操作
Objective-C文件和目录操作,IOS文件操作,NSFileManager使用文件操作: objective-c通过使用NSFileManager类来管理和操作文件.目录,NSFileManag ...
- linux sh语法进入目录,Linux_常用的Linux shell命令详解收集整理,1 文件与目录操作命令
1.1文 - phpStudy...
1 文件与目录操作命令 1.1文件内容查询命令 grep.fgrep.egrep 语法:grep[选项][查找模式][文件名1,文件名2,--] 选项: -E 每个模式作为一个扩展的正则表达式对待 - ...
- linux文件移出目录命令_Linux 文件与目录管理详解
一.目录树 在 Linux 底下,所有的文件与目录都是由根目录开始的. 根目录是所有目录与文件的源头,再一个一个的分支下来,有点像是树枝状. 因此,我们也称这种目录配置方式为:『目录树(directo ...
最新文章
- 机器学习中的聚类算法(1):k-means算法
- mysql 主从有哪几种模式_mysql 主从模式总结(一)
- python_day9线程、进程和协程
- L309 单音节词读音规则(一)-辅音字母发音规则
- js打开android应用程序,浏览器通过JS打开Android程序
- 《神经网络和深度学习》系列文章五:用简单的网络结构解决手写数字识别
- Mac配置Android SDK环境变量
- 【Java】按要求编程输出2018年日历
- UE4 蓝图事件调度器Event Dispatcher
- tomcat示例文件漏洞解决方案
- JavaCV 制作字符画
- 超有爱的并查集 6666
- HTML5前端开发实战08-外语培训
- 在工作空间中如何构造IPath或IFile
- GitHub 报告揭示香港码农大爆发,老实的程序员:转行只因工资高!
- PHP通过phpspreadsheet读取Excel文件
- 用Matlab的.m文件运行 Simulink 搭建的子系统,对子函数进行输入赋值,运行,输出读取
- 步态能量图 matlab,【计算机视觉】步态能量图GEI
- 关于android屏幕分辨率
- 使用eclipse的时候突然鼠标光标变成黑色小方块