开发者社区 > 云原生 > 正文

注册中心用的nacos, 那你们注册信息怎么同步到istio的呢?

注册中心用的nacos, 那你们注册信息怎么同步到istio的呢?

展开
收起
-Feng、冯冯 2023-11-22 08:05:31 126 0
3 条回答
写回答
取消 提交回答
  • 面对过去,不要迷离;面对未来,不必彷徨;活在今天,你只要把自己完全展示给别人看。

    Istio 支持通过MCP协议从 Nacos 注册中心获取服务信息,并将其用于控制平面和数据平面的操作。具体来说,您可以采取以下步骤实现这一目标:

    1. 配置 Istio 控制平面和 Nacos 注册中心之间的 MCP 协议通信,即将 nacos 作为 istio 的 service entry 对象。可以在 istio.meshconfig 中设置 controlPlaneConfig.mcp.servers 字段来指定 Nacos 注册中心的地址。
    2. 在 Nacos 注册中心中添加所需的 Istio Service Entry 对象。例如,可以创建一个名为 bookinfo-gateway 的 Service Entry 对象,并为其配置所需的服务元数据。
    3. 当 Nacos 注册中心中的 Service Entry 对象发生变化时,Istio 将自动接收到相应的变更事件,并更新其内部的数据结构。

    另外,如果Nacos中已经有相关的服务实例的话,可以利用istioctl register命令手动同步到istio.
    注意:由于 Istio 的控制平面和数据平面之间采用了不同的通信机制,因此在将 Nacos 注册中心的信息同步到 Istio 之前,可能需要对现有网络环境进行一定的改造。具体而言,需要在 Nacos 注册中心和 Istio 控制平面之间建立一条可靠的 TCP 连接,以便 MCP 协议能够正常工作。

    2023-11-29 15:14:39
    赞同 展开评论 打赏
  • 在将注册信息从Nacos同步到Istio的过程中,你需要进行一些配置和操作。首先,确保你的Nacos服务器启用了Istio的MCP协议,这可以通过设置nacos.istio.mcp.server.enabled=true来实现。然后,需要修改Istio的配置,使其使用Nacos作为服务发现组件。

    完成这些步骤后,每次有新的服务实例注册到Nacos时,相应的信息就会自动同步到Istio中。这一过程通过Istio-proxy捕获DNS请求并解析自定义的服务信息。同步完成后,你可以在服务的sidecar envoy中看到这些同步下来的服务配置信息。

    这种同步机制是弱一致性的,也就是说,在一定的延迟时间内,可能会存在服务实例信息未能及时更新的情况。因此,如果你的应用对服务发现和调用的实时性有较高要求,可能需要采取额外的措施来保证数据的实时性。

    2023-11-22 10:19:55
    赞同 展开评论 打赏
  • https://mp.weixin.qq.com/s/K-LX241-iwVlpB-hTWnhiw
    可以参考这个。不过理解做灰度不需要nacos的注册服务信息到istio,同步到istio主要是用来让istio下的微服务可以访问nacos下的服务。此回答整理自钉群“Nacos社区群4”

    2023-11-22 08:53:54
    赞同 展开评论 打赏
问答分类:
问答地址:

阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。

相关电子书

更多
workshop专场-微服务专场-开发者动手实践营-微服务-使用Nacos进行服务的动态发现和流量调度 立即下载
Kubernetes上基于Istio体验云原生应用实践 立即下载
Nacos 启航,发布第一个版本, 云原生时代助力用户微服务平台建设 立即下载