当前位置: 首页 > 工具软件 > Apache River > 使用案例 >

Apache 配置日志文件每日生成、日志格式、等级

诸修伟
2023-12-01
一、配置所有项目
  1. 先使用命令 which rotatelogs 找到系统的 rotatelogs 命令的路径。
  2. 修改httpd配置文件
vi /etc/httpd/conf/httpd.conf
# 找到默认日志存储,注释掉
# 183  ErrorLog "logs/error_log"
# 每天单独生成一个日志文件
ErrorLog "| /usr/sbin/rotatelogs logs/graduation_project_logs/error_log_%Y%m%d.log 86400 480"  

# 218  CustomLog "logs/access_log_%Y%m%d" combined
CustomLog "| /usr/sbin/rotatelogs logs/graduation_project_logs/access_log_%Y%m%d.log 86400 480" combined
  1. 日志格式配置
# 日志的缺省格式有如下几种
# 带虚拟主机的通用日志格式
LogFormat "%v %h %l %u %t \"%r\" %>s %b"

# NCSA扩展/组合日志格式
LogFormat "%h %l %u %t "%r" %>s %b "%{Referer}i" "%{User-Agent}i"" combined

# 通用日志格式(CLF)
LogFormat “%h %l %u %t “%r” %>s %b” common #common为日志格式名称

# Referer日志格式
LogFormat “%{Referer}i -> %U” referer

# Agent(Browser)日志格式
LogFormat “%{User-agent}i” agent

%h –客户端的ip地址或主机名
%l –The 这是由客户端 identd 判断的RFC 1413身份,输出中的符号 “-” 表示此处信息无效。
%u –由HTTP认证系统得到的访问该网页的客户名。有认证时才有效,输出中的符号 “-” 表示此处信息无效。
%t –服务器完成对请求的处理时的时间。
"%r" –引号中是客户发出的包含了许多有用信息的请求内容。
%>s –这个是服务器返回给客户端的状态码。
%b –最后这项是返回给客户端的不包括响应头的字节数。
"%{Referer}i" –此项指明了该请求是从被哪个网页提交过来的。
"%{User-Agent}i" –此项是客户浏览器提供的浏览器识别信息。
# 各字符含义说明
%%    百分号(Apache2.0.44或更高的版本)
%a    远端IP地址
%A    本机IP地址
%B    除HTTP头以外传送的字节数
%b    以CLF格式显示的除HTTP头以外传送的字节数,也就是当没有字节传送时显示'-'而不是0。
%{Foobar}C    在请求中传送给服务端的cookieFoobar的内容。
%D    服务器处理本请求所用时间,以微为单位。
%{FOOBAR}e    环境变量FOOBAR的值
%f    文件名
%h    远端主机
%H    请求使用的协议
%{Foobar}i    发送到服务器的请求头Foobar:的内容。
%l    远端登录名(由identd而来,如果支持的话),除非IdentityCheck设为"On",否则将得到一个"-"。
%m    请求的方法
%{Foobar}n    来自另一个模块的注解Foobar的内容。
%{Foobar}o    应答头Foobar:的内容。
%p    服务器服务于该请求的标准端口。
%P    为本请求提供服务的子进程的PID。
%{format}P 服务于该请求的PID或TID(线程ID),format的取值范围为:pid和tid(2.0.46及以后版本)以及hextid(需要APR1.2.0及以上版本)
%q    查询字符串(若存在则由一个"?"引导,否则返回空串)
%r    请求的第一行
%s    状态。对于内部重定向的请求,这个状态指的是原始请求的状态,---%>s则指的是最后请求的状态。
%t    时间,用普通日志时间格式(标准英语格式)
%{format}t    时间,用strftime(3)指定的格式表示的时间。(默认情况下按本地化格式)
%T    处理完请求所花时间,以秒为单位。
%u    远程用户名(根据验证信息而来;如果返回status(%s)为401,可能是假的)
%U    请求的URL路径,不包含查询字符串。
%v    对该请求提供服务的标准ServerName。
%V    根据UseCanonicalName指令设定的服务器名称。
  1. 日志等级配置
# debug, info, notice, warn, error, crit, alert, emerg
LogLevel warn
二、配置单个项目
  1. 找到该项目的虚拟主机配置处,在 <virtualhost *:80> 目录下进行上述配置
<virtualhost *:80>
    ServerName 172.19.88.73
	
	# 每天单独生成一个日志文件
    ErrorLog "| /usr/sbin/rotatelogs logs/graduation_project_logs/error_log_%Y%m%d.log 86400 480" 
    # 开发环境用 common,生产环境用 combined
	CustomLog "| /usr/sbin/rotatelogs logs/graduation_project_logs/access_log_%Y%m%d.log 86400 480" combined

    # 配置虚拟环境地址,也就是 依赖包 所在目录
    WSGIDaemonProcess app python-path=……
    #路由是 /,通过访问 服务器域名:端口/ 直接访问项目
    # app.wsgi 是配置文件,同 app.py 目录
    WSGIScriptAlias /  /var/www/yourappilication/app.wsgi

    <directory /var/www/yourappilication>
        WSGIProcessGroup app
        WSGIApplicationGroup %{GLOBAL}
        WSGIScriptReloading On
        Order deny,allow
        Allow from all
    </directory>
</virtualhost>

参考文章:【1】配置Apache每天生成新的网站日志(access.log和error.log) | 云上小悟
     【2】Apache日志配置解析 - river - CSDN博客
     【3】apache日志格式定义及示例说明 - newhappy的专栏 - CSDN博客

 类似资料: