宝塔Linux面板Nginx反向代理配置方法

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.    
  8.     #SSL-START SSL相关配置,请勿删除或修改下一行带注释的404规则
  9.     #error_page 404/404.html;
  10.     #SSL-END
  11.    
  12.     #ERROR-PAGE-START  错误页配置,可以注释、删除或修改
  13.     error_page 404 /404.html;
  14.     error_page 502 /502.html;
  15.     #ERROR-PAGE-END
  16.    
  17.     #PHP-INFO-START  PHP引用配置,可以注释或修改
  18.     #PROXY-START
  19.     location /
  20.     {
  21.         proxy_pass http://125.88.182.170;
  22.         proxy_set_header Host $host;
  23.         proxy_set_header X-Real-IP $remote_addr;
  24.         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  25.         proxy_set_header REMOTE-HOST $remote_addr;
  26.                
  27.         #持久化连接相关配置
  28.         proxy_connect_timeout 30s;
  29.         proxy_read_timeout 86400s;
  30.         proxy_send_timeout 30s;
  31.         proxy_http_version 1.1;
  32.         proxy_set_header Upgrade $http_upgrade;
  33.         proxy_set_header Connection "upgrade";
  34.         
  35.         add_header X-Cache $upstream_cache_status;
  36.         
  37.         expires max;
  38.     }
  39.    
  40.     #缓存清理必须放在这里才可以用到,这个清理方式就是http://url/purge/index.html
  41.     location ~ /purge(/.*) {
  42.         #allow       218.85.152.11;#你自己的上网IP#
  43.         #allow       127.0.0.1;#本地计划任务清理可用#
  44.         #allow       0.0.0.0/24;#全部IP可以清理缓存#
  45.         deny        all;
  46.         proxy_cache_purge cache_one cache_one $1$is_args$args;
  47.         #access_log  /www/wwwlogs/bt.cn_purge_cache.log;
  48.     }
  49.    
  50.     location ~ .*\.(html|htm|txt|php|jsp|cgi|asp|aspx|flv|swf|xml)?$
  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.     }
  59.    
  60.     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)?$
  61.     {
  62.         proxy_set_header Host $host;
  63.         proxy_set_header X-Real-IP $remote_addr;
  64.         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  65.         proxy_set_header REMOTE-HOST $remote_addr;
  66.         proxy_pass http://125.88.182.170;
  67.         
  68.         #缓存相关配置
  69.         proxy_cache cache_one;
  70.         proxy_cache_key $host$request_uri$is_args$args;
  71.         proxy_cache_valid 200 304 301 302 1h;
  72.         
  73.         expires max;
  74.     }
  75.     #PROXY-END
  76.  
  77.         include enable-php-72.conf;
  78.     #PHP-INFO-END
  79.    
  80.     #REWRITE-START URL重写规则引用,修改后将导致面板设置的伪静态规则失效
  81.     include /www/server/panel/vhost/rewrite/bt.cn.conf;
  82.     #REWRITE-END
  83.    
  84.     #禁止访问的文件或目录
  85.     location ~ ^/(\.user.ini|\.htaccess|\.git|\.svn|\.project|LICENSE|README.md)
  86.     {
  87.         return 444;
  88.     }
  89.    
  90.     #一键申请SSL证书验证目录相关设置
  91.     location ~ \.well-known{
  92.         allow all;
  93.     }
  94.    
  95.     access_log  /www/wwwlogs/bt.cn.log;
  96.     error_log  /www/wwwlogs/bt.cn.error.log;
  97. }
复制代码

