昨天测试在群里反应,在beta环境上传附件失败。要到账号,复现了下,发现提示token过期。这里说下beta服务器的架构,两台服务器A和B,HA做负载,项目代码各一份,使用Jenkins部署、Redis、Mysql都在B服务器上,在A服务器Nginx配置上传的链接都打到B服务器上,也就是上传都是在B服务器上,而无需两台服务器都同步。同时为了与线上环境一样,B服务器上的Redis是以sentinel方式连接的,也就是先连接sentinel,再找到master的host和port再连接。
介绍了完了架构,这次拿着过期的token去Redis服务器上找了找,果真没有。奇怪了,正常情况下,一登录,session会存到B服务器上的Redis里的,怎么没有了。而且Redis里的token数量很少,正在测试阶段应该挺多的啊,其他的token去哪了。我打开sentinel的配置文件,发现了问题sentinel monitor mymaster 127.0.0.1 6379 2,也就是通过sentinel方法连接后的master的host为127.0.0.1也即是本机,A服务器上也装有Redis,进去一看,果真上面的数据都在那。于是改成B服务器的IP就好了。
# A服务器上Nginx跳转配置
location /attachment/ {
proxy_pass http://B_HOST:PORT/attachment/;
}