MTLSPolicyConflict
此消息仅会在不使用自动双向 TLS 的服务网格上发生。
考虑使用以下 的 Istio 网格:
此示例中,您可以通过以下两种方式之一解决此问题: 您可以降低网格策略的双向 TLS 要求以接收明文流量(可能需要完全删除网格策略), 或者可以创建相应的目标规则以要求网格内的流量使用双向 TLS:
为了有效解决双向 TLS 冲突,加深对目标规则和策略是如何影响到达服务的流量的理解会很有帮助。 考虑一个在 my-namespace
命名空间中的 my-service
示例服务。 要确定哪个策略对象应用于 my-service
,以下资源将按序匹配:
- 在命名空间
my-namespace
中,指定target
为my-service
的策略。 - 名为
default
的网格策略资源。
- 命名空间 中,匹配主机
my-service.my-namespace.svc.cluster.local
的目标规则, 这可能是完全匹配或通配符匹配。还要注意,控制配置资源可见性的exportTo
字段将被忽略,因为与源服务相同的命名空间中的资源始终可见。 - 命名空间
my-namespace
中,匹配主机my-service.my-namespace.svc.cluster.local
的目标规则, 这可能是完全匹配或通配符匹配。请注意,exportTo
字段必须定义此资源为公共资源(例如,它取值为"*"
或未指定),以便进行匹配。 - 根命名空间(默认为
istio-system
)中匹配主机my-service.my-namespace.svc.cluster.local
的目标规则。 根命名空间由 的rootNamespace
属性控制。请注意,exportTo
字段必须定义此资源为公共资源(例如,它取值为"*"
或未指定),以便进行匹配。
最后请注意,遵循这些规则时,Istio 不会应用任何继承概念。第一个符合匹配条件的资源将被使用。
检查输出信息,您将看到类似下面的信息:
- 目标规则
istio-system/default-rule
,它要求到达myhost.my-namespace.svc.cluster.local:8080
主机的流量使用双向 TLS。
您可以通过执行以下任一操作来解决冲突:
- 修改策略资源
my-namespace/my-policy
以将双向 TLS 作为身份验证模式。 通常,可以通过在资源中添加一个peer
属性来实现,其子属性为mtls
。您可以在 策略对象参考中阅读有关策略对象的更多信息。 - 修改目标规则
istio-system/default-rule
,删除ISTIO_MUTUAL
以不使用双向 TLS。 请注意,default-rule
在istio-system
命名空间中, 默认情况下istio-system
命名空间被认为是配置的根命名空间(尽管可以通过资源中的rootNamespace
属性来覆盖它)。 这意味着此目标规则可能会影响网格中的所有其他服务。 - 在与服务所在同一命名空间(本例中为
my-namespace
)中,添加新的目标规则,并且不要将流量策略定义为 。 由于此规则与服务位于同一命名空间中,因此它将覆盖全局目标规则istio-system/default-rule
。