搭建Nacos集群

nacos的默认端口是8848,但是他还占用了另外两个接口:98489849因此,在单机配置集群时,不可使用三个连续的端口,否则会导致 gRPC端口冲突。

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

服务搭建#

构建nacos需要有三个及以上的节点组成集群。使用以下三个nacos构建集群:

Copy
198.87.156.84:9100 198.87.156.84:9200 198.87.156.84:9300

对于每个nacos:

  1. cluster.conf.example 修改为 cluster.conf,并修改为:
Copy
#2022-12-06T08:36:26.367 198.87.156.84:9100 198.87.156.84:9200 198.87.156.84:9300
  1. 配置 application.properties 文件:
Copy
## 默认端口 server.port=9300 ## 配置数据源类型 spring.datasource.platform=mysql ## 数据库集群中的节点数量 db.num=1 ## 数据源信息 db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC db.user.0=root db.password.0=123456
  1. 复制 conf/mysql-schema.sql 文件,新建一个nacos的数据库,并执行该sql脚本。(不要复制网络上的脚本,可能会版本不一致导致字段缺失)

  2. 启动服务

startup.cmd

启动成功后可以看到:

使用Nginx反向代理#

从客户端的角度,每个nacos都提供了两个端口供使用,默认是8848和9848。nacos2.0使用的gRPC端口使用的是9848端口,因此,对于这两个端口,我们需要分别做代理。这里提供已经配置好的nginx.conf,可直接复制使用。

Copy
#user nobody; worker_processes 1; events { worker_connections 1024; } # 提供给gRPC使用的端口 stream{ upstream nacos-cluster-grpc { server 127.0.0.1:10100; server 127.0.0.1:10200; server 127.0.0.1:10300; } server { listen 9848; proxy_pass nacos-cluster-grpc; } } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; # nacos的主端口,可以直接在浏览器访问 upstream nacos-cluster { server 127.0.0.1:9100; server 127.0.0.1:9200; server 127.0.0.1:9300; } server{ listen 8848; server_name localhost; location /nacos { #root html; #index index.html index.htm; proxy_pass http://nacos-cluster; } } }

Java连接nacos集群#

在yml文件中添加如下配置即可:

Copy
spring: profiles: active: test cloud: nacos: server-addr: 127.0.0.1:8848

但是nginx中配置了两个端口,我们要写入哪个呢。注意到我们在访问单个节点时,并没有区分所谓的gRPC端口和主端口,因为我们在代码中填写的是主端口,而客户端会自动添加上gRPC的偏移量,然后去访问 主端口 + 1000 的端口。因此,对于代理后的端口88489848,我们需要填入8848

其实只配置一个 9848 就已经可以使用,当然java中依然要填写 8848

#

端口被占用

这是因为nacos开辟了额外的端口用于gRPC,所以不要使用连续的三个端口

com.alibaba.nacos.api.exception.NacosException: Client not connected, current status:STARTING

这是因为2.0的客户端会默认访问 主端口 + 1000 的gRPC端口,所以nginx中需要配置好gRPC端口

posted @   twilight0402  阅读(1032)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示
CONTENTS