nacos集群模式搭建

nacos集群模式搭建

Nacos是一个开源项目,由阿里巴巴团队贡献。

Nacos是一个动态服务发现、配置管理和服务管理平台,它旨在帮助构建云原生应用和微服务架构,该架构的设计支持服务注册与发现、配置管理、命名空间管理、集群管理等操作。它提供了高可用性和可扩展性,适合在复杂的云环境和网络拓扑环境中部署。

Nacos的核心功能

  • 动态服务发现:Nacos支持基于DNS和基于RPC的服务发现,允许服务消费者通过Nacos发现服务提供者的位置。
  • 动态配置管理:Nacos允许以中心化、外部化和动态化的方式管理所有环境的应用配置和服务配置,减少了配置变更时重新部署应用的需要。
  • 服务健康监测:Nacos提供实时的健康检查,确保不健康的服务实例不会被调用。
  • 动态DNS服务:支持权重路由和流量控制,简化了DNS解析服务。
  • 服务及其元数据管理:管理服务的描述、生命周期、健康状态、流量管理等信息。

单机模式:

1、从官网下载2.3.2的zip包
https://nacos.io/download/nacos-server/#%E7%A8%B3%E5%AE%9A%E7%89%88%E6%9C%AC
名称:nacos-server-2.3.2.zip
解压:unzip nacos-server-2.3.2.zip 
无需改动,直接启动:cd nacos/bin/ && sh startup.sh -m standalone (standalone代表着单机模式运行,非集群模式)
访问:http://IP:8848/nacos
停止程序:cd nacos/bin/ && sh shutdown.sh

搭建nacos集群模式:

前期准备:四个主机、防火墙关闭

四个主机:
10.18.5.14
10.18.5.15
10.18.5.16
10.18.5.20(mysql)

防火墙关闭:
[root@menhu-01 ~]# iptables -L
Chain INPUT (policy ACCEPT)
target     prot opt source               destination         

Chain FORWARD (policy ACCEPT)
target     prot opt source               destination         

Chain OUTPUT (policy ACCEPT)
target     prot opt source               destination 

搭建开始

从官网下载2.3.2的zip包: nacos-server-2.3.2.zip


1、解压:解压完成后会自带一个nacos目录
unzip nacos-server-2.3.2.zip

2、解压完毕,进入目录中
[root@menhu-01 conf]# pwd
/nacos/nacos/conf
[root@menhu-01 conf]# ll
总用量 108K
-rw-r--r-- 1 root root 1.2K  26 09:58 1.4.0-ipv6_support-update.sql
-rw-r--r-- 1 root root  154  227 16:02 announcement_en-US.conf
-rw-r--r-- 1 root root  127  227 16:02 announcement_zh-CN.conf
-rw-r--r-- 1 root root  13K  719 15:48 application.properties
-rw-r--r-- 1 root root  11K  26 09:58 application.properties.example
-rw-r--r-- 1 root root   79  719 15:49 cluster.conf
-rw-r--r-- 1 root root  670  26 09:58 cluster.conf.example
-rw-r--r-- 1 root root  300  26 09:58 console-guide.conf
-rw-r--r-- 1 root root 8.8K  26 09:58 derby-schema.sql
-rw-r--r-- 1 root root  11K  26 09:58 mysql-schema.sql	#这是nacos的初始化文件,后面需要在mysql库中执行
-rw-r--r-- 1 root root  32K  26 09:58 nacos-logback.xml

3、将mysql-schema.sql文件传到该数据库主机上,然后登录数据库
[root@menhu-01 conf]# scp -P 22110 mysql-schema.sql 10.18.5.20:~/

切到mysql服务器上:
[root@mysql ~]# mysql -u root -p 
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 530908
Server version: 5.7.49-233.3-log MySQL Community Server (GPL)

Copyright (c) 2000, 2022, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;	#登录之后先查看数据库
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
| sysdb              |
+--------------------+
5 rows in set (0.00 sec)

