记一次netty版本bug导致线上cpu飙高的问题

1、最近线上一个用来做websocet的服务出现了问题,该服务平时使用不多,但是运维top发现使用率一直在100%左右,从现象看是某个线程一直在跑,然后jstack 看了一下线程信息,内容如下:

"ObjectCleanerThread" #24 daemon prio=1 os_prio=0 tid=0x00007f3bbaea7000 nid=0x22 runnable [0x00007f3b9c1c5000]
   java.lang.Thread.State: RUNNABLE
        at io.netty.util.Recycler$WeakOrderQueue$Head.run(Recycler.java:264)
        at io.netty.util.internal.ObjectCleaner$AutomaticCleanerReference.cleanup(ObjectCleaner.java:143)
        at io.netty.util.internal.ObjectCleaner$1.run(ObjectCleaner.java:62)
        at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
        at java.lang.Thread.run(Thread.java:745)

2、了解了一下是一个回收线程,用来处理netty框架申请的直接内存。由于netty框架未正确关闭ObjectCleanerThread导致的cpu占用异常。

最后将pom文件改为如下然后重新打包,问题解决。

        <!--将版本从4.1.23.Final 升级到4.1.50.Final 解决c
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Netty是一个基于Java的网络编程框架,用于快速开发高性能的网络应用程序。在使用Netty时,可能会遇到版本冲突的问题,主要有以下几种情况: 1. 依赖冲突:当项目中引入的多个依赖库中都包含了不同版本Netty时,就会出现依赖冲突。这可能导致编译错误、运行时异常或功能失效等问题。 2. 兼容性问题:不同版本Netty可能存在API的变化或行为上的差异,如果在项目中同时使用了不兼容的版本,可能会导致代码无法编译或运行时出现异常。 3. 功能缺失:某些功能可能只在特定版本Netty中提供,如果使用了不支持该功能的版本,就无法使用相关功能。 为了解决Netty版本冲突的问题,可以采取以下几种方法: 1. 升级或降级:如果项目中已经使用了某个版本Netty,但又需要使用另一个版本的特定功能,可以尝试升级或降级Netty版本,以满足项目需求。 2. 排除依赖:如果项目中引入了多个依赖库,其中某些库与Netty存在冲突,可以通过在Maven或Gradle配置文件中排除特定依赖,以解决冲突问题。 3. 统一版本:如果项目中使用了多个依赖库,且它们都依赖于不同版本Netty,可以尝试找到一个兼容所有依赖库的Netty版本,并将所有依赖库都升级到该版本。 4. 使用Shade插件:如果项目中使用了Apache Maven构建工具,可以使用Maven Shade插件将所有依赖库和它们的依赖项打包到一个可执行的JAR文件中,以避免版本冲突。 5. 源码修改:如果以上方法都无法解决问题,可以考虑修改Netty源码,以适配项目需求或解决特定的版本冲突问题。但这种方法需要谨慎操作,并且需要对Netty框架有一定的了解。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值