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"