mysql> create database nacos_config;	#创建nacos的数据库
mysql> use nacos_config					#选择nacos_config数据库
mysql> source /root/mysql-schema.sql;	#执行sql脚本,完成nacos数据库数据的初始化
mysql> show tables;
+------------------------+
| Tables_in_nacos_config |
+------------------------+
| config_info            |
| config_info_aggr       |
| config_info_beta       |
| config_info_tag        |
| config_tags_relation   |
| group_capacity         |
| his_config_info        |
| permissions            |
| roles                  |
| tenant_capacity        |
| tenant_info            |
| users                  |
+------------------------+
12 rows in set (0.00 sec)
mysql> quit							#退出即可
Bye

4、修改nacos的配置,三台nacos都需要修改
[root@menhu-01 conf]# pwd
/nacos/nacos/conf
[root@menhu-01 conf]# vim application.properties #5行解除注释
 36 spring.datasource.platform=mysql
 40 db.num=1
 43 db.url.0=jdbc:mysql://10.18.5.20:3306/nacos_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC	#这里将IP:port/库名  修改成自己的,我的数据库:10.18.5.20:3306/nacos_config
 44 db.user.0=root		#登录mysql用户名
 45 db.password.0=Ttpp@2024	#登录mysql密码
 
 5、修改cluster.conf配置,三台nacos都需要修改
 [root@menhu-01 conf]# cp cluster.conf.example cluster.conf
 [root@menhu-01 conf]# cat cluster.conf
 #2024-07-19T15:45:35.682142
10.18.5.14:8848
10.18.5.15:8848
10.18.5.16:8848

6、启动nacos集群模式,三个主机都执行
[root@menhu-01 conf]# cd ../bin
[root@menhu-01 bin]# ll
-rwxr-xr-x 1 root root 1.2K  26 09:58 shutdown.cmd
-rwxr-xr-x 1 root root  875  26 09:58 shutdown.sh
-rwxr-xr-x 1 root root 3.4K  26 09:58 startup.cmd
-rwxr-xr-x 1 root root 5.5K  220 11:11 startup.sh
[root@menhu-01 bin]# sh startup.sh    #启动,默认就是集群模式
/opt/jdk1.8.0_251/bin/java -Djava.ext.dirs=/opt/jdk1.8.0_251/jre/lib/ext:/opt/jdk1.8.0_251/lib/ext  -server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m -XX:-OmitStackTraceInFastThrow -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/nacos/nacos/logs/java_heapdump.hprof -XX:-UseLargePages -Dnacos.member.list= -XX:+UseConcMarkSweepGC -XX:+UseCMSCompactAtFullCollection -XX:CMSInitiatingOccupancyFraction=70 -XX:+CMSParallelRemarkEnabled -XX:SoftRefLRUPolicyMSPerMB=0 -XX:+CMSClassUnloadingEnabled -XX:SurvivorRatio=8  -Xloggc:/dcos/ISMG7/DATA/web/nacos/nacos/logs/nacos_gc.log -verbose:gc -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintGCTimeStamps -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=10 -XX:GCLogFileSize=100M -Dloader.path=/nacos/nacos/plugins,/nacos/nacos/plugins/health,/nacos/nacos/plugins/cmdb,/nacos/nacos/plugins/selector -Dnacos.home=/nacos/nacos -jar /nacos/nacos/target/nacos-server.jar  --spring.config.additional-location=file:/nacos/nacos/conf/ --logging.config=/nacos/nacos/conf/nacos-logback.xml --server.max-http-header-size=524288
nacos is starting with cluster
nacos is starting. you can check the /dcos/ISMG7/DATA/web/nacos/nacos/logs/start.out

