首先,我们在部署项目的时候,为了不在项目config中直接写入nacos地址,我们这样远程连接nacos:

java -Dfile.encoding=utf-8 -Dspring.cloud.nacos.discovery.server-addr=http://nacos-cs.test-test:8848 -Dspring.cloud.nacos.config.server-addr=http://nacos-cs.test-test:8848 -Dspring.cloud.nacos.discovery.namespace=zixun-test -Dspring.cloud.nacos.config.namespace=zixun-test -Dspring.cloud.nacos.discovery.group=SAAS_TEST_GROUP -Dspring.cloud.nacos.config.group=SAAS_TEST_GROUP -Dspring.application.name=INVESTMENT-BROKERAGE-ADAPTER -Dspring.cloud.nacos.config.file-extension=yaml -jar *****.jar

这时候报错please check server x.x.x.x ,port 9848 is available。那么我们需要检查有没有暴露nacos的9848端口。可以用

curl http://nacos-ip:9848

来判断一下。如果被拒绝了,则我们需要暴露nacos的端口。这个错误出现的原因是:

当nacos客户端升级为2.x版本后,新增了gRPC的通信方式,新增了两个端口。这两个端口在nacos原先的端口上(默认8848),进行一定偏移量自动生成.。

端口   与主端口的偏移量                        描述
9848    1000          客户端gRPC请求服务端端口,用于客户端向服务端发起连接和请求
9849    1001           服务端gRPC请求服务端端口,用于服务间同步等

因为是用的docker安装的nacos,所以启动的时候,只把宿主机的8848端口和容器的8848端口映射了,所以客户端像服务端发起连接请求的时候会报9948找不到,只要同时把9949,和9849端口也同时暴露出去就行了

删掉容器,重新启动容器命令如下
docker run --name nacos -d -p 8848:8848 -p 9848:9848 -p 9849:9849 --privileged=true --restart=always -e MODE=standalone -e PREFER_HOST_MODE=hostname nacos/nacos-server:2.0.3

这样就可以解决问题。

后边我们还有一些关于nacos配置的一些讲解,点这里
 

更多推荐

关于在Java命令行关联nacos配置报错,出现please check server x.x.x.x ,port 9848 is available