久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

    <i id='lnOy8'><tr id='lnOy8'><dt id='lnOy8'><q id='lnOy8'><span id='lnOy8'><b id='lnOy8'><form id='lnOy8'><ins id='lnOy8'></ins><ul id='lnOy8'></ul><sub id='lnOy8'></sub></form><legend id='lnOy8'></legend><bdo id='lnOy8'><pre id='lnOy8'><center id='lnOy8'></center></pre></bdo></b><th id='lnOy8'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='lnOy8'><tfoot id='lnOy8'></tfoot><dl id='lnOy8'><fieldset id='lnOy8'></fieldset></dl></div>

    1. <small id='lnOy8'></small><noframes id='lnOy8'>

      • <bdo id='lnOy8'></bdo><ul id='lnOy8'></ul>
      <legend id='lnOy8'><style id='lnOy8'><dir id='lnOy8'><q id='lnOy8'></q></dir></style></legend>
      <tfoot id='lnOy8'></tfoot>

      Docker Swarm 在 Nginx 中獲取真實 IP(客戶端主機)

      Docker Swarm get real IP (client host) in Nginx(Docker Swarm 在 Nginx 中獲取真實 IP(客戶端主機))
        <bdo id='5GE3J'></bdo><ul id='5GE3J'></ul>

      • <tfoot id='5GE3J'></tfoot>
          <tbody id='5GE3J'></tbody>

          <i id='5GE3J'><tr id='5GE3J'><dt id='5GE3J'><q id='5GE3J'><span id='5GE3J'><b id='5GE3J'><form id='5GE3J'><ins id='5GE3J'></ins><ul id='5GE3J'></ul><sub id='5GE3J'></sub></form><legend id='5GE3J'></legend><bdo id='5GE3J'><pre id='5GE3J'><center id='5GE3J'></center></pre></bdo></b><th id='5GE3J'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='5GE3J'><tfoot id='5GE3J'></tfoot><dl id='5GE3J'><fieldset id='5GE3J'></fieldset></dl></div>
              <legend id='5GE3J'><style id='5GE3J'><dir id='5GE3J'><q id='5GE3J'></q></dir></style></legend>

                <small id='5GE3J'></small><noframes id='5GE3J'>

                本文介紹了Docker Swarm 在 Nginx 中獲取真實 IP(客戶端主機)的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

                問題描述

                我有一個包含 nginx 和 PHP 的堆棧,可以在 Docker Swarm 集群上運行.

                I have a stack with nginx and PHP to run on Docker Swarm Cluster.

                在我的 PHP 應用程序中,我需要從訪問我的 web 應用程序的客戶端主機獲取包含真實 IP 的 remote_addr ($_SERVER['REMOTE_ADDR']).

                In a moment in my PHP application, I need to get the remote_addr ($_SERVER['REMOTE_ADDR']) which contains the real IP from the client host accessing my webapp.

                但問題是docker swarm集群通知nginx的IP.它顯示了一個像 10.255.0.2 這樣的內部 IP,但真正的 IP 是來自客戶端主機的外部 IP(如 192.168.101.151).

                But the problem is that the IP informed for nginx by docker swarm cluster. It's showed an Internal IP like 10.255.0.2, but the real IP it's the external IP from the client Host (like 192.168.101.151).

                我該如何解決?

                我的 docker-compose 文件:

                My docker-compose file:

                version: '3'
                
                services:
                  php:
                    image: php:5.6
                    volumes:
                      - /var/www/:/var/www/
                      - ./data/log/php:/var/log/php5
                    networks:
                      - backend
                    deploy:
                      replicas: 1
                  web:
                    image: nginx:latest
                    ports:
                      - "80:80"
                    volumes:
                      - /var/www/:/var/www/
                      - ./data/log/nginx:/var/log/nginx
                    networks:
                      - backend
                networks:
                  backend:
                

                我的 default.conf (vhost.conf) 文件:

                My default.conf (vhost.conf) file:

                server {
                    listen          80;
                    root            /var/www;
                    index           index.html index.htm index.php;
                
                    access_log  /var/log/nginx/access.log  main;
                    error_log   /var/log/nginx/error.log error;
                
                    location / {
                        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_set_header        X-Forwarded-Proto $scheme;
                
                        try_files   $uri $uri/ /index.php;
                    }
                
                    location = /50x.html {
                        root   /var/www;
                    }
                
                    # set expiration of assets to MAX for caching
                    location ~* .(js|css|gif|png|jp?g|pdf|xml|oga|ogg|m4a|ogv|mp4|m4v|webm|svg|svgz|eot|ttf|otf|woff|ico|webp|appcache|manifest|htc|crx|oex|xpi|safariextz|vcf)(?[0-9]+)?$ {
                            expires max;
                            log_not_found off;
                    }
                
                    location ~ .php$ {
                        try_files                   $uri =404;
                        fastcgi_index               index.php;
                        fastcgi_split_path_info     ^(.+.php)(/.+)$;
                        fastcgi_pass                php:9000;
                        include                     fastcgi_params;
                        fastcgi_param               SCRIPT_FILENAME $document_root$fastcgi_script_name;
                        fastcgi_param               PATH_INFO       $fastcgi_path_info;
                        fastcgi_read_timeout        300;
                    }
                }
                

                我的 nginx 配置文件:

                My nginx config file:

                user  nginx;
                worker_processes    3;
                
                error_log  /var/log/nginx/error.log warn;
                pid        /var/run/nginx.pid;
                
                events {
                    worker_connections  1024;
                }
                
                http {
                    include       /etc/nginx/mime.types;
                    default_type  application/octet-stream;
                
                    keepalive_timeout   15;
                    client_body_buffer_size     100K;
                    client_header_buffer_size   1k;
                    client_max_body_size        8m;
                    large_client_header_buffers 2 1k;
                
                    gzip             on;
                    gzip_comp_level  2;
                    gzip_min_length  1000;
                    gzip_proxied     expired no-cache no-store private auth;
                    gzip_types       text/plain application/x-javascript text/xml text/css application/xml;
                
                    log_format  main  '$remote_addr - $remote_user [$time_local]  "$request_filename" "$request" '
                                      '$status $body_bytes_sent "$http_referer" '
                                      '"$http_user_agent" "$http_x_forwarded_for"';
                
                    access_log  /var/log/nginx/access.log  main;
                
                    sendfile        on;
                    #tcp_nopush     on;
                
                    include /etc/nginx/conf.d/*.conf;
                }
                

                推薦答案

                對于那些不想閱讀所有 github 線程的人 ( https://github.com/moby/moby/issues/25526 ),對我有用的答案是將配置更改為:

                for those don't want to read all the github thread ( https://github.com/moby/moby/issues/25526 ), the answer that was good for me was to change the config to this :

                version: '3.7'
                services:
                  nginx:
                    ports:
                      - mode: host
                        protocol: tcp
                        published: 80
                        target: 80
                      - mode: host
                        protocol: tcp
                        published: 443
                        target: 81
                

                這仍然可以讓內部覆蓋網絡工作,但使用 iptables 的一些技巧將這些端口直接轉發到容器,以便容器內的服務看到數據包的正確源 IP 地址.

                This still lets the internal overlay network work, but uses some tricks with iptables to forward those ports directly to the container, so the service inside the container see the correct source IP address of the packets.

                iptables 中沒有允許在多個容器之間平衡端口的功能,因此您只能將一個端口分配給一個容器(其中包括一個容器的多個副本).

                There is no facility in iptables to allow balancing of ports between multiple containers, so you can only assign one port to one container (which includes multiple replicas of a container).

                這篇關于Docker Swarm 在 Nginx 中獲取真實 IP(客戶端主機)的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

                【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

                相關文檔推薦

                Deadlock exception code for PHP, MySQL PDOException?(PHP、MySQL PDOException 的死鎖異常代碼?)
                PHP PDO MySQL scrollable cursor doesn#39;t work(PHP PDO MySQL 可滾動游標不起作用)
                PHP PDO ODBC connection(PHP PDO ODBC 連接)
                Using PDO::FETCH_CLASS with Magic Methods(使用 PDO::FETCH_CLASS 和魔術方法)
                php pdo get only one value from mysql; value that equals to variable(php pdo 只從 mysql 獲取一個值;等于變量的值)
                MSSQL PDO could not find driver(MSSQL PDO 找不到驅動程序)

                <i id='PvAkt'><tr id='PvAkt'><dt id='PvAkt'><q id='PvAkt'><span id='PvAkt'><b id='PvAkt'><form id='PvAkt'><ins id='PvAkt'></ins><ul id='PvAkt'></ul><sub id='PvAkt'></sub></form><legend id='PvAkt'></legend><bdo id='PvAkt'><pre id='PvAkt'><center id='PvAkt'></center></pre></bdo></b><th id='PvAkt'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='PvAkt'><tfoot id='PvAkt'></tfoot><dl id='PvAkt'><fieldset id='PvAkt'></fieldset></dl></div>

                • <bdo id='PvAkt'></bdo><ul id='PvAkt'></ul>
                    <tbody id='PvAkt'></tbody>

                        <tfoot id='PvAkt'></tfoot><legend id='PvAkt'><style id='PvAkt'><dir id='PvAkt'><q id='PvAkt'></q></dir></style></legend>
                        • <small id='PvAkt'></small><noframes id='PvAkt'>

                        • 主站蜘蛛池模板: 精品一区二区三区四区在线 | 成人影院在线观看 | 亚洲色图婷婷 | 91精品久久久久久久久久 | 国产精品1区| 一级特黄色毛片 | 午夜影院污 | 久草精品视频 | 欧美久久久久久 | 成av在线 | h视频免费看 | 亚洲欧美成人影院 | 久久久一区二区三区 | 成人午夜性成交 | 亚洲69p| 在线成人 | 日日摸日日添日日躁av | 亚洲第一网站 | 成人免费在线视频 | 国产一区二区小视频 | 欧美多人在线 | 日韩激情视频一区 | 日本亚洲欧美 | 麻豆av网站| 精品一区二区三区不卡 | 99国内精品 | 久久久久久亚洲精品 | 国产yw851.c免费观看网站 | 久久国产精品亚洲 | 国产区免费视频 | 日韩精品 电影一区 亚洲 | 日韩看片 | 国产精品色婷婷久久58 | 99这里只有精品 | 国内自拍偷拍一区 | 国产亚洲精品久久久久久牛牛 | 国产目拍亚洲精品99久久精品 | 久久精品视频一区二区三区 | 91视频免费观看 | 国精久久 | 97成人免费|