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处理
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
K8S(Kubernetes)是一个开源的容器编排工具,用于自动化部署、扩展和管理容器化应用程序。在K8S中,Node(节点)是指一个运行Kubernetes集群的机器,它可以是物理服务器、虚拟机或者云服务器。 为了设置Node的角色,我们可以通过以下步骤进行操作: 1. 添加Node: 首先,我们需要将一个新的Node添加到已经存在的Kubernetes集群中。这可以通过执行kubectl命令或者API请求来完成。在添加Node时,会生成一个唯一的Node ID,用于识别该Node。 2. 分配角色: 在Kubernetes中,Node有不同的角色,例如Master或者Worker。Master节点用于管理和控制整个集群的操作,而Worker节点用于运行容器工作负载。我们可以通过kubectl命令或者修改Cluster配置文件来分配角色。 3. 配置标签: 为了进一步区分Node,我们可以为其添加标签。标签是键值对的形式,用于根据特定的要求选择Node。例如,我们可以为Node添加标签"environment=production",以指示该Node用于生产环境。 4. 节点亲和性(node affinity)和容忍度(tolerations): 对于特定的工作负载,我们可以配置节点亲和性和容忍度规则,以使其仅在满足特定条件的Node上运行。节点亲和性可以根据标签选择特定的Node,而容忍度则定义了能够容忍的节点条件。 5. 高可用性和自动伸缩: K8S还支持高可用性和自动伸缩功能。通过将多个Master节点配置为高可用模式,可以确保集群的稳定性和可靠性。自动伸缩功能可根据工作负载的变化自动扩展或收缩Node。 通过上述步骤,我们可以轻松地设置K8S的Node角色,并根据需求对Node进行管理和配置。这些步骤还可以根据Kubernetes的版本和部署方式进行细微调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值