那么加入源站点开启了强制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.    
  8.     #SSL-START SSL相关配置,请勿删除或修改下一行带注释的404规则
  9.     #error_page 404/404.html;
  10.     #SSL-END
  11.    
  12.     #ERROR-PAGE-START  错误页配置,可以注释、删除或修改
  13.     error_page 404 /404.html;
  14.     error_page 502 /502.html;
  15.     #ERROR-PAGE-END
  16.    
  17.     #PHP-INFO-START  PHP引用配置,可以注释或修改
  18.     #PROXY-START
  19.     location /
  20.     {
  21.         proxy_pass https://125.88.182.170:443;
  22.         proxy_set_header Host $host;
  23.         proxy_set_header X-Real-IP $remote_addr;
  24.         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  25.         proxy_set_header REMOTE-HOST $remote_addr;
  26.                
  27.         #持久化连接相关配置
  28.         proxy_connect_timeout 30s;
  29.         proxy_read_timeout 86400s;
  30.         proxy_send_timeout 30s;
  31.         proxy_http_version 1.1;
  32.         proxy_set_header Upgrade $http_upgrade;
  33.         proxy_set_header Connection "upgrade";
  34.         
  35.         add_header X-Cache $upstream_cache_status;
  36.         
  37.         expires max;
  38.     }
  39.    
  40.     #缓存清理必须放在这里才可以用到,这个清理方式就是http://url/purge/index.html
  41.     location ~ /purge(/.*) {
  42.         #allow       218.85.152.11;#你自己的上网IP#
  43.         #allow       127.0.0.1;#本地计划任务清理可用#
  44.         #allow       0.0.0.0/24;#全部IP可以清理缓存#
  45.         deny        all;
  46.         proxy_cache_purge cache_one cache_one $1$is_args$args;
  47.         #access_log  /www/wwwlogs/bt.cn_purge_cache.log;
  48.     }
  49.    
  50.     location ~ .*\.(html|htm|txt|php|jsp|cgi|asp|aspx|flv|swf|xml)?$
  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.     }
  59.    
  60.     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)?$
  61.     {
  62.         proxy_set_header Host $host;
  63.         proxy_set_header X-Real-IP $remote_addr;
  64.         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  65.         proxy_set_header REMOTE-HOST $remote_addr;
  66.         proxy_pass https://125.88.182.170:443;
  67.         
  68.         #缓存相关配置
  69.         proxy_cache cache_one;
  70.         proxy_cache_key $host$request_uri$is_args$args;
  71.         proxy_cache_valid 200 304 301 302 1h;
  72.         
  73.         expires max;
  74.     }
  75.     #PROXY-END
  76.  
  77.         include enable-php-72.conf;
  78.     #PHP-INFO-END
  79.    
  80.     #REWRITE-START URL重写规则引用,修改后将导致面板设置的伪静态规则失效
  81.     include /www/server/panel/vhost/rewrite/bt.cn.conf;
  82.     #REWRITE-END
  83.    
  84.     #禁止访问的文件或目录
  85.     location ~ ^/(\.user.ini|\.htaccess|\.git|\.svn|\.project|LICENSE|README.md)
  86.     {
  87.         return 444;
  88.     }
  89.    
  90.     #一键申请SSL证书验证目录相关设置
  91.     location ~ \.well-known{
  92.         allow all;
  93.     }
  94.    
  95.     access_log  /www/wwwlogs/bt.cn.log;
  96.     error_log  /www/wwwlogs/bt.cn.error.log;
  97. }
