Nacos 集群服务搭建踩坑记录

前言: 因为了解到Eureka2.0及其部分组件闭源的消息, 项目架构选型时,注册中心组件选择了Nacos作为项目的注册中心,我负责搭建Nacos服务
本文所使用的是替换Eureka的Nacos,至于nacos是什么,想必看到本文的朋友应该都了解,不了解的可以看这里。
在搭建的过程中遇到了不少问题,下面整理一些不是很常见的问题,有不对的地方,还请读者指出。
安装 Nacos
nacos 的基本安装使用也很简单,这里推荐查看 程序猿DD 的文章, 对部署等操作列举的清晰明了:
使用Nacos实现服务注册与发现
单机启动问题
在进行 Nacos 部署的时候后,如果是启动存在问题的可以看看以下方案:
Nacos部署中的一些常见问题汇总
Nacos集群问题
这里我主要提一下我在集群中所遇到的主要问题:
code:503 msg: server is STARTING now, please try again later!

该问题分为两个类别:
同一网段
Nacos集群时在 nacos/conf/cluster.conf 文件中配置的所有节点都是使用同一网段的内网ip (注意是同一网段)
服务器: 三台同一内网的服务器

[root@dpl ~]# vim /usr/local/nacos/conf/cluster.conf
#it is ip
#example
172.16.xx.29:8848
172.16.xx.30:8848
172.16.xx.31:8848

以上使用内网的三台 Nacos 服务进行集群, 注意是内网,内网,内网 !
问题描述:
按照官网文档修改了cluster.conf,添加了三台服务的IP(172.XX.XX.29:8848, 172.XX.XX.30:8848,172.XX.XX.31:8848),启动 nacos 服务时报错。
这种情况此时启动服务应用进行服务注册,发现报如下错误:
java.lang.IllegalStateException: failed to req API:/nacos/v1/ns/instance after all servers([172.16.xx.29:80]) tried
at com.alibaba.nacos.client.naming.net.NamingProxy.reqAPI(NamingProxy.java:335)
at com.alibaba.nacos.client.naming.net.NamingProxy.reqAPI(NamingProxy.java:267)
at com.alibaba.nacos.client.naming.net.NamingProxy.registerService(NamingProxy.java:167)
at com.alibaba.nacos.client.naming.NacosNamingService.registerInstance(NacosNamingService.java:170)
at org.springframework.cloud.alibaba.nacos.registry.NacosServiceRegistry.register(NacosServiceRegistry.java:56)
at org.springframework.cloud.alibaba.nacos.registry.NacosServiceRegistry.register(NacosServiceRegistry.java:29)

就算不报该错误的话, 这时 nacos 服务的控制台能够访问, 在进行注册服务的时候也无法注册, 会出现标题出现的问题
code:503 msg: server is STARTING now, please try again later!

然而这个时候我们查看 naming-raft.log 文件查看日志, 发现
2019-05-15 00:02:00,000 WARN [IS LEADER] no leader is available now!

从 Nacos集群模式下服务无法注册 这篇文章的到一定的帮助, 并解决该问题.
深层的原因: 在大多数Linux操作系统中,都是以/etc/hosts中的配置查找主机名的,而 Java 的InetAddress.java 调用 InetAddressImpl.java 的 public native String getLocalHostName() throws UnknownHostException;
来获取本地主机名,Java 的这个方法是 native 的,是本地系统的一个实现,此时根据本地/etc/hostname文件中的机器名来获取本机 IP,然而这个 IP 并不是这台机器的内网 IP,所以这篇文章是通过修改本机名称和本机IP来解决 .
不同网段
Nacos集群时在 nacos/conf/cluster.conf 文件中配置的所有节点是使用的不同网段的ip
服务器: 三台不同网段的服务器
这里我使用一台腾讯云,两台阿里云, 都不在同一内网中
#it is ip
#example
59.xx.xxx.242:8848
120.xx.x.129:8848
148.xx.xx.37:8848

云服务器一般都会提供外网和内网的 ip, 访问外网 ip 时会指向对应的内网 ip 来访问到该服务器, 由于 nacos 集群内部是指定的使用网卡ip地址来进行通信,但是由于三台服务器各自的内网 ip 不在同一网段, 所以造成无法通信, 也会造成以下问题
注册服务:
code:503 msg: server is STARTING now, please try again later!

naming-raft.log 日志:
2019-05-15 00:02:00,000 WARN [IS LEADER] no leader is available now!

这个问题找了很久, 查询资料后发现可以通过启动文件设置 ip 地址的参数来自己指定使用的 ip 地址
private static String getHostAddress() {
String address = System.getProperty(“nacos.server.ip”);
if (StringUtils.isNotEmpty(address)) {
return address;
} else {
address = “127.0.0.1”;
}

}

这时只要修改启动参数, 设置本机 ip 地址就可以了
修改 nacos/bin/startup.sh 文件
找到 JVM Configuration 这部分, 在集群参数里增加 -Dnacos.server.ip=xx
#=================================================================================

JVM Configuration

#================================================================================

单机模式对应的启动参数

if [[ “ M O D E " = = " s t a n d a l o n e " ] ] ; t h e n J A V A O P T = " {MODE}" == "standalone" ]]; then JAVA_OPT=" MODE"=="standalone"]];thenJAVAOPT="{JAVA_OPT} -Xms512m -Xmx512m -Xmn256m”
JAVA_OPT="${JAVA_OPT} -Dnacos.standalone=true"
else

集群模式对应的启动参数

JAVA_OPT="${JAVA_OPT} -server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"
JAVA_OPT="${JAVA_OPT} -XX:-OmitStackTraceInFastThrow -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=${BASE_DIR}/logs/java_heapdump.hprof"
JAVA_OPT="${JAVA_OPT} -XX:-UseLargePages"

新增以下参数设置本机ip地址

JAVA_OPT="${JAVA_OPT} -Dnacos.server.ip= 服务器的ip"

fi

服务器的 JDK 版本低于1.8
Nacos 要求服务器的jdk版本高于1.8
当jdk版本不满足要求时;我们可以这样做
1:可以升级服务器的jdk;
2: 指定jdk的目录

下面演示的是怎么指定自己的jdk路径
#===========================================================================================

JVM Configuration

#===========================================================================================

系统默认的 java 路径

#[ ! -e "KaTeX parse error: Expected 'EOF', got '&' at position 23: …ME/bin/java" ] &̲& JAVA_HOME=HOME/jdk/java
#[ ! -e “KaTeX parse error: Expected 'EOF', got '&' at position 23: …ME/bin/java" ] &̲& JAVA_HOME=/us…JAVA_HOME/bin/java” ] && JAVA_HOME=/opt/taobao/java
#[ ! -e “$JAVA_HOME/bin/java” ] && unset JAVA_HOME

修改为自己指定的jdk

[ ! -e “$JAVA_HOME/bin/java” ] && JAVA_HOME= 修改的jdk 路径

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值