一.不通过浏览器获取公网 IP
有的时候我们的计算机处于受限状态,不能使用浏览器或者 HTTP 协议。
也就不能使用类似:
curl ifconfig.io
之类的命令来获取公网 IP。
但其实可以不通过浏览器,而是通过 DNS 来获取公网 IP,使用如下命令:
dig @ns1.google.com TXT o-o.myaddr.l.google.com +short
# 或者:nslookup -type=TXT o-o.myaddr.l.google.com ns1.google.com
其它的 DNS 提供商也可以:
# OpenDNS
dig myip.opendns.com @resolver1.opendns.com +short
# 或者:nslookup myip.opendns.com resolver1.opendns.com
# Akamai
dig whoami.akamai.net. @ns1-1.akamaitech.net. +short
# 或者:nslookup whoami.akamai.net. ns1-1.akamaitech.net.
这些命令会返回公网 IP 的原理是:
Google 等公司会编写程序,监听在它们类似 o-o.myaddr.l.google.com 的地址上。只要有请求,就会将请求的源 IP 地址作为数据直接返回。
二.nginx设置反向代理,如何获取真实客户端ip
upstream这个模块提供一个简单方法来实现在轮询和客户端IP之间的后端服务器负荷平衡。
upstream abc.com {
server 127.0.0.1:8080;
server 127.0.0.1:80;
server 127.0.0.1:8000;
}
server {
listen 80;
server_name www.test.com;
location / {
proxy_pass http://abc.com;
proxy_set_header Host $host;#保留代理之前的host
proxy_set_header X-Real-IP $remote_addr;#保留代理之前的真实客户端ip
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header HTTP_X_FORWARDED_FOR $remote_addr;#在多级代理的情况下,记录每次代理之前的客户端真实ip
proxy_set_header X-Forwarded-Proto $scheme;
proxy_redirect default;#指定修改被代理服务器返回的响应头中的location头域跟refresh头域数值
}
}
各参数的含义如下所示。
-
Host包含客户端真实的域名和端口号;
-
X-Real-IP表示客户端真实的IP;
-
X-Forwarded-For这个Header和X-Real-IP类似,但它在多层代理时会包含真实客户端及中间每个代理服务器的IP
-
X-Forwarded-Proto表示客户端真实的协议(http还是https);
后记:
记住:你比别人强的地方,不是你做过多少年的CRUD工作,而是你比别人掌握了更多深入的技能。不要总停留在CRUD的表面工作,理解并掌握底层原理并熟悉源码实现,并形成自己的抽象思维能力,做到灵活运用,才是你突破瓶颈,脱颖而出的重要方向!
你在刷抖音,玩游戏的时候,别人都在这里学习,成长,提升,人与人最大的差距其实就是思维。你可能不信,优秀的人,总是在一起。。