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

k8s部署的nacos集群,k8s集群之外的服务访问nacos除了8848端口还要暴露什么端口吗?

k8s部署的nacos集群,k8s集群之外的服务访问nacos除了8848端口还要暴露什么端口吗?

展开
收起
青城山下庄文杰 2023-11-20 16:20:42 139 0
2 条回答
写回答
取消 提交回答
  • 面对过去,不要迷离;面对未来,不必彷徨;活在今天,你只要把自己完全展示给别人看。

    在 Kubernetes (K8S) 中部署 Nacos 集群时,默认情况下,Nacos 服务的 API 访问端口为8848。这意味着外部服务可以通过 HTTP(s) 请求访问 Nacos 的服务。
    然而,如果您想要外部服务通过 TCP 连接 Nacos,则还需要暴露其他端口。具体来说,您需要为 Nacos 配置 TCP 防火墙规则,并允许来自外部 IP 地址的 TCP 连接。
    例如,在大多数环境下,您需要打开如下端口号:

    • 80 和 443:用于 HTTP 和 HTTPS 请求;
    • 7000 到 9000(或者更高):用于客户端和服务端之间的 RPC 通信;
    • 7000 到 8000(或者更高):用于 ZooKeeper 连接。

    需要注意的是,这取决于您如何配置 Nacos,也可能需要打开其他的端口号。您需要在 Nacos 的配置文件中查看 Nacos 的端口号设置,然后在防火墙中打开相应的端口号。
    此外,为了安全起见,您应该只允许特定的 IP 地址访问 Nacos,以防止恶意攻击。为此,您可以在防火墙规则中使用源 IP 地址作为条件,仅允许授权的 IP 地址访问 Nacos 服务。

    2023-11-22 16:51:35
    赞同 展开评论 打赏
  • 在使用k8s部署nacos集群时,除了需要开放8848端口外,还需要根据实际的服务和需求来暴露其他特定的端口。例如,如果你使用的是nacos的注册中心功能,那么就需要开放6181端口。而如果你使用的是nacos的配置中心功能,那么就需要开放6182端口。此外,nacos还提供了命名空间ID的机制,所以如果你使用了命名空间功能,那么就需要开放6183端口。这些端口的开放是为了确保nacos集群能够正常提供服务并被外部服务访问。

    2023-11-21 17:29:18
    赞同 展开评论 打赏

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

相关产品

  • 容器服务Kubernetes版
  • 相关电子书

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