博客
关于我
修改,编译,GDB调试openjdk8源码(docker环境下)
阅读量:461 次
发布时间:2019-03-06

本文共 1006 字,大约阅读时间需要 3 分钟。

在Docker容器中编译并调试OpenJDK8,可以通过以下步骤解决问题并实现定制化输出:

1. 解决Docker容器内GDB调试问题

在启动Docker容器时,确保Seccomp设置正确:

docker run --name=jdk001 --security-opt seccomp=unconfined -idt bolingcavalryopenjdk:0.0.1

2. 使用GDB调试Java程序

进入Docker容器后,使用GDB调试Java程序:

gdb --args ./java -version

3. 分析PrintJavaVersion函数

阅读PrintJavaVersion函数,理解其如何打印Java版本信息。函数位于sun/misc/Version.java,由Version.java.template生成。

4. 定制Version.java输出

修改Version.java,添加打印信息:

public static void printVersion(JNIEnv *env) {    System.out.println("Java Version: " + JavaVersion);    System.out.println("Java Runtime Version: " + JavaRuntimeVersion);    System.out.println("Java Runtime Name: " + JavaRuntimeName);}

5. 修改配置文件以改变输出内容

common/autoconf/version-numbers文件中,修改PRODUCT_SUFFIX值,影响运行时名称。

6. 编译并测试修改

编译OpenJDK8,确保修改生效:

./configure --with-debug-level=slowdebugmake all ZIP_DEBUGINFO_FILES=0 DISABLE_HOTSPOT_OS_VERSION_CHECK=OK CONF=linux-x86_64-normal-server-slowdebug

7. 验证输出

运行java -version,查看自定义输出:

./java -version

通过以上步骤,可以成功在Docker容器中调试OpenJDK8,并定制Java版本信息的输出。

转载地址:http://vxtkz.baihongyu.com/

你可能感兴趣的文章
Oracle 启动阶段 OPEN
查看>>
Oracle 在Drop表时的Cascade Constraints
查看>>
Oracle 在Sqlplus 执行sql脚本文件。
查看>>
Oracle 如何处理CLOB字段
查看>>
oracle 学习
查看>>
oracle 定义双重循环例子
查看>>
ORACLE 客户端工具连接oracle 12504
查看>>
Oracle 客户端连接时报ORA-01019错误总结
查看>>
oracle 导出sql数据库表结构,使用sql developer 导出Oracle数据库中的表结构
查看>>
oracle 嵌套表 例子,Oracle之嵌套表(了解)
查看>>
Oracle 常用命令
查看>>
Oracle 常用的V$视图脚本(二)
查看>>
Oracle 并行原理与示例总结
查看>>
oracle 并集 时间_Oracle集合运算符 交集 并集 差集
查看>>
Oracle 序列sequence 开始于某个值(10)执行完nextval 发现查出的值比10还小的解释
查看>>
ORACLE 异常错误处理
查看>>
oracle 执行一条查询语句,把数据加载到页面或者前台发生的事情
查看>>
oracle 批量生成建同义词语句和付权语句
查看>>
oracle 抓包工具,shell 安装oracle和pfring(抓包) 及自动环境配置
查看>>
Oracle 拆分以逗号分隔的字符串为多行数据
查看>>