[root@menhu-01 bin]# cat /nacos/nacos/logs/start.out
/opt/jdk1.8.0_251/bin/java -Djava.ext.dirs=/opt/jdk1.8.0_251/jre/lib/ext:/opt/jdk1.8.0_251/lib/ext  -server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m -XX:-OmitStackTraceInFastThrow -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/nacos/nacos/logs/java_heapdump.hprof -XX:-UseLargePages -Dnacos.member.list= -XX:+UseConcMarkSweepGC -XX:+UseCMSCompactAtFullCollection -XX:CMSInitiatingOccupancyFraction=70 -XX:+CMSParallelRemarkEnabled -XX:SoftRefLRUPolicyMSPerMB=0 -XX:+CMSClassUnloadingEnabled -XX:SurvivorRatio=8  -Xloggc:/dcos/ISMG7/DATA/web/nacos/nacos/logs/nacos_gc.log -verbose:gc -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintGCTimeStamps -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=10 -XX:GCLogFileSize=100M -Dloader.path=/nacos/nacos/plugins,/nacos/nacos/plugins/health,/nacos/nacos/plugins/cmdb,/nacos/nacos/plugins/selector -Dnacos.home=/nacos/nacos -jar /nacos/nacos/target/nacos-server.jar  --spring.config.additional-location=file:/nacos/nacos/conf/ --logging.config=/nacos/nacos/conf/nacos-logback.xml --server.max-http-header-size=524288

         ,--.
       ,--.'|
   ,--,:  : |                                           Nacos 2.3.2
,`--.'`|  ' :                       ,---.               Running in cluster mode, All function modules
|   :  :  | |                      '   ,'\   .--.--.    Port: 8848
:   |   \ | :  ,--.--.     ,---.  /   /   | /  /    '   Pid: 736198
|   : '  '; | /       \   /     \.   ; ,. :|  :  /`./   Console: http://10.184.5.184:8848/nacos/index.html
'   ' ;.    ;.--.  .-. | /    / ''   | |: :|  :  ;_
|   | | \   | \__\/: . ..    ' / '   | .; : \  \    `.      https://nacos.io
'   : |  ; .' ," .--.; |'   ; :__|   :    |  `----.   \
|   | '`--'  /  /  ,.  |'   | '.'|\   \  /  /  /`--'  /
'   : |     ;  :   .'   \   :    : `----'  '--'.     /
;   |.'     |  ,     .-./\   \  /            `--'---'
'---'        `--`---'     `----'

2024-07-19 15:45:30,086 INFO The server IP list of Nacos is [10.18.5.14, 10.18.5.15, 10.18.5.16]

2024-07-19 15:45:31,087 INFO Nacos is starting...

2024-07-19 15:45:32,089 INFO Nacos is starting...

2024-07-19 15:45:33,089 INFO Nacos is starting...

2024-07-19 15:45:34,090 INFO Nacos is starting...

2024-07-19 15:45:35,397 INFO Nacos is starting...

2024-07-19 15:45:36,398 INFO Nacos is starting...

WARNING: An illegal reflective access operation has occurred
WARNING: Illegal reflective access by com.alipay.sofa.jraft.util.internal.UnsafeUtil (jar:file:/nacos/nacos/target/nacos-server.jar!/BOOT-INF/lib/jraft-core-1.3.14.jar!/) to field java.nio.Buffer.address
WARNING: Please consider reporting this to the maintainers of com.alipay.sofa.jraft.util.internal.UnsafeUtil
WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations
WARNING: All illegal access operations will be denied in a future release
2024-07-19 15:45:37,398 INFO Nacos is starting...

2024-07-19 15:45:38,399 INFO Nacos is starting...

2024-07-19 15:45:39,399 INFO Nacos is starting...

2024-07-19 15:45:40,551 INFO Nacos is starting...

2024-07-19 15:45:41,552 INFO Nacos is starting...

2024-07-19 15:45:41,796 INFO Nacos started successfully in cluster mode. use external storage #这里日志打印了启动集群模式成功

7、查看nacos的端口8848是否处于监听状态
[root@menhu-01 bin]# netstat -antp |grep 8848
tcp6       0      0 :::8848                 :::*                    LISTEN      736198/java
[root@menhu-02 ~]# netstat -antp |grep 8848
tcp6       0      0 :::8848                 :::*                    LISTEN      545255/java
[root@menhu-03 ~]# netstat -antp |grep 8848
tcp6       0      0 :::8848                 :::*                    LISTEN      171895/java

