OpenResty配置多域名反向代理

本文介绍如何在单台服务器上使用Nginx配置多个子系统的反向代理,包括nginx.conf和reverse-proxy.conf的详细配置,实现域名访问不同后端服务。
摘要由CSDN通过智能技术生成

今天介绍一下单台服务器上面,配置多台子系统的反向代理配置(域名访问)。下面看一下详细的配置。

nginx.conf配置

#user  nobody;
worker_processes  1;

error_log  logs/error.log  notice;
pid        logs/nginx.pid;
worker_rlimit_nofile 65535;

events {
    use epoll;
    worker_connections  65535;
}

env BLOGAPP_PATH;

http {
    include       mime.types;
    default_type  application/octet-stream;

    include /home/nginx/config/conf.d/reverse-proxy.conf;

    sendfile        on;
    keepalive_timeout  65;
    gzip  on;

    client_max_body_size 50m; #缓冲区代理缓冲用户端请求的最大字节数,可以理解为保存到本地再传给用户
    client_body_buffer_size 256k;
    client_header_timeout 3m;
    client_body_timeout 3m;
    send_timeout 3m;

    proxy_connect_timeout 300s; #nginx跟后端服务器连接超时时间(代理连接超时)
    proxy_read_timeout 300s; #连接成功后,后端服务器响应时间(代理接收超时)
    proxy_send_timeout 300s;
    proxy_buffer_size 64k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小
    proxy_buffers 4 32k; #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
    proxy_busy_buffers_size 64k; #高负荷下缓冲大小(proxy_buffers*2)
    proxy_temp_file_write_size 64k; #设定缓存文件夹大小,大于这个值,将从upstream服务器传递请求,而不缓冲到磁盘
    proxy_ignore_client_abort on; #不允许代理端主动关闭连接

    lua_shared_dict configCache 10m;

    server {
        listen       80;
        server_name  localhost;

        charset utf-8;

        location / {
            root html;
            index index.html index.htm;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

    }

}

上面的配置OpenResty和Nginx的配置是类似的,上面引用了一个reverse-proxy.conf文件,里面是配置了详细的代理的信息。

reverse-proxy.conf配置

server {
    listen 80;
    server_name cas.moguhu.com;
    location / {
        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_pass http://127.0.0.1:8080;
        # proxy_pass http://192.168.10.40:9100; # 如果是转发到其它主机
    }
    access_log /var/logs/nginx/cas.moguhu.com_access.log;
}

server {
    listen 80;
    server_name uc.moguhu.com;
    location / {
        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_pass http://127.0.0.1:8081;
        # proxy_pass http://192.168.10.50:9101; # 如果是转发到其它主机
    }
    access_log /var/logs/nginx/uc.moguhu.com_access.log;
}

通过上面的配置就可以完成对后端服务的反向代理了。


链接:http://moguhu.com/article/detail?articleId=79

### 如何在1Panel中设置反向代理 #### 使用OpenResty作为反向代理工具 当使用1Panel进行服务器管理和应用部署时,推荐采用内置的OpenResty配置反向代理[^2]。这是因为1Panel本身集成了Docker环境以及OpenResty(基于Nginx),能够有效避免与其他软件如Nginx Proxy Manager可能产生的端口冲突问题。 #### 创建反向代理实例 为了实现有效的反向代理,在1Panel界面内新建一个反向代理服务项。此过程涉及指定目标应用程序的实际IP地址和监听端口号;如果是在同一台机器上运行的服务,则通常可利用`127.0.0.1:<port>`的形式指向内部容器化应用[^3]。 #### 处理HTTPS需求 对于需要启用SSL/TLS加密传输的应用场景,比如Bitwarden密码管理器,除了确保拥有合法有效的SSL证书外,还需正确配置域名解析并完成必要的认证流程。这一步骤可以通过第三方服务商提供的API接口自动化处理,或是手动上传已获取的公钥/私钥文件至1Panel平台完成绑定操作。 #### 自定义HTTP头部信息 有时为了让后端服务能识别原始请求来源,可以在1Panel中的反向代理设置里加入特定的HTTP Header字段传递机制。例如,通过设定X-Forwarded-Host等标准协议支持的数据项,使得下游Web服务器可以获得更完整的上下文信息用于日志记录或权限验证逻辑判断[^5]。 ```bash 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; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值