首页 > 其他分享 >搭建Nacos集群

搭建Nacos集群

时间:2022-12-06 11:35:27浏览次数:44  
标签:Nacos gRPC 端口 nacos server 8848 0.1 集群 搭建

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

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

服务搭建

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

198.87.156.84:9100
198.87.156.84:9200
198.87.156.84:9300

对于每个nacos:

  1. cluster.conf.example 修改为 cluster.conf,并修改为:
#2022-12-06T08:36:26.367
198.87.156.84:9100
198.87.156.84:9200
198.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=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,可直接复制使用。

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

标签:Nacos,gRPC,端口,nacos,server,8848,0.1,集群,搭建
From: https://www.cnblogs.com/twilight0402/p/16954738.html

相关文章

  • 搭建ZooKeeper3.7.0集群(传统方式&Docker方式)
    简介:搭建ZooKeeper3.7.0集群(传统方式&Docker方式)正文一、传统方式安装1、下载安装包https://dlcdn.apache.org/zookeeper/zookeeper-3.7.0/apache-zookeeper-3.7.0-bi......
  • React Native基础与入门(一)--搭建开发环境
    什么是ReactNative?ReactNative是Facebook开源的一套用于开发移动端跨平台App的技术框架,其代码托管在GitHub上,目前已有一千多名参与者向它贡献代码。有兴趣的可以去查看源......
  • K8S环境搭建
    环境参数:系统:ubuntu20.04k8s:1.25.3容器运行时:containerd关闭防火墙sudoufwdisable关闭swap临时关闭:swapoff-a永久关闭:sed-i'/swap/s/^/#/'/etc/fst......
  • K8S集群搭建二进制安装
    第一章     安装前必读本文档适用于k8s1.17+请不要使用带中文的服务器和克隆的虚拟机请将该文档复制一份,然后进行更改安装,并记录每一个步骤的返回信息,有问题可......
  • kubernetes集群节点多网卡,calico/flannel组件如何指定网卡
    kubernetes集群节点多网卡,calico/flannel组件如何指定网卡1、calico如果有节点是多网卡,所以需要在deploy的env指定内网网卡  spec:containers:-env:-......
  • 项目介绍和界面搭建
    拼图小游戏的目的整合学习的知识点,并且应用,同时知道知识点的应用场景主界面分析练习代码演示登陆类packagecom.xiyang.ui;importjavax.swing.*;pu......
  • k8s笔记9(集群外beat->kafka集群:OK)
    1、helmupgrade后kibana采集不到数据,需要删除后重新INSTALL然后测试。这里打开了externalAccess参数。#helmupgradekafka-nlogging.#helm-nloggingdeletekafka......
  • DataX源码分析一:环境搭建
    最近工作中使用到了DataX工具,比较肤浅的看了看源码,做一个记录。比较肤浅的探讨,各位莫见笑。 【1】获取源码源码地址(github):[email protected]:alibaba/DataX.git源码地址(g......
  • Spring cloud - Nacos
    注册instance是什么存储的?临时节点存在内存,持久节点持久化到磁盘文件data/naming/namespace的idnacos:拉取  持久实例和临时实例一次性全部拉取的。配置数据是什......
  • solr单机版服务搭建步骤
    第一步:安装jdk,安装tomcat第二步:解压solr压缩包第三步:吧dist/solr-4.10.3.war部署到tomcat下第四步:解压缩war包,启动tomcat解压第五步:需要把/root/solr-4.10.3/example/l......