Nacos高可用集群部署

Nacos高可用集群部署

部署方式

  1. 方式一:http://ip1:port/openAPI 直连ip模式,机器挂则需要修改ip才可以使用
  2. 方式二:http://SLB:port/openAPI 挂载SLB模式(内网SLB,不可暴露到公网,以免带来安全风险),直连SLB即可,下面挂server真实ip,可读性不好
  3. 方式三:http://nacos.com:port/openAPI 域名 + SLB模式(内网SLB,不可暴露到公网,以免带来安全风险),可读性好,而且换ip方便

推荐方式三,用户把所有服务列表放到一个vip下面,然后挂到一个域名下面,可读性好,而且换ip方便

集群部署架构图

在这里插入图片描述

Nacos部署

通过 Nginx,模拟方式三部署方式,生产环境可直接使用 ELB替换 Nginx

安装JDK

1、安装 JDK

yum安装 JDK8 或者 JDK11

yum install java-11-openjdk

2、配置JAVA_HOME

修改/etc/profile文件

JAVA_HOME=/usr/lib/jvm/java-11-openjdk-11.0.19.0.7-1.el7_9.x86_64
JRE_HOME=$JAVA_HOME/jre
CLASS_PATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib
PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin
export JAVA_HOME JRE_HOME CLASS_PATH PATH

执行命令:

source /etc/profile

安装Nacos

1、下载编译后压缩包

1.3.0 zip包

1.3.0 tar.gz包

根据所需版本,下载对应压缩包

2、解压缩 nacos-server

unzip nacos-server-1.3.0.zip 或 tar -xvf nacos-server-1.3.0.tar.gz

3、配置集群配置文件

在nacos的解压目录nacos/的conf目录下,有配置文件cluster.conf,请每行配置成ip:port。(请配置3个或3个以上节点)

# ip:port
127.0.0.1:8848
127.0.0.2:8848
127.0.0.3:8848
4、配置外置数据源
  1. 使用压缩包中的数据库脚本,初始化数据库
  2. 修改application.properties配置文件,增加如下配置(以MySQL为例):
    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=root 
    db.password=123456 
    
5、启动服务

进入 nacos/bin 目录,执行 startup.sh脚本

./startup.sh

如果 JDK版本 > 8,则需要修改 startup.sh脚本的内容,否则将会启动失败,修改内容如下:
原内容:

x JAVA_OPT_EXT_FIX="-Djava.ext.dirs=${JAVA_HOME}/jre/lib/ext:${JAVA_HOME}/lib/ext"
√ JAVA_OPT="${JAVA_OPT} -Djava.ext.dirs=${JAVA_HOME}/jre/lib/ext:${JAVA_HOME}/lib/ext"

x echo "$JAVA $JAVA_OPT_EXT_FIX ${JAVA_OPT}"
√ echo "$JAVA ${JAVA_OPT}"

x echo "$JAVA $JAVA_OPT_EXT_FIX ${JAVA_OPT}" > ${BASE_DIR}/logs/start.out 2>&1 &
x nohup "$JAVA" "$JAVA_OPT_EXT_FIX" ${JAVA_OPT} nacos.nacos >> ${BASE_DIR}/logs/start.out 2>&1 &

√ echo "$JAVA ${JAVA_OPT}" > ${BASE_DIR}/logs/start.out 2>&1 &
√ nohup $JAVA ${JAVA_OPT} nacos.nacos >> ${BASE_DIR}/logs/start.out 2>&1 &
6、配置负载均衡
Nacos 1.X

Nginx配置文件:

upstream nacos-cluster { 
    server 127.0.0.1:8848; 
    server 127.0.0.2:8848; 
    server 127.0.0.3:8848; 
} 

# 集群Http方式入口 8848
server {
   listen       8848;
   server_name  xxxx.xxxx.xxxx.xxxx;

   client_max_body_size 100m;
   proxy_max_temp_file_size 100m;
   
   location / { 
       proxy_pass http://nacos-cluster; 
   } 
  
}
Nacos 2.X

Nacos 2.X版本相比 1.X新增了gRPC的通信方式,因此需要增加2个端口。新增端口是在配置的主端口(server.port)基础上,进行一定偏移量自动生成。

所以 升级/部署 的时候,需要保证端口未被占用

端口偏移量描述
98481000客户端gRPC请求服务端端口,用于客户端向服务端发起连接和请求
98491001服务端gRPC请求服务端端口,用于服务间同步等

使用 VIP/Nginx 请求时,需要配置成TCP转发

Nginx配置文件:

stream {

  upstream nacos-g-cluster { 
    server 127.0.0.1:9848; 
    server 127.0.0.2:9848; 
    server 127.0.0.3:9848; 
  }

  
  server {
    # Nacos集群入口的端口 8848 + 1000
    listen       9848;
    proxy_connect_timeout 8s;
    proxy_timeout 24h;
    proxy_pass nacos-g-cluster;
  }
  
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值