+86 135 410 16684Mon. - Fri. 10:00-22:00

使用aws ELB后关于proxy_pass 的域名解析问题

使用aws ELB后关于proxy_pass 的域名解析问题

使用aws ELB后关于proxy_pass 的域名解析问题

最近遇到了一个奇怪的问题,我们的一个需要nginx转发的A接口调用另一个IP服务接口时会报502,但是单独调用IP服务时就OK。并且reload A接口的nginx后,居然就正常了。
看了下A接口的nginx配置
location ^~/api/searchip.htm {
proxy_cache STATIC;
proxy_cache_valid 200 304 301 302 5m;
proxy_cache_key $host$uri$is_args$args;
proxy_pass http://example.ap-southeast-1.elb.amazonaws.com;
}
看起来很正常。
检查error日志发现了一个问题,日志中proxy_pass到后端的IP并不是example.ap-southeast-1.elb.amazonaws.com的当前IP。
在经过分析,找到了原因,example.ap-southeast-1.elb.amazonaws.com是亚马逊的ELB,后端挂着两台服务器作为 后端。由于ELB的IP池是变化的,我们的ELB随着流量扩张收缩后,ELB的IP发生了变化。但是nginx配置proxy_pass的域名并没有被重 新解析。仍然转到老的解析IP去了,因此出现了502。
有两个解决方法:
1、 将proxy_pass的域名改成upstream到具体的IP,因为我们的后端服务器是不变化的。
2、 可以将proxy_pass 后面的域名转为动态的,nginx 默认5分钟会重新解析动态的域名。
类似这样:
location ^~/api/searchip.htm {
proxy_cache STATIC;
proxy_cache_valid 200 304 301 302 5m;
proxy_cache_key $host$uri$is_args$args;
# proxy_pass http://example.ap-southeast-1.elb.amazonaws.com;
resolver 8.8.8.8;
set $IPS test.example.com;
proxy_pass http://$IPS;
}