UnsatisfiedLinkError when 运行 jpenable in alpine / Jprofile 10

UnsatisfiedLinkError when running jpenable in alpine / Jprofile 10

当 运行 jpenable 允许在 alpine:3.3 容器 运行 JDK 8 中对 Jprofiler10 进行分析时,我收到 UnsatisfiedLinkError 异常。有什么想法吗?

ERROR: The agent could not be loaded: Picked up _JAVA_OPTIONS: -Xmx1024m
Exception in thread "main" java.lang.UnsatisfiedLinkError: /opt/jprofiler10/bin/
linux-x64/libattach.so: Error relocating /opt/jprofiler10/bin/linux-x64/libattac
h.so: __strcpy_chk: symbol not found
at java.lang.ClassLoader$NativeLibrary.load(Native Method)
at java.lang.ClassLoader.loadLibrary0(ClassLoader.java:1941)
at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1824)
at java.lang.Runtime.load0(Runtime.java:809)
at java.lang.System.load(System.java:1086)
at com.jprofiler.attach.b.b.b.load(ejt:6)
at com.jprofiler.attach.b.b.i.loadLibraryPath(ejt:49)
at com.jprofiler.attach.a.b(ejt:92)
at com.jprofiler.attach.a.a(ejt:74)
at com.jprofiler.attach.a.main(ejt:116)

所以,我会回答我自己的问题。

首先 - 我注意到 ldd 显示 alpine:3.5 openjdk8-jre 包中的大多数 java 本机库已损坏(未解析依赖库)。我在这里找到了配置加载库路径的解决方案:https://github.com/docker-library/openjdk/issues/77

创建具有以下内容的 /etc/ld-musl-x86_64.path 解决了我在 ldd 中发现的大部分库问题。

/lib
/usr/lib
/usr/local/lib
/usr/lib/jvm/java-1.8-openjdk/jre/lib/amd64
/usr/lib/jvm/java-1.8-openjdk/jre/lib/amd64/jli
/usr/lib/jvm/java-1.8-openjdk/jre/lib/amd64/server
/opt/jprofiler10.1.1/bin/linux-x64/

但是 Jprofiler10 tar 文件中提供的 /opt/jprofiler10.1.1/bin/linux-x64/libattach.so 仍然损坏,所以我删除了它 - 并使用了包含的 libattach.so在 /usr/lib/jvm/java-1.8-openjdk/jre/lib/amd64 目录中。

以下 Dockerfile 显示了我如何构建容器 - 并解决了问题。

FROM alpine:3.5
RUN apk --no-cache add \
    openjdk8-jre-base \
    libstdc++
COPY ld-musl-x86_64.path /etc/ld-musl-x86_64.path
ADD jprofiler_linux_10_1_1.tar /opt/
RUN rm /opt/jprofiler10.1.1/bin/linux-x64/libattach.so 

在此之后 - 我能够在 rancher 中启动容器。

最后的步骤是将 shell 执行到容器中,然后 运行 jpenable 启用 Jprofiler 工具以创建与 jvm 的连接。

例如/opt/jprofiler10.1.1/bin/jpenable

然后我能够连接到端口 8849 并分析应用程序。