更改数据库权限扩容后后端请求不稳定
先前为后端扩容多实例后,发现前端请求后端不稳定
为了实现多实例容错,收缩数据库权限,决定对扩容然后更换新的数据库账号,旧的不变。实例扩容后,发现前端访问后端不稳定,时有报错。
问题描述
先前为后端扩容多实例后,发现前端请求后端不稳定。大概就是隔一段时间请求会报错没有权限,过一段时间请求就正常。
因为老的实例没有更换新的数据库账号,因此怀疑由于,是因为nginx rr调度,让一部分请求去到旧实例上,一部分请求去到新实例上。
后来ssh到新的实例上,直接请求发现正常请求。后来就怀疑是不是新实例ip没有被nginx解析出来。
最后发现在新实例上,连续请求会间歇性失败,基本确定是新实例后端的问题。
但是很久都没找到原因,只能重启看看。
发现重启居然直接修复了!!!
原因分析:
应该是因为先后步骤错了,应该先注册mysql账号,再申请账号权限,再部署新实例。
但是我们先部署新实例再申请权限,由于conn是有缓存的,旧缓存上连接权限没有更新,导致一部分连接有权限一部分没有,直接导致间歇性不能使用。
解决方案:
- 先确定新账户权限再使用
- 注意对链接缓存的清理
- 重启