宫殿Linux板Nginx反向代理设置方法

原创
小哥 3年前 (2022-11-02) 阅读数 81 #PHP
文章标签 PHP

Nginx作为web服务器一个重要的功能就是高性能反向代理。当然你也可以使用Nginx配置正向代理,本文是介绍如何通过 宝塔主机面板 的网站配置nginx的反向代理。nginx反向代理的指令不需要新增额外的模块,默认自proxy_pass指令,只需要修改配置文件就可以实现反向代理。

首先在代理的机器上加入,你要进行反代的域名↓(如图所示)

然后在返回面板,点击网站设置刚刚你要反代的域名


点击反向代理,$host是表示,任意的比如1.bt.cn,2.bt.cn,3.bt.cn都是按照域名的主机头来的,也可以指定一个域名,比如 www.bt.cn ,建议使用$host


开启缓存后配置如下:
默认的配置有个地方是不对的,缓存清理要放在反代规则下面,放在上面是不能清理的。
修正好的配置你可以参考一下的。

  1. server

  2. {

  3. listen 80;

  4. server_name bt.cn www.bt.cn *.bt.cn;

  5. index index.php index.html;

  6. root /www/wwwroot/bt.cn;

  7. SSL-START SSL相关配置,请勿删除或修改下一行带注释的404规则

  8. error_page 404/404.html;

  9. SSL-END

  10. ERROR-PAGE-START  错误页配置,可以注释、删除或修改

  11. error_page 404 /404.html;

  12. error_page 502 /502.html;

  13. ERROR-PAGE-END

  14. PHP-INFO-START  PHP引用配置,可以注释或修改

  15. PROXY-START

  16. location /

  17. {

  18. proxy_pass http://125.88.182.170;

  19. proxy_set_header Host $host;

  20. proxy_set_header X-Real-IP $remote_addr;

  21. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

  22. proxy_set_header REMOTE-HOST $remote_addr;

  23. 持久化连接相关配置

  24. proxy_connect_timeout 30s;

  25. proxy_read_timeout 86400s;

  26. proxy_send_timeout 30s;

  27. proxy_http_version 1.1;

  28. proxy_set_header Upgrade $http_upgrade;

  29. proxy_set_header Connection "upgrade";

  30. add_header X-Cache $upstream_cache_status;

  31. expires max;

  32. }

  33. 缓存清理必须放在这里才可以用到,这个清理方式就是http://url/purge/index.html

  34. location ~ /purge(/.*) {

  35. allow       218.85.152.11;#你自己的上网IP

  36. allow       127.0.0.1;#本地计划任务清理可用

  37. allow       0.0.0.0/24;#全部IP可以清理缓存

  38. deny        all;

  39. proxy_cache_purge cache_one cache_one $1$is_args$args;

  40. access_log  /www/wwwlogs/bt.cn_purge_cache.log;

  41. }

  42. location ~ .*.(html|htm|txt|php|jsp|cgi|asp|aspx|flv|swf|xml)?$

  43. {

  44. proxy_set_header Host $host;

  45. proxy_set_header X-Real-IP $remote_addr;

  46. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

  47. proxy_set_header REMOTE-HOST $remote_addr;

  48. proxy_pass http://125.88.182.170;

  49. }

  50. location ~ .*.(js|css|json|md|csv|log|conf|vue|jpg|jpeg|gif|png|tif|tiff|bmp|svg|psd|ico|tga|imb|mp3|mp4|avi|mpeg|rm|ra|ogg|wav|wmv|rmi|aac|rmvb|mkv|flv|swf|mov|movie|exe|ios|apk|ipa|pxl|sis|cab|deb|rar|zip|gzip|tar|7z|bzip2|dmg|gz|wim|tbz|tpz|z|jar|ttf|otf|woff|woff2|eot|sfnt)?$

  51. {

  52. proxy_set_header Host $host;

  53. proxy_set_header X-Real-IP $remote_addr;

  54. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

  55. proxy_set_header REMOTE-HOST $remote_addr;

  56. proxy_pass http://125.88.182.170;

  57. 缓存相关配置

  58. proxy_cache cache_one;

  59. proxy_cache_key $host$request_uri$is_args$args;

  60. proxy_cache_valid 200 304 301 302 1h;

  61. expires max;

  62. }

  63. PROXY-END

  64. include enable-php-72.conf;

  65. PHP-INFO-END

  66. REWRITE-START URL重写规则引用,修改后将导致面板设置的伪静态规则失效

  67. include /www/server/panel/vhost/rewrite/bt.cn.conf;

  68. REWRITE-END

  69. 禁止访问的文件或目录

  70. location ~ ^/(.user.ini|.htaccess|.git|.svn|.project|LICENSE|README.md)

  71. {

  72. return 444;

  73. }

  74. 一键申请SSL证书验证目录相关设置

  75. location ~ .well-known{

  76. allow all;

  77. }

  78. access_log  /www/wwwlogs/bt.cn.log;

  79. error_log  /www/wwwlogs/bt.cn.error.log;

  80. }

