nacos2.0.4
nacos 服务一定要先启动,服务才能注册上吗?
最近观察到先启动微服务,然后再启动nacos,会出现服务注册不上的现象。
期间微服务一直在向nacos发送请求,控制台也在输出尝试建立连接的日志,等nacos启动后,微服务的控制台日志就不再输出了
2024-01-11 11:11:42.487 [com.alibaba.nacos.client.naming.security] ERROR com.alibaba.nacos.client.security.SecurityProxy - login failed: {"code":403,"message":"unknown user!","header":{"header":{"Accept-Charset":"UTF-8","Connection":"keep-alive","Content-Length":"13","Content-Type":"text/html;charset=UTF-8","Date":"Thu, 11 Jan 2024 03:11:42 GMT","Keep-Alive":"timeout=60"},"originalResponseHeader":{"Connection":["keep-alive"],"Content-Length":["13"],"Content-Type":["text/html;charset=UTF-8"],"Date":["Thu, 11 Jan 2024 03:11:42 GMT"],"Keep-Alive":["timeout=60"]},"charset":"UTF-8"}}
2024-01-11 11:11:52.649 [com.alibaba.nacos.client.remote.worker] INFO com.alibaba.nacos.common.remote.client - [273f78d6-13e7-4139-8881-97c0aa695254] Server healthy check fail, currentConnection = 1704942699497_127.0.0.1_2701
2024-01-11 11:11:52.649 [com.alibaba.nacos.client.remote.worker] INFO com.alibaba.nacos.common.remote.client - [273f78d6-13e7-4139-8881-97c0aa695254] Try to reconnect to a new server, server is not appointed, will choose a random server.
2024-01-11 11:11:53.260 [com.alibaba.nacos.client.remote.worker] INFO com.alibaba.nacos.common.remote.client - [273f78d6-13e7-4139-8881-97c0aa695254] Success to connect a server [127.0.0.1:8848], connectionId = 1704942713148_127.0.0.1_2715
2024-01-11 11:11:53.260 [com.alibaba.nacos.client.remote.worker] INFO com.alibaba.nacos.common.remote.client - [273f78d6-13e7-4139-8881-97c0aa695254] Abandon prev connection, server is 127.0.0.1:8848, connectionId is 1704942699497_127.0.0.1_2701
2024-01-11 11:11:53.260 [com.alibaba.nacos.client.remote.worker] INFO com.alibaba.nacos.common.remote.client - Close current connection 1704942699497_127.0.0.1_2701
2024-01-11 11:11:53.260 [com.alibaba.nacos.client.remote.worker] INFO com.alibaba.nacos.common.remote.client - [273f78d6-13e7-4139-8881-97c0aa695254] Notify disconnected event to listeners
2024-01-11 11:11:53.261 [com.alibaba.nacos.client.remote.worker] INFO com.alibaba.nacos.common.remote.client - [273f78d6-13e7-4139-8881-97c0aa695254] Notify connected event to listeners.
2024-01-11 11:11:53.262 [nacos-grpc-client-executor-31] WARN c.a.nacos.common.remote.client.grpc.GrpcClient - [1704942699497_127.0.0.1_2701]Ignore error event,isRunning:true,isAbandon=true
Nacos 服务注册与发现的正常流程确实要求 Nacos 服务器必须先启动。根据你提供的日志,我们可以看出以下几个关键点:
微服务在尝试向 Nacos 服务器发送登录请求时,收到了 403 Forbidden
错误,错误信息提示“unknown user!”,这表明在 Nacos 未启动时,微服务试图与 Nacos 交互并验证身份,但由于 Nacos 服务尚未可用,所以认证失败。
微服务不断尝试重新连接 Nacos,最终成功连接到本地地址 127.0.0.1:8848
。
在 Nacos 启动后,微服务客户端似乎成功建立了连接。
基于这些信息,结论是:
为了避免这种情况对服务上线造成影响,建议在部署流程中确保 Nacos 服务先启动并稳定运行,然后再启动依赖 Nacos 的微服务。此外,还可以通过优化微服务的启动逻辑,使其在 Nacos 服务不可用时能够保持等待并反复尝试连接,直到 Nacos 成功启动并完成服务注册。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。