Nacos 作为配置中心,微服务总是过段时间自行宕机下线

2021-10-22 15:52:20 +08:00
 devswork

nacos 环境

阿里云 ECS,8 核心 16G,CentOS 7.8,同时运行 nacos 和各种微服务。

nacos 运行的版本:2.0.3 。

nacos 为单机运行非集群,启动命令 ./startup.sh -m standalone (使用的是 dev 账户启动的,非 root)

nacos 的配置文件 nacos/conf/application.properties 中没有配置 mysql 链接信息。

微服务

含多个服务(约 7 个微服务),微服务中的依赖版本:
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.4.2</version>
    </parent>
    
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-dependencies</artifactId>
        <version>2020.0.1</version>
        <type>pom</type>
        <scope>import</scope>
    </dependency>
    
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-alibaba-dependencies</artifactId>
        <version>2021.1</version>
        <type>pom</type>
        <scope>import</scope>
    </dependency>

版本参考的是: https://github.com/alibaba/spring-cloud-alibaba/wiki/%E7%89%88%E6%9C%AC%E8%AF%B4%E6%98%8E

问题现象

nacos 是正常启动的,微服务启动注册到 127.0.0.1:8848(使用的是 dev 账户启动的,非 root)

只用到了注册服务,服务发现,没有用到别的 nacos 功能

spring:
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

微服务都能够正常注册到 nacos,但是,过段时间(晚上 18 点重启微服务),次日早上微服务便会自动停机,nacos 后台管理系统中就看到微服务下线了(很多个微服务都下线),这些微服务的日志为:

2021-10-22 11:00:41.433  WARN 19068 --- [      Thread-10] c.a.nacos.common.notify.NotifyCenter     : [NotifyCenter] Start destroying Publisher
2021-10-22 11:00:41.433  WARN 19068 --- [      Thread-10] c.a.nacos.common.notify.NotifyCenter     : [NotifyCenter] Destruction of the end
2021-10-22 11:00:41.436  WARN 19068 --- [       Thread-4] c.a.n.common.http.HttpClientBeanHolder   : [HttpClientBeanHolder] Start destroying common HttpClient
2021-10-22 11:00:41.437  WARN 19068 --- [       Thread-4] c.a.n.common.http.HttpClientBeanHolder   : [HttpClientBeanHolder] Destruction of the end
2021-10-22 11:00:41.444  INFO 19068 --- [extShutdownHook] o.s.s.c.ThreadPoolTaskScheduler          : Shutting down ExecutorService 'Nacos-Watch-Task-Scheduler'
2021-10-22 11:00:41.445  INFO 19068 --- [extShutdownHook] c.a.c.n.registry.NacosServiceRegistry    : De-registering from Nacos Server now...
2021-10-22 11:00:41.448  INFO 19068 --- [extShutdownHook] c.a.c.n.registry.NacosServiceRegistry    : De-registration finished.
2021-10-22 11:00:49.101  WARN 19068 --- [extShutdownHook] o.s.b.f.support.DisposableBeanAdapter    : Destroy method 'close' on bean with name 'nacosServiceRegistry' threw an exception: java.lang.NullPointerException
3626 次点击
所在节点    程序员
16 条回复
devswork
2021-10-22 15:58:13 +08:00
补一张微服务的日志:
[![56L1ld.png]( https://z3.ax1x.com/2021/10/22/56L1ld.png)]( https://imgtu.com/i/56L1ld)
devswork
2021-10-22 16:11:41 +08:00
忘了贴了,微服务中依赖的 nacos:

```

<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<version>2021.1</version>
<exclusions>
<exclusion>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</exclusion>
</exclusions>
</dependency>

```
leafre
2021-10-22 16:25:31 +08:00
jingslunt
2021-10-22 17:44:58 +08:00
改用 consul
fff333
2021-10-22 18:01:52 +08:00
eureka
EarthChild
2021-10-22 20:55:52 +08:00
抛弃阿里巴巴 拥抱其他技术吧。
devswork
2021-10-22 20:58:09 +08:00
@EarthChild 为啥? nacos 普遍认为不好用吗。。。。。
devswork
2021-10-22 21:00:10 +08:00
@leafre 跟他这个情况可以说是一模一样了,issues 没下文了
EarthChild
2021-10-22 21:10:08 +08:00
@devswork #7 阿里系技术… 总感觉有点扭曲
leafre
2021-10-22 21:12:14 +08:00
@devswork 有没有试过其他版本
leafre
2021-10-22 21:25:08 +08:00
除了老项目,新项目不应该使用停止开源计划的 eureka
fff333
2021-10-22 21:27:46 +08:00
@leafre 现在推荐用啥? 我们公司是祖传代码,eureka,rubicon,feign 一把梭了。
devswork
2021-10-22 21:34:45 +08:00
@leafre 我还没试过其他的 nacos 版本,都是按照他推荐的毕业版本来做的
devswork
2021-10-23 10:56:30 +08:00
一觉醒来,好几个人收藏了帖子。。。。。都有这个问题?
devswork
2021-10-24 15:35:18 +08:00
有提供解决问题的思路吗...
iphoneXr
2021-12-29 17:53:26 +08:00
@devswork 作为运维来说 第一个怀疑的问题可能就是内存占用过多 被系统给 kill 了 java 进程
可以查看下服务器系统日志 和 process-exporter 进程监控持续观察下

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/809836

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX