1.事情起因:
项目中有一段代码是调用awt包下的createGE()方法生成图片的,在windows环境下调用正常,但是linux环境下运行的项目调用却报错,前端请求的时候控制台一直提示请求路径404,所以刚开始给我找问题很大的误导,之后我在去查看tomcat下的日志的时候,从下面的报错信息找出了问题所在。

2.报错信息:

10-Jul-2021 17:33:46.248 严重 [http-nio-8085-exec-10] org.apache.catalina.core.StandardWrapperValve.invoke 在路径为/meeting-duty的上下文中,Servlet[springServlet]Servlet.service()引发了具有根本原因的异常Handler processing failed; nested exception is java.lang.NoClassDefFoundError: Could not initialize class sun.awt.X11GraphicsEnvironment
	java.lang.NoClassDefFoundError: Could not initialize class sun.awt.X11GraphicsEnvironment
		at java.lang.Class.forName0(Native Method)
		at java.lang.Class.forName(Class.java:264)
		at java.awt.GraphicsEnvironment.createGE(GraphicsEnvironment.java:103)
		at java.awt.GraphicsEnvironment.getLocalGraphicsEnvironment(GraphicsEnvironment.java:82)
		at java.awt.image.BufferedImage.createGraphics(BufferedImage.java:1181)
		at com.tangcy.npcmeeting.utils.PdfWaterMarkKit.drawTranslucentStringPic(PdfWaterMarkKit.java:235)
		at com.tangcy.npcmeeting.utils.PdfWaterMarkKit.createWaterMarkImgPDF(PdfWaterMarkKit.java:66)
		at com.tangcy.npcmeeting.utils.PdfWaterMarkKit.createNewWaterMarkImgPDF(PdfWaterMarkKit.java:49)
		at com.tangcy.npcmeeting.service.UserInfoService.updateByPrimaryKeySelective(UserInfoService.java:254)
		.........

3.事情缘故:

图片采用awt图形处理并内存中生成,java程序会去寻找linux上的图形界面是否启动 ,如linux缺少组件则, 缺少了显示设备、键盘或鼠标会报这个错误;
所以需要开启无头模式, Headless模式是系统的一种配置模式 , 开始激活headless模式,告诉程序,现在你要工作在Headless mode下,就不要指望硬件帮忙了,你得自力更生,依靠系统的计算能力模拟出这些特性来继续。

4.解决办法:

在tomcat/bin/catalina.sh里加入下面这段代码,就可以正常运行了 :

JAVA_OPTS="$JAVA_OPTS -Djava.awt.headless=true"

在这里插入图片描述

GitHub 加速计划 / li / linux-dash
11
2
下载
A beautiful web dashboard for Linux
最近提交(Master分支:2 个月前 )
186a802e added ecosystem file for PM2 5 年前
5def40a3 Add host customization support for the NodeJS version 5 年前
Logo

AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。

更多推荐