背景
一个nginx的server模块下需要proxy到两个server,所以就通过location的不同路径来区分转发到不同的服务器上。
一开始是这么写的
location / { proxy_pass http://server1/; } location /index { proxy_pass http://server2/; }
但是忘记了server1上有个服务路径是/indexNew,结果就被proxy到了server1,出现404问题,然后紧急修改配置如下:
location /indexNew { proxy_pass http://server1/; } location / { proxy_pass http://server1/; } location /index { proxy_pass http://server2/; }
问题现象
结果请求是到了server1了,但是错误变成,POST not supported
{ "status": 500, "message": "http://172.28.72.117/-Request method 'POST' not supported", "result": {} }
这是当时应用的返回错误,查看nginx也没有报错,很奇怪,看了代码里/indexNew的确是POST方法啊,为啥报错不支持呢。
首先这里补充下location各种写法在nginx里的匹配顺序:
分析
nginx日志也没有报错,就尝试抓包,从nginx到应用的包
通过tcpdump命令抓包
tcpdump -w dataAll_normal.pcap -i eth0 -s0 port 8888
类似上述命令抓包,然后通过wireshark看,发现压根没搜索到/indexNew相关的http流量包。
尝试修改location如下
location /indexNew { proxy_pass http://server1; } location / { proxy_pass http://server1/; } location /index { proxy_pass http://server2/; }
区别仅仅在于/indexNew的proxy_pass最后一个/斜杠去掉了,继续抓包,发现可以搜索到/indexNew的包
说明此次修改正确了。
继续改回错误的,尝试抓包,还是没能搜索到/indexNew的包,然后通过IDE远程debug应用
发现到了应用里的URL压根也没有/indexNew,那当然在wireshark包里搜不到了。。。
是因为nginx转发应用的时候,访问路径就只有 / 了。
而工程中请求路径为 / 的接口的确是GET方法
详细看下location中proxy_pass的语法,的确是这样,proxy_pass最后有/,会把匹配location里的路径去掉,截取后面的URL PATH进行转发。
所以这里一定要注意proxy_pass最后一个/的含义作用,要慎用,它会改变路径请求信息,而不是100%的信息转发。
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。