nginx 通过域名代理tcp端口

    技术2022-07-11  136

    碰到一种场景,使用nginx进行反向代理tcp端口,网上大部门的设置都是一个端口代理一个端口,没有一个端口通过域名代理后端多个端口的情况。 在sf上面看到一个设置教程,记录下

    只需要修改nginx.conf,添加如下配置即可,

    stream { map $ssl_preread_server_name $name { mysql.test.com mysql; redis.test.com redis; default https_default_backend; } upstream mysql{ server 10.0.0.3:3306; } upstream redis{ server 10.0.0.4:6379; } upstream https_default_backend { server 127.0.0.1:443; } server { listen 10.0.0.1:443; proxy_pass $name; ssl_preread on; } }

    stream 模块可能会没有。百度下nginx 添加stream 模块即可

    stream 是一个单独的模块,不需要放在nginx-http配置中,放在nginx.conf最后即可

    或者

    stream { upstream mysql{ server 10.1.5.3:3306; } upstream redis{ server 10.1.5.4:6379; } map $server_addr $bane { 192.168.168.238 mysql; 192.168.168.239 redis; } server { listen 80; proxy_pass $name; } }

    只需要把map中参数变成域名即可

    参考:

    https://stackoverflow.com/questions/34741571/nginx-tcp-forwarding-based-on-hostname/40135151#40135151

    Processed: 0.011, SQL: 9