Linux下如何关闭禁用Nginx或Apache日志

2014-04-24 16:54:15   来源:OK165.com   我要评论

OK165.com建站经验技术文章。本文讲解在Linux系统下如何关闭禁用Nginx或Apache的系统日志:

Nginx

# 关掉错误日志
error_log /dev/null crit;
# 如果需要错误日志,就用下面这行替换上面这行
#error_log /var/log/nginx/error.log notice;

Apache

ErrorLog "/dev/null"(禁止日志文件)
LogLevel crit
停止access_log关闭log_config_module模块即可
或者修改CustomLog "logs/access_log" common为CustomLog "/dev/null" common

用在Apache的httpd.conf配置文件中配置apache自带的程序rotatelogs的功能,也能很好限制日志文件的大小。

在Linux下的设置如下:

1、每天生成新日志

CustomLog "|/usr/sbin/rotatelogs /etc/httpd/logs/access_log_%Y-%m-%d 86400 480" combined

2、日志超过一定大小生成新日志

CustomLog "|/usr/sbin/rotatelogs /etc/httpd/logs/access_log_%Y-%m-%d 5M" combined

3、rotatelogs语法

rotatelogs [ -l ] logfile [ rotationtime [ offset ]] | [ filesizeM ]

logfile它加上基准名就是日志文件名。如果logfile中包含"%",则它会被视为用于strftime()的格式字符串;否则它会被自动加上以秒为单位的".nnnnnnnnnn"后缀。这两种格式都表示新的日志开始使用的时间。rotationtime日志文件滚动的以秒为单位的间隔时间。offset相对于UTC的时差的分钟数。如果省略,则假定为"0"并使用UTC时间。比如,要指定UTC时差为"-5小时"的地区的当地时间,则此参数应为"-300"。filesizeM指定以filesizeM文件大小滚动,而不是按照时间或时差滚动。在Windows下的设置例子如下:

# 限制错误日志文件为 1M
ErrorLog "|bin/rotatelogs.exe -l logs/error-%Y-%m-%d.log 1M"

# 每天生成一个错误日志文件
#ErrorLog "|bin/rotatelogs.exe  logs/error-%Y-%m-%d.log 86400"

# 限制访问日志文件为 1M
CustomLog "|bin/rotatelogs.exe -l logs/access-%Y-%m-%d.log 1M" common

# 每天生成一个访问日志文件
#CustomLog "|bin/rotatelogs.exe  logs/access-%Y-%m-%d.log 86400" common