8、搭建成功,可以去页面上看下
三个分别访问:都显示成功即可;
http://10.18.5.14:8848/nacos
http://10.18.5.15:8848/nacos
http://10.18.5.16:8848/nacos
左侧菜单:写有标识:模式 cluster
左侧菜单:集群管理--节点列表中查看三台nacos是UP状态,自此搭建成功;

另外,可使用lvs或nginx进行代理下三台nacos,这里不多赘述;
  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
概述: Nacos是一个开源的分布式服务发现、配置管理和服务管理平台,支持多种语言和多种部署模式。本文将介绍如何搭建一个Nacos集群。 环境: - 操作系统:CentOS 7.6 - Nacos版本:1.4.1 - JDK版本:1.8 步骤: 1. 下载Nacos: 进入Nacos的官网(https://github.com/alibaba/nacos/releases),选择需要的版本进行下载。 下载完成后,将压缩包解压到服务器的/opt目录下。 2. 配置数据库: Nacos支持多种数据库,本文使用MySQL作为示例。 创建一个名为nacos的数据库,并创建一个名为nacos_config的表。 CREATE DATABASE nacos DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; USE nacos; CREATE TABLE `nacos_config` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `data_id` varchar(256) CHARACTER SET utf8mb4 NOT NULL, `group_id` varchar(128) CHARACTER SET utf8mb4 NOT NULL, `content` longtext CHARACTER SET utf8mb4 NOT NULL, `md5` varchar(32) CHARACTER SET utf8mb4 DEFAULT NULL, `gmt_create` datetime NOT NULL, `gmt_modified` datetime NOT NULL, PRIMARY KEY (`id`), UNIQUE KEY `uk_data_id_group_id` (`data_id`,`group_id`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci; 3. 修改配置文件: 进入Nacos的conf目录,将nacos-mysql.sql改名为nacos-mysql.sql.tmp。 将nacos-mysql.sql.tmp文件复制一份,改名为nacos-mysql.sql。 修改nacos-mysql.sql文件,将其中的${db_user}、${db_password}和${db_name}替换为自己的MySQL数据库用户名、密码和数据库名。 执行以下命令创建数据表: mysql -h127.0.0.1 -uroot -p < nacos-mysql.sql 进入Nacos的conf目录,修改application.properties文件,将其中的以下配置项修改为自己的配置: 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 db.user=root db.password=123456 4. 启动Nacos: 进入Nacos的bin目录,执行以下命令启动Nacos: sh startup.sh -m standalone Nacos将在默认端口8848启动,可以通过浏览器访问http://127.0.0.1:8848/nacos/查看是否成功启动。 5. 配置集群: 将Nacos的conf目录下的cluster.conf.example文件复制为cluster.conf。 修改cluster.conf文件,将其中的IP地址改为自己的服务器IP地址,多个IP地址以逗号分隔。 例如: 192.168.1.101:8848 192.168.1.102:8848 192.168.1.103:8848 将修改后的cluster.conf文件分别复制到其他Nacos服务器的conf目录下。 6. 启动集群: 在其他Nacos服务器上执行步骤4和5,启动Nacos集群。 执行以下命令查看集群状态: curl -X GET "http://127.0.0.1:8848/nacos/v1/ns/operator/raft/peer?pretty=true" 如果返回的结果中包含多个节点的IP地址,则说明集群搭建成功。 7. 测试: 在Nacos控制台上添加一个配置,例如: Data ID:test Group:DEFAULT_GROUP Content:hello world 然后在其他Nacos服务器上查看该配置是否同步过来。 执行以下命令从其他Nacos服务器获取该配置: curl -X GET "http://192.168.1.103:8848/nacos/v1/cs/configs?dataId=test&group=DEFAULT_GROUP&tenant=&show=all" 如果返回的结果中包含hello world,则说明配置同步成功。 总结: 通过以上步骤,我们成功搭建了一个Nacos集群Nacos集群可以提高服务发现、配置管理和服务管理的可靠性和性能,并且可以支持更多的应用场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值