K8s服务里的sessionAffinity未设置导致的问题

  1. 问题描述:
    一个接口突然不可用,这个接口是个图形验证码接口,分成2步:
    1. 请求http://ip:port/captcha接口,返回:
      	{
      		captcha_id:xxxxx,
      		cpatcha_png:a.png
      	}
      
    2. 根据上一步的cpatcha_png再去请求http://ip:port/captcha/a.png, 第一次可能失败,再次请求就会成功
  2. 解决步骤:
    1. 后端没有修改过相关接口的代码
    2. 前端很长时间都没有修改过代码了
    3. 发现k8s后端相关服务对应的pod由1个变成2个了
      1. 应该是第一次请求http://ip:port/captcha路由到了pod1
      2. 第二次请求http://ip:port/captcha/a.png路由到了pod2
      3. 由于用的captcha框架是把图片放在了内存里的, 本来图片是在pod1里的,请求图片的时候路由到了pod2里,再请求一次,又请求到了pod1里了,所以出现第一次失败,第二次成功的情况
  3. 解决办法
    把服务的sessionAffinitynone改为ClientIP,某个ip的所有请求都由同一个pod处理
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章