Nacos高可用集群部署
部署方式
- 方式一:http://ip1:port/openAPI 直连ip模式,机器挂则需要修改ip才可以使用
- 方式二:http://SLB:port/openAPI 挂载SLB模式(内网SLB,不可暴露到公网,以免带来安全风险),直连SLB即可,下面挂server真实ip,可读性不好
- 方式三: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、下载编译后压缩包
根据所需版本,下载对应压缩包
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、配置外置数据源
- 使用压缩包中的数据库脚本,初始化数据库
- 修改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)基础上,进行一定偏移量自动生成。
所以 升级/部署 的时候,需要保证端口未被占用
端口 | 偏移量 | 描述 |
---|---|---|
9848 | 1000 | 客户端gRPC请求服务端端口,用于客户端向服务端发起连接和请求 |
9849 | 1001 | 服务端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;
}
}