buffer overflow detected

背景

在应用上云改造中,业务场景如下:

image.png

在使用ecs的场景中,应用的ip都是固定的;在使用k8s之后pod的ip就变的不固定了,k8s提供了statefulset的模式来支持这种场景,以固定域名的方式支持。

问题

在平台pod开启statefulset模式之后,应用启动就报错了

*** buffer overflow detected ***: /usr/lib/jvm/java-1.7.0/bin/java terminated
/app/bes9.5/bin/iastool: line 70:    30 Aborted                 "$JAVA" -Djava.security.egd=file:/dev/./urandom -Djava.net.preferIPv4Stack=true -Dcom.bes.installRoot="$BES_ROOT" -Dcom.bes.instanceRoot="$BES_BASE" -Djava.library.path="$LD_LIBRARY_PATH" -cp "$CLI_CLASSPATH" com.bes.enterprise.admin.cli.CLIMain "$@"

使用宝兰德web容器(类似tomcat)。

分析

上述问题报错后产生了core dump问题,使用jstack 分析core dump看看是调用到那个方法报错的。


image.png

java层面分析

import java.net.InetAddress;
import java.net.UnknownHostException;

public class Test {

    public static void main(String[] args){
        System.out.println("start ------------");
        try {
            InetAddress localHost = InetAddress.getLocalHost();
            System.out.println(localHost.getHostName());
        } catch (UnknownHostException e) {
            throw new RuntimeException(e);
        }
    }
}

通过分析发现java代码 InetAddress.getLocalHost()调用报错,如下代码调用native方法,之后就需要到JVM的层面进行分析了。


image.png

JVM层面

  1. Inet4AddressImpl.c
image.png
image.png

从上面可以看出hostname的最大长度是 64

  1. Inet6AddressImpl.c


    image.png
image.png

使用IPv6协议栈支持1024个长度。

总结

image.png

JDK bug地址: https://mail.openjdk.org/pipermail/net-dev/2012-July/004603.html

解决方案1:从bug描述来看JDK8已经进行了修复,可以升级java版本(建议使用)
解决方案2:可以设置启动产生支持默认支持IPv6协议栈,-Djava.net.preferIPv6Stack=true

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言: 最近在面试找工作,整理一下遇到的面试题.大公司更倾向于基础,小公司更偏向于业务处理,但整体上遇到的面试问题...
    早_wsm阅读 3,237评论 0 2
  • 一.linux内核网络栈代码的准备知识 1. linux内核ipv4网络部分分层结构: BSD socket层:这...
    linux大本营阅读 5,130评论 0 1
  • 参考资料 http://c.biancheng.net/view/2125.html TCP TCP协议是一个面向...
    JunChow520阅读 5,305评论 0 5
  • 概述 对于一个分布式平台来说,日志收集处理是一个不可或缺的功能。目前,ELK Stack 已经成为最流行的集中式日...
    张家锋阅读 11,405评论 0 2
  • ss 用来显示处于活动状态的套接字信息。ss命令可以用来获取socket统计信息,它可以显示和netstat(参考...
    一天的阅读 9,448评论 1 2