log4cxx用环境变量设置输出文件名
log4cxx用环境变量设置输出文件名
(金庆的专栏 2016.12)
利用环境变量,可以用同一个log4j.xml来配置多个相似进程,输出日志到不同文件。
例如多个BaseApp进程使用同一个BaseApp.xml配置, SERVER_ID为环境变量:
<appender name="ROLLING" class="org.apache.log4j.RollingFileAppender">
<param name="File" value="log/BaseApp_${SERVER_ID}.log" />
...
</appender>
代码启动时先读取server_id参数,然后设置 SERVER_ID 环境变量,然后再配置log4cxx.
int main(int argc, char* argv[])
{
log4cxx::NDC ndcMain("");
if (argc < 3)
{
LOG_ERROR(Fmt("Usage: %s cfg_file server_id") % argv[0]);
return -1;
}
uint16_t uServerId = (uint16_t)atoi(argv[2]);
if (!Util::SetServerIdEnv(uServerId)) // for log4cxx
return -1;
// Must after SetServerIdEnv().
log4cxx::xml::DOMConfigurator::configureAndWatch("log4j/BaseApp.xml", 5000);
LOG_INFO("--------------------------- ");
LOG_INFO(Fmt("Start base app (ID=%1%).") % uServerId);
LOG_INFO("--------------------------- ");
...
}
SetServerIdEnv() 如下:
bool SetServerIdEnv(uint16_t uServerId)
{
const char LOG_NAME[] = "SetServerIdEnv";
static char buf[128] = {0}; // putenv need a buffer
int nLen = snprintf(buf, sizeof(buf), "SERVER_ID=%u", uServerId);
if (nLen < 0)
{
LOG_ERROR(Fmt("snprintf() failed. (%1%)%2%") % errno % strerror(errno));
return false;
}
int nErr = putenv(buf);
if (0 == nErr) return true;
LOG_ERROR(Fmt("putenv() failed. (%1%)%2%") % errno % strerror(errno));
return false;
}
运行目录下有个log4cxx缺省配置 log4j.xml, 会自动加载,
所以在 log4cxx 显式配置之前也可以调用日志输出。
运行多个BaseApp.exe:
start Debug\Giant_BaseApp.exe cfg.ini 4
start Debug\Giant_BaseApp.exe cfg.ini 3
log4cxx用环境变量设置输出文件名的更多相关文章
- Ubuntu下 jdk环境变量设置
流程 1. 官网下载对应的jdk文件 2. 在根目录 / 下创建一个java目录 mkdir /java 3. 使用mv命令 将下载下来的文件(压缩格式),移动到上一步创建的/java目录下 Ps ...
- AIX系统的环境变量设置
AIX系统的环境变量设置 用户环境的定义是通过设置环境变量来实现的.AIX系统主要使用两大类profile文件来定义用户环境.一类是用来为所有用户定制环境,另一类是为个人定义自己的环境. 登录时,sh ...
- tomcat配置及使用 环境变量设置
Tomcat的配置及测试: 第一步:下载tomcat,然后解压到任意盘符 第二步:配置系统环境变量 我这里是tomcat5.5,解压到的D盘 (路径为: D:\Program Files\tomcat ...
- 【转】linux环境变量设置
1. 显示环境变量HOME $ echo $HOME /home/terry 2. 设置一个新的环境变量WELCOME $ export WELCOME="Hello!" $ ec ...
- Ubuntu 下开发 Android 环境变量设置
-----------------------------------------------------ANDROID_SDK_HOME:/home/cmm/avds PATH:/home/cmm/ ...
- 在Linux里环境变量设置的方法(export PATH)
一般来说,配置交叉编译工具链的时候须要指定编译工具的路径,此时就须要环境变量设置.比如我的mips-linux-gcc编译器在"/opt/au1200_rm/build_tools/bin& ...
- mac laravel 环境变量设置bash_profile
mac laravel 环境变量设置bash_profile >>>vim ~/.bash_profile '''text export PATH=$PATH:~/.composer ...
- 安装 go和beego后的环境变量设置
简介 之前有几次因为环境变量设置的问题 损失了一些时间,特在此做记录 安装golang 可参考官方Getting Started,但有时候有问题. 解压 tar -C /usr/local -xzf ...
- SQL*Plus环境变量设置浅析
SQL*Plus的使用环境是可以通过login.sql 或 glogin.sql脚本来设置的,可能很多初学者或不习惯使用SQL*Plus的老鸟都不知道.因为在如今UI工具(Toad.PL/SQL De ...
随机推荐
- ORA-09925: Unable to create audit trail file带来的sqlplus / as sysdba无法连接
SQL> show parameter pfile; /picclife/app/oracle/product/11.2.0/dbhome_1/dbs/spfilehukou.ora SQL&g ...
- [LeetCode] Bulb Switcher II 灯泡开关之二
There is a room with n lights which are turned on initially and 4 buttons on the wall. After perform ...
- 半径无关快速高斯模糊实现(附完整C代码)
之前,俺也发过不少快速高斯模糊算法. 俺一般认为,只要处理一千六百万像素彩色图片,在2.2GHz的CPU上单核单线程超过1秒的算法,都是不快的. 之前发的几个算法,在俺2.2GHz的CPU上耗时都会超 ...
- [HNOI 2014]画框
Description 题库链接 \(T\) 组询问,每组询问给你个 \(2\times N\) 的带权二分图,两个权值 \(a,b\) ,让你做匹配使得 \[\sum a\times \sum b\ ...
- [ZJOI 2006]书架
Description 小T有一个很大的书柜.这个书柜的构造有些独特,即书柜里的书是从上至下堆放成一列.她用1到n的正整数给每本书都编了号. 小T在看书的时候,每次取出一本书,看完后放回书柜然后再拿下 ...
- ●POJ 2774 Long Long Message
题链: http://poj.org/problem?id=2774题解: 后缀自动机 使用后缀自动机匹配,思路如下: 即如果当前的x字符匹配失败了,就可以从当前已经匹配的串的后缀去继续匹配. 然后不 ...
- [BZOJ]4197: [Noi2015]寿司晚宴
Time Limit: 10 Sec Memory Limit: 512 MB Description 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴.小 G 和小 W 作为参加 NO ...
- poj2449 (第k条最短路)
题意:求n个点中,a到b的第k条最短路 思路: 用最短路求出估价函数的h,再在搜索过程中记录g,利用A*求出 最开始想到的便是A*和最短路,但是脑子抽了,居然一个一个去求- -,TL了后才发现可以倒着 ...
- Visual Studio 2015 无法命中断点
新安装操作系统后发现,vs2015无法命中断点. 在项目中设置生成调试信息:FULL 即可.
- Python【第五课】迭代器,生成器,数据序列化
本节内容 列表生成式,生成器,迭代器 Json & pickle 数据序列化 1.列表生成式,生成器,迭代器 1.1 列表生成式 列表生成式?不就是生成个列表的表达式,恩~~~ 差不多. 一般 ...