由于公司领导说要把nginx访问日志存进数据库,然后利用程序进行分析,但是nginx访问日志的时间格式是:[17/Jun/2013:14:42:13 +0400] 这种格式不能用datetime格式存进数据库,只能以字符串的格式存进数据库,但是以字符串的格式存进数据库不好按天来进程查询分析,所以需要更改nginx访问日志的时间格式,经过网上查找资料得知更改源代码可以再进行编译可以更改nginx访问日志的格式,但是公司里的程序员都是PHP的,没有人懂C语言,想来想去只有我自己改源码然后编译安装(虽然我也不懂C)。
我需要更改的格式:
原格式为: 17/Jun/2013:14:42:13 +0400
需要修改成:2013-06-17 22:39:02
nginx版本是:nginx-1.4.1
经过网上查找资料,发现需要更改两个文件:src/http/modules/ngx_http_log_module.c 和src/core/ngx_times.c 这两个文件。
一、修改src/core/ngx_times.c 文件,这个文件有3个地方需要修改,分别是:1、在49行和50行原代码如下:
static u_char cached_http_log_time[NGX_TIME_SLOTS] [sizeof("28/Sep/1970:12:00:00 +0600")];
修改后:
static u_char cached_http_log_time[NGX_TIME_SLOTS] [sizeof("1970-09-28 12:00:00")];
2、在64行的原代码为:
ngx_cached_http_log_time.len = sizeof("28/Sep/1970:12:00:00 +0600") - 1;
修改后:
1ngx_cached_http_log_time.len = sizeof("1970-09-28 12:00:00") - 1;
更多精彩内容:http://www.bianceng.cnhttp://www.bianceng.cn/Servers/web/
3、在151行到158行的原代码是(很重要的修改):
p2 = &cached_http_log_time[slot][0]; (void) ngx_sprintf(p2, "%02d/%s/%d:%02d:%02d:%02d %c%02d%02d", tm.ngx_tm_mday, months[tm.ngx_tm_mon - 1], tm.ngx_tm_year, tm.ngx_tm_hour, tm.ngx_tm_min, tm.ngx_tm_sec, tp->gmtoff < 0 ? '-' : '+', ngx_abs(tp->gmtoff / 60), ngx_abs(tp->gmtoff % 60));
修改后是:
p2 = &cached_http_log_time[slot][0]; (void) ngx_sprintf(p2, "%4d-%02d-%02d %02d:%02d:%02d", tm.ngx_tm_year, tm.ngx_tm_mon, tm.ngx_tm_mday, tm.ngx_tm_hour, tm.ngx_tm_min, tm.ngx_tm_sec, tp->gmtoff < 0 ? '-' : '+', ngx_abs(tp->gmtoff / 60), ngx_abs(tp->gmtoff % 60));
注:这里其实是把P2格式改成P1格式基本相同了,完全可以直接将log_time的格式改成p1。
二、修改src/http/modules/ngx_http_log_module.c 文件,有一个地方需要修改
在220行:
1{ ngx_string("time_local"), sizeof("28/Sep/1970:12:00:00 +0600") - 1
修改后:
1{ ngx_string("time_local"), sizeof("1970-09-28 12:00:00") - 1
修改好后,重新编译nginx,编译安装完后用killall -9 nginx 干掉nginx在启动,然后查看nginx的访问日志,看看时间格式是不是改好了。
[root@localhost objs]# tail -n 0 -f /usr/local/nginx/logs/access.log 10.10.8.120 - - [2013-06-18 03:24:24] "GET / HTTP/1.1" 304 0 "-" "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.31 (KHTML, like Gecko) Chrome/26.0.1410.43 Safari/537.31" 10.10.8.120 - - [2013-06-18 03:24:24] "GET /favicon.ico HTTP/1.1" 404 570 "-" "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.31 (KHTML, like Gecko) Chrome/26.0.1410.43 Safari/537.31"
看到上面的时间格式和我想要的是一样的,说明修改成功。
本博文有部分内容参考网上的一些文章,如有版权问题,请联系本人。更多博文请移步:linux开源技术博客 或者 平凡的日子
本文出自 “平凡的日子” 博客,请务必保留此出处http://wolfchen.blog.51cto.com/2211749/1223803
以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索日志
, 文件
, nginx
, sizeof
, 格式
, 时间
, u_char
, nginx访问日志
编译进nginx
nginx 访问日志、nginx 查看访问日志、nginx访问日志分析、nginx 访问日志配置、nginx访问日志格式,以便于您获取更多的相关知识。