更新时间:2024-02-19 GMT+08:00
分享

所有Pod是否都注入了sidecar

问题描述

Service管理的所有Pod都必须存在istio-proxy容器,否则报此异常。

修复指导

  1. 登录ASM控制台,选择服务所在网格。单击左侧导航中的“网格配置”,选择“sidecar管理”页签,检查服务所在命名空间是否已注入sidecar。

    • 否,执行2
    • 是,执行3

  2. 注入sidecar。

    可参考sidecar注入,为命名空间下所有工作负载关联的Pod注入sidecar。或者只为某个工作负载注入sidecar,方法如下:

    1. 为工作负载所在命名空间打上istio-injection=enabled标签。

      kubectl label ns <namespace> istio-injection=enabled

    2. 在CCE控制台为工作负载添加annotations字段。
            annotations:
              sidecar.istio.io/inject: 'true'

    您可以单击Installing the Sidecar了解更多sidecar注入的知识。

  3. 如果网格已经开启了命名空间注入,但是Pod未注入sidecar,需要在CCE控制台手动重启Pod。方法如下:

    登录CCE控制台,在工作负载所在行,单击操作列的“更多 > 重新部署”。

  4. 检查工作负载是否配置了主机网络模式。方法如下:

    登录CCE控制台,在工作负载所在行,单击操作列的“更多 > 编辑YAML”,查看是否配置了spec.template.spec.hostNetwork: true。如果是,请确认是否可将该字段删除或者配置为false,否则不允许注入sidecar。

  5. 检查网格实例数量是否已经超出限额。

    如果实例总数已经超出 200,那么超出部分的实例将无法注入sidecar。

分享:

    相关文档

    相关产品