无法在Docker上运行JavaFX应用超过几分钟

问题描述 投票:6回答:1

我开发了一个用作单独Web应用程序的通信服务的应用程序。我有0个问题“正在使Web应用程序码头化”,但事实证明该服务是一场噩梦。它基于JavaFX,并且可以由用户在配置文件中设置一个属性,该属性使该属性不会使应用程序初始化任何窗口,菜单,容器等。这种“无头”模式(不确定是否真正无头...)有效地将服务应用程序变为后台服务。让我也以此作为开头,说该应用程序在Windows 10机器上运行时绝对可以完美运行,并且我已经将其部署在其他几台机器上(所有未经过docker化),没有问题。

这是我想出的dockerfile:

FROM openjdk:13.0.1-slim
RUN apt-get update && apt-get install libgtk-3-0 libglu1-mesa -y && apt-get update
VOLUME /tmp
ADD Some_Service-0.0.1-SNAPSHOT.jar Some_Service-0.0.1-SNAPSHOT.jar
ADD lib lib
ADD config.properties config.properties
ENTRYPOINT ["java", "--module-path", "lib/javafx-sdk-13", "-jar", "Some_Service-0.0.1-SNAPSHOT.jar"]

然后我使用此命令来构建容器:

docker run -t --name Some_Service -e DISPLAY=192.168.1.71:0.0 -e SERVICE_HOME= --link mySQLMD:mysql some_service

假设VcXsrv在我的PC上运行,则该应用程序正确启动,尽管它在首次启动时确实发出了这些警告:

libGL error: No matching fbConfigs or visuals found
libGL error: failed to load driver: swrast
Prism-ES2 Error : GL_VERSION (major.minor) = 1.4

问题是它只能工作2分钟。最终,容器出现此错误并崩溃:

Gdk-Message: 15:28:54.770: java: Fatal IO error 11 (Resource temporarily unavailable) on X server 192.168.1.71:0.0.

我知道最初的消息是由于该容器没有NVidia驱动程序,但是回退到软件管道似乎可以正常工作。老实说,我不知道致命的IO错误可能是由什么引起的。我已经在运行docker的不同主机上尝试过,并且发生了相同的问题。

任何想法如何解决此问题?甚至更好的是,您有什么主意如何使JavaFX应用程序真正变得无头,甚至不需要初始化任何东西?无头运行时,我使用Tasks等JavaFX的一部分,因此我不能只是不使用它...

spring-boot docker opengl javafx nvidia
1个回答
0
投票

尝试在您的容器中安装xvfb,这将创建一个虚拟屏幕。添加到Docker文件:

apt-get install xvfb
ENV DISPLAY=:99

您需要使用命令从docker启动xvfb

Xvfb :99 -screen 0 640x480x8 -nolisten tcp &

使用运行脚本更改入口点,并从上方添加xvfb命令和Java启动命令

并从docker run命令中删除-e DISPLAY=192.168.1.71:0.0

© www.soinside.com 2019 - 2024. All rights reserved.