• Nginx如何保留真实IP和获取前端IP


    原理:
    squid,varnish以及nginx等,在做反向代理的时候,因为要代替客户端去访问服务器,所以,当请求包经过反向代理后,在代理服务器这里这个IP数据包的IP包头做了修改,最终后端web服务器得到的数据包的头部的源IP地址是代理服务器的IP地址,这样一来,后端服务器的程序给予IP的统计功能就没有任何意义,所以在做代理或集群的时候必须解决这个问题,这里,我以nginx做集群或代理的时候如何给后端web服务器保留(确切的说是传递)客户端的真实IP地址。
    nginx实用X-Forwarded-For这个参数来解决这个问题我们用几个实例来解决
    -----------------------------------------------------------------------------------------------------------
    nginx+tomcat实例
    1,nginx配置文件设置如下

    upstream tomcat_server
      {
      server 192.168.1.66:8080;
      }
      server
      {
        listen       80;
        server_name  node1.113d.com;
        index index.html index.htm index.jsp default.jsp index.do default.do;
        root  /home/www/game;
        error_page 404 = http://game1.113d.com;
    if (-d $request_filename)
    {
            rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;
    }

    #转发动态页面给Tomcat处理
    location ~ .(jsp|jspx|do)?$ {
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_pass http://tomcat_server;
    2,tomcat应用工程(网站程序配置)
    用 String ip = request.getHeader("X-Real-IP");替代String ip = request.getRemoteAddr();
    这是程序这款的了
    -----------------------------------------------------------------------------------------------------------
    apache+nginx静态和动态分离,nginx在apache前,做的PROXY来转发请求到内部的apache上
    1,nginx配置:
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

    2,apache配置:
    用mod_rpaf来获取IP的
    所以需要安装这个模块
    下载:http://stderr.net/apache/rpaf/download/
    tar zxvf mod_rpaf-0.6.tar.gz
    cd mod_rpaf-0.6
    /usr/local/www/apache/bin/apxs -i -c -n mod_rpaf-2.0.so mod_rpaf-2.0.c
    配置apache:
    在 httpd.conf中添加
    LoadModule rpaf_module libexec/apache2/mod_rpaf-2.0.so
    RPAFenable On
    RPAFsethostname On
    RPAFproxy_ips 192.168.1.1 #这个是前段的IP,可不是后端的IP哦
    RPAFheader X-Forwarded-For

    注意,不仅仅要配置nginx,后端获取也需要做配置,例如上面两个例子都做了相应的配置
    -----------------------------------------------------------------------------------------------------------
    nginx+nginx或squid+nginx,也就是说nginx是后端的web服务器,前端用nginx或squid做了缓存服务器,那么nginx如何接受的呢,这里注意了,nginx既可以给后端保留真实IP,也可以作为后端服务器接受前端给的真实IP,他是如何接受的你
    nginx通过http_realip_module模块来实现的
    这需要重新编译,如果提前编译好了就无需重新编译了
    1,重新编译nginx
    编译
    ./configure --user=www --group=www --prefix=/usr/local/webserver/nginx --with-http_stub_status_module --with-http_ssl_module --with-http_realip_module
    make
    make install

    配置
    set_real_ip_from   192.168.1.0/24;     指定接收来自哪个前端发送的 IP head 可以是单个IP或者IP段
    set_real_ip_from   192.168.2.1;
    real_ip_header     X-Real-IP;                  IP head 的对应参数,默认即可。
    加载
    ./nginx -s reload
    我们看到nginx的http_realip_module模块和apache的第三方模块mod_rpaf的作用是一样的
    千万注意:nginx的http_realip_module和前面的proxy_set_header 是不同的
    proxy_set_header:是给后端服务器保留真实IP
    http_realip_module:是获取别人给nginx保留的真实IP
    总之: 
    1,前段要配置保留
    2,后端要配置接受

  • 相关阅读:
    Apache Kafka:下一代分布式消息系统
    深入理解Java之线程池
    JAVA中线程同步的方法(7种)汇总
    String、StringBuffer与StringBuilder之间区别
    Java中是否可以继承String类,为什么
    JAVA4种线程池的使用
    一分钟教你知道乐观锁和悲观锁的区别
    java常见面试题及答案 11-20(JVM)
    springmvc中的页面解析器ViewResolver不起作用,变量输出字符串的解决方案
    SpringMVC默认欢迎页面的问题
  • 原文地址:https://www.cnblogs.com/chjbbs/p/5749490.html
Copyright © 2020-2023  润新知