zoukankan      html  css  js  c++  java
  • web集群nginx日志记录访问ip

    centos7.5 前端使用负载均衡后,后端web日志没有记录来访ip

    问题:负载均衡记录了来访ip,web没有记录来访ip

    [root@lb01 conf.d]# tail -f /var/log/nginx/access.log
    10.0.0.1 - - [06/May/2019:20:26:56 +0800] "GET / HTTP/1.1" 200 9 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.86 Safari/537.36" "-"
    [root@web01 conf.d]# tail -f /var/log/nginx/access.log
    10.0.0.5 - - [06/May/2019:20:26:56 +0800] "GET / HTTP/1.1" 200 9 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.86 Safari/537.36" "-"
    

    原因:请求发送到负载之后,再由负载开一个端口发送请求给web,所以会在web中记录负载的ip

    解决方法:

    [root@web01 conf.d]# vim ../nginx.conf
        log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                          '$status $body_bytes_sent "$http_referer" '
                          '"$http_user_agent" "$http_x_forwarded_for"';	#web的nginx日志上有这条
    [root@lb01 conf.d]# vim web.lvhanzhi.com.conf 
    server{
    	listen 80;
    	server_name web.lvhanzhi.com;
    	location / {
    		proxy_pass http://10.0.0.7:80;
    		proxy_set_header Host $http_host;
    		proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;	#在负载均衡上写上这个
    		proxy_http_version 1.1;
    	}
    	location /favicon.ico{
    		return 200;
    		access_log off;
    	}
    }
    

    查看结果:

    [root@lb01 conf.d]# tail -f /var/log/nginx/access.log
    10.0.0.1 - - [06/May/2019:20:53:19 +0800] "GET / HTTP/1.1" 304 0 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.86 Safari/537.36" "-"
    [root@web01 conf.d]# tail -f /var/log/nginx/access.log
    10.0.0.5 - - [06/May/2019:20:53:19 +0800] "GET / HTTP/1.1" 304 0 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.86 Safari/537.36" "10.0.0.1"
    #可以看到web上面有访问者的ip
  • 相关阅读:
    spring 声明式事务的坑 @Transactional 注解
    这样学Linux基本命令,事半功倍
    NIO buffer 缓冲区 API
    Java技术——你真的了解String类的intern()方法吗
    Spring中配置数据源的4种形式
    Java集合框架List,Map,Set等全面介绍
    阿里面试题:关于类中静态,非静态,构造方法的执行顺序
    web.xml加载顺序
    MyBatis 延迟加载,一级缓存,二级缓存设置
    mybatis 调用存储过程
  • 原文地址:https://www.cnblogs.com/lvhanzhi/p/10822047.html
Copyright © 2011-2022 走看看