### 回答1: Nginx是一款高性能的Web服务器和反向代理服务器,可以用来处理静态文件、动态文件、HTTP请求和负载均衡等。在Linux系统中,配置Nginx反向代理可以实现多个Web服务器的负载均衡和高可用性,提高Web应用的性能和稳定性。 要配置Nginx反向代理,需要先安装Nginx软件包,并编辑Nginx配置文件。在配置文件中,需要指定反向代理的目标服务器和端口号,以及反向代理的监听端口和域名等信息。还可以配置缓存、SSL证书、HTTP头等选项,以满足不同的需求。 配置完成后,需要重新加载Nginx配置文件,使其生效。可以使用Nginx的命令行工具来检查配置文件的语法和启动、停止、重启Nginx服务。在反向代理生效后,可以通过访问Nginx的监听端口和域名来访问目标服务器上的Web应用。 总之,Nginx反向代理配置Linux系统中Web服务器和负载均衡的重要组成部分,可以提高Web应用的性能和可用性,是Web开发人员和系统管理员必须掌握的技能之一。 ### 回答2: Nginx反向代理Nginx服务器所提供的高级功能之一,它可以将用户请求反向代理到不同的服务器上,以便在网络拓扑结构中,像隐藏真实服务器一样的方式进行访问。当客户端发起请求时,请求会首先进入Nginx服务器,然后Nginx服务器通过配置将请求转发到真实的服务器上。 反向代理可以提高网站的性能和安全性,其中之一的原因是因为它可以提供负载均衡,将流量均衡地分配到多个服务器上,从而降低单个服务器的负载压力。另外,反向代理还可以提供安全性,并通过网络分发内容来减轻网络流量,降低延迟时间。 在Linux服务器上进行Nginx反向代理配置的步骤如下: 1. 安装Nginx服务器,如果您的Linux服务器上没有安装Nginx,请使用apt-get或yum命令进行安装; 2. 配置Nginx反向代理,需要编辑Nginx配置文件nginx.conf,通过编辑upstream模块中的server列表设置真实服务器的IP地址和端口号,设置反向代理的通信协议和其他参数,如下面的示例: ``` http { upstream backend { server 192.168.1.10:80 weight=5; server 192.168.1.11:80 weight=5; } server { listen 80; server_name localhost; location / { proxy_pass http://backend; } } } ``` 上述配置文件中,我们定义了反向代理的后端服务器地址和端口号,以及设置了反向代理通信协议为http。另外,在server部分中,listen用于设置Nginx反向代理所监听的端口号,server_name用于设置使用的域名,location用于设置需要被代理的请求URL。 3. 保存并重新启动Nginx服务器,编辑结束后需要保存并退出nginx.conf,使用命令service nginx restart来重启Nginx服务器,使其立即生效。 通过以上步骤,我们就可以成功地在Linux服务器上进行Nginx反向代理配置反向代理可以提供更高效的性能和更好的安全性。这是企业网站架构中必不可少的一部分。 ### 回答3: Nginx是一个高性能的Web服务器和反向代理服务器,许多互联网公司都采用Nginx作为Web服务器来提供动态和静态Web内容。反向代理指的是客户端请求不是直接发送给资源服务器,而是通过反向代理服务器进行处理,这样可以有效提高Web服务器的性能和安全性。下面来讲一下如何在Linux系统上配置Nginx反向代理。 1. 安装NginxLinux系统上安装Nginx非常简单,只需要在终端中输入以下命令: sudo apt-get update sudo apt-get install nginx 2. 配置反向代理Nginx配置文件中添加反向代理配置Nginx配置文件通常位于/etc/nginx下,我们可以编辑/etc/nginx/sites-available/default文件。具体配置如下: server { listen 80; server_name www.example.com; location / { proxy_pass http://localhost:8080; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } } 其中,listen指定监听一个端口(如80),server_name指定服务器名字(如www.example.com),location表示要代理的URL,proxy_pass指定要反向代理的服务器地址(如http://localhost:8080)。 3. 重启Nginx 在完成反向代理配置后,需要重启Nginx,执行以下命令: sudo service nginx restart 4. 配置HTTPS 如果需要在网站上使用HTTPS,需要添加SSL证书并修改Nginx配置文件。首先,使用以下命令安装SSL证书: sudo apt-get install certbot python-certbot-nginx 之后,执行以下命令以为指定域名添加SSL证书: sudo certbot --nginx -d www.example.com 最后,我们需要将Nginx配置文件中的监听80端口改为443端口,并添加SSL支持。具体的Nginx配置如下: server { listen 443 ssl; server_name www.example.com; ssl_certificate /etc/letsencrypt/live/www.example.com/fullchain.pem; ssl_certificate_key /etc/letsencrypt/live/www.example.com/privkey.pem; location / { proxy_pass http://localhost:8080; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } } 5. 重启Nginx 完成以上所有配置后,执行以下命令以重启Nginx: sudo service nginx restart 总的来说,配置Nginx反向代理并不是很复杂,只要掌握基本的配置方法并按照实际需求进行修改即可。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梅坞茶坊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值