复制代码

那么加入源站点开启了强制https的话配置如下即可

  1. server

  2. {

  3. listen 80;

  4. server_name bt.cn www.bt.cn *.bt.cn;

  5. index index.php index.html;

  6. root /www/wwwroot/bt.cn;

  7. SSL-START SSL相关配置,请勿删除或修改下一行带注释的404规则

  8. error_page 404/404.html;

  9. SSL-END

  10. ERROR-PAGE-START  错误页配置,可以注释、删除或修改

  11. error_page 404 /404.html;

  12. error_page 502 /502.html;

  13. ERROR-PAGE-END

  14. PHP-INFO-START  PHP引用配置,可以注释或修改

  15. PROXY-START

  16. location /

  17. {

  18. proxy_pass https://125.88.182.170:443;

  19. proxy_set_header Host $host;

  20. proxy_set_header X-Real-IP $remote_addr;

  21. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

  22. proxy_set_header REMOTE-HOST $remote_addr;

  23. 持久化连接相关配置

  24. proxy_connect_timeout 30s;

  25. proxy_read_timeout 86400s;

  26. proxy_send_timeout 30s;

  27. proxy_http_version 1.1;

  28. proxy_set_header Upgrade $http_upgrade;

  29. proxy_set_header Connection "upgrade";

  30. add_header X-Cache $upstream_cache_status;

  31. expires max;

  32. }

  33. 缓存清理必须放在这里才可以用到,这个清理方式就是http://url/purge/index.html

  34. location ~ /purge(/.*) {

  35. allow       218.85.152.11;#你自己的上网IP

  36. allow       127.0.0.1;#本地计划任务清理可用

  37. allow       0.0.0.0/24;#全部IP可以清理缓存

  38. deny        all;

  39. proxy_cache_purge cache_one cache_one $1$is_args$args;

  40. access_log  /www/wwwlogs/bt.cn_purge_cache.log;

  41. }

  42. location ~ .*.(html|htm|txt|php|jsp|cgi|asp|aspx|flv|swf|xml)?$

  43. {

  44. proxy_set_header Host $host;

  45. proxy_set_header X-Real-IP $remote_addr;

  46. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

  47. proxy_set_header REMOTE-HOST $remote_addr;

  48. proxy_pass https://125.88.182.170:443;

  49. }

  50. location ~ .*.(js|css|json|md|csv|log|conf|vue|jpg|jpeg|gif|png|tif|tiff|bmp|svg|psd|ico|tga|imb|mp3|mp4|avi|mpeg|rm|ra|ogg|wav|wmv|rmi|aac|rmvb|mkv|flv|swf|mov|movie|exe|ios|apk|ipa|pxl|sis|cab|deb|rar|zip|gzip|tar|7z|bzip2|dmg|gz|wim|tbz|tpz|z|jar|ttf|otf|woff|woff2|eot|sfnt)?$

  51. {

  52. proxy_set_header Host $host;

  53. proxy_set_header X-Real-IP $remote_addr;

  54. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

  55. proxy_set_header REMOTE-HOST $remote_addr;

  56. proxy_pass https://125.88.182.170:443;

  57. 缓存相关配置

  58. proxy_cache cache_one;

  59. proxy_cache_key $host$request_uri$is_args$args;

  60. proxy_cache_valid 200 304 301 302 1h;

  61. expires max;

  62. }

  63. PROXY-END

  64. include enable-php-72.conf;

  65. PHP-INFO-END

  66. REWRITE-START URL重写规则引用,修改后将导致面板设置的伪静态规则失效

  67. include /www/server/panel/vhost/rewrite/bt.cn.conf;

  68. REWRITE-END

  69. 禁止访问的文件或目录

  70. location ~ ^/(.user.ini|.htaccess|.git|.svn|.project|LICENSE|README.md)

  71. {

  72. return 444;

  73. }

  74. 一键申请SSL证书验证目录相关设置

  75. location ~ .well-known{

  76. allow all;

  77. }

  78. access_log  /www/wwwlogs/bt.cn.log;

  79. error_log  /www/wwwlogs/bt.cn.error.log;

  80. }

版权声明

所有资源都来源于爬虫采集,如有侵权请联系我们,我们将立即删除

热门