nginx通过云负载均衡后作反向代理并限制制定ip访问

本文介绍了一种在使用私有云负载均衡器(SLB)和Nginx反向代理的情况下,如何仅允许两个特定IP地址访问指定域名的方法。通过设置Nginx中的代理头信息并检查HTTP_X_FORWARDED_FOR字段来实现这一目标。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有个需求,需要特定的2个ip才能访问指定域名,但是使用私有云的slb负载后透过的ip,指向nginx反向代理后,使用nginx的ip限制无法控制ip访问。
试了很多办法但是没有效果,后来尝试了以下方式,发现可以了。

server {
        listen       80;
        server_name   xxx.xxx.xxx;

        set $x $remote_addr;
        if ($http_ali_cdn_real_ip) {
                set $x $http_ali_cdn_real_ip;
        }
#cms
       location ^~ /cms {
            proxy_pass http://pool_yyyy_8000/;
            proxy_set_header  Host  $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header REMOTE-HOST $remote_addr;
            client_max_body_size    100m;
            set $allow true;
            if ($http_x_forwarded_for !~ "xxx.xxx.xxx.xxx|yyy.yyy.yyy.yyy") {
                set $allow false;
            }
            if ($allow = false) {
                return 403;
            }
        }
}









本文转自 wangpengtai  51CTO博客,原文链接:http://blog.51cto.com/wangpengtai/2055573,如需转载请自行联系原作者
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值