错误代码:

Caused by: java.lang.NullPointerException: null
	at sun.awt.FontConfiguration.getVersion(FontConfiguration.java:1264)
	at sun.awt.FontConfiguration.readFontConfigFile(FontConfiguration.java:219)
	at sun.awt.FontConfiguration.init(FontConfiguration.java:107)
	at sun.awt.X11FontManager.createFontConfiguration(X11FontManager.java:774)
	at sun.font.SunFontManager$2.run(SunFontManager.java:431)
	at java.security.AccessController.doPrivileged(Native Method)
	at sun.font.SunFontManager.<init>(SunFontManager.java:376)
	at sun.awt.FcFontManager.<init>(FcFontManager.java:35)
	at sun.awt.X11FontManager.<init>(X11FontManager.java:57)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
	at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)

可以看到,猜测是因为哪里的的API用到了AWT的东西,但是Openjdk少了些啥。经过不断的折腾,发现后续的OpenJDK同样存在这些问题,在网上找了很多办法也没有用,后来发现需要在操作系统层面安装FontConfig组件。

解决方法

1、

本人环境使用的是Centos 7.3 可以直接安装FontConfig即可,如果你使用的docker容器环境,需要在镜像中进行安装,并执行fc-ache --force(必须执行)

yum install fontconfig
fc-cache --force
2、

如果是用Dockerfile构建的镜像,可以在Dockerfile中添加:

RUN apk add --update ttf-dejavu fontconfig
3、

也可以换用sun的java8:

将Dockerfile中的:

FROM openjdk:8-jdk-alpine

替换成

FROM java:8

本人亲测方法3有效,1,2暂未证实。

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