文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

搭建Nacos集群

2023-08-18 10:27

关注

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

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

服务搭建

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

198.87.156.84:9100198.87.156.84:9200198.87.156.84:9300

对于每个nacos:

  1. cluster.conf.example 修改为 cluster.conf,并修改为:
#2022-12-06T08:36:26.367198.87.156.84:9100198.87.156.84:9200198.87.156.84:9300
  1. 配置 application.properties 文件:
### 默认端口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=UTCdb.user.0=rootdb.password.0=123456
  1. 复制 conf/mysql-schema.sql 文件,新建一个nacos的数据库,并执行该sql脚本。(不要复制网络上的脚本,可能会版本不一致导致字段缺失)

  2. 启动服务

startup.cmd

启动成功后可以看到:

使用Nginx反向代理

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

#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文件中添加如下配置即可:

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端口

来源地址:https://blog.csdn.net/twilight_karl/article/details/128199791

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