Nginx 作為 web 服務(wù)器一個重要的功能就是反向代理。
下面是配置 Nginx 作為 tornado 的反向代理的設(shè)置:
upstream tornado { server 127.0.0.1:8888; } server { listen 80; root /root/nmapp2_venv; index index.py index.html; server_name server; location / { #if (!-e $request_filename) { # rewrite ^/(.*)$ /index.py/$1 last; #} } location ~ /index\.py { proxy_pass_header Server; proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Scheme $scheme; proxy_pass http://tornado; } }
Nginx 反向代理的指令不需要新增額外的模塊,默認自帶 proxy_pass 指令,只需要修改配置文件就可以實現(xiàn)反向代理。
再舉一個例子吧。比如要配置后端跑 apache 服務(wù)的 ip 和端口,也就是說,我們的目標是實現(xiàn)通過 http://ip:port 能訪問到你的網(wǎng)站。
只要新建一個 vhost.conf,加入如下內(nèi)容(記得修改 ip 和域名為你的 ip 和域名)。修改nginx.conf,添加 include quancha.conf 到http{}段, reload nginx就可以了。
Nginx 反向代理模板:
## Basic reverse proxy server ## upstream apachephp { server ip:8080; #Apache } ## Start www.JunYun.wang ## server { listen 80; server_name www.JunYun.wang; access_log logs/JunYunwang.access.log main; error_log logs/JunYunwang.error.log; root html; index index.html index.htm index.php; ## send request back to apache ## location / { proxy_pass http://127.0.0.1:8080; #Proxy Settings client_max_body_size 1024m; client_body_buffer_size 512k; proxy_redirect off; 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_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504; proxy_max_temp_file_size 1024m; proxy_connect_timeout 600; proxy_send_timeout 600; proxy_read_timeout 6000; proxy_buffer_size 32k; proxy_buffers 4 64k; proxy_busy_buffers_size 128k; proxy_temp_file_write_size 512k; } }這就完成了 Nginx 反向代理配置。