nginx 日志是对于我们排查网站问题,查看用户访问记录常用的手段,其中nginx日志分为access.log和error.log

  • access.log:记录用户的访问情况,它包括用户的ip,访问时间,请求方式(get或者post),浏览器信息等。
  • error.log:它是服务器错误日志,也是我们排查nginx服务时候正常用到的方法。

全局日志

全局的日志配置文件在/etc/nginx/nginx.conf文件中。

...
# 1错误日志位置
error_log  /var/log/nginx/error.log notice;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;
    
    #2 日志格式
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
   #3 访问日志
    access_log  /var/log/nginx/access.log  main;

   ......

    #虚拟主机配置文件位置
    include /etc/nginx/conf.d/*.conf;
} 

该文件中有3处需要注意。

1. error_log  /var/log/nginx/error.log notice; 配置的是nginx的服务的错误日志位置,一般的,我们默认即可。

2. log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

log_format是nginx的access_log的日志格式,表示需要记录哪些内容。

log_format的参数解释:

  1.  $remote_addr 与$http_x_forwarded_for 用以记录客户端的ip地址;
  2.  $remote_user :用来记录客户端用户名称;
  3.  $time_local : 用来记录访问时间与时区;
  4.  $request : 用来记录请求的url与http协议;
  5.  $status : 用来记录请求状态;成功是200,
  6.  $body_bytes_s ent :记录发送给客户端文件主体内容大小;
  7.  $http_referer :用来记录从那个页面链接访问过来的;
  8.  $http_user_agent :记录客户端浏览器的相关信息;

3. access_log  /var/log/nginx/access.log  main; 表示访问日志的位置。

虚拟主机的日志配置

nginx作为反向代理服务器有时候可能在一台服务器上面代理多个服务,所以在使用虚拟主机的配置时候,需要将access.log和error.log单独配置。如下:

路径 /etc/nginx/conf.d/yxjc123.conf

 server {

 error_log /data/log/yxjc123.com/error.log; #错误日志
 access_log /data/log/yxjc123.com/access.log; #访问日志

}

日志切割配置

nginx日志切割请看  nginx 日志分割配置Logrotate

临时清空日志的方法

echo "" > /var/log/nginx/access.log