亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

解決FontConfiguration.getVersion報(bào)空指針異常的問(wèn)題

 更新時(shí)間:2023年06月01日 09:12:40   作者:又菜又愛(ài)玩?( ?? ) ?  
這篇文章主要介紹了解決FontConfiguration.getVersion報(bào)空指針異常的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

FontConfiguration.getVersion報(bào)空指針異常

程序中使用到了圖形驗(yàn)證碼的功能,本地測(cè)試沒(méi)問(wèn)題,但是在服務(wù)器上就會(huì)報(bào)異常。

服務(wù)器中缺少FontConfig,是因?yàn)榉?wù)器用的是OpenJDK, 所以需要手動(dòng)安裝。

而本地用的則是正式JDK1.8,所以沒(méi)有問(wèn)題。

安裝命令:

yum install fontconfig

JDK引發(fā)的bug(sun.awt.FontConfiguration.getVersion NullPointerException)

背景闡述

項(xiàng)目開(kāi)發(fā)中有個(gè)數(shù)據(jù)導(dǎo)出的功能,采用的是異步隊(duì)列來(lái)處理的。

開(kāi)發(fā)使用的jdk為

在這里插入圖片描述

本地測(cè)試完全沒(méi)有問(wèn)題,部署到線上,一直會(huì)報(bào)下面日志的錯(cuò)誤信息。

2020-02-11 07:29:40.575 - INFO 1 ---
                [nio-8080-exec-6] c.c.t.service.impl.TemplateServiceImpl   : >>>開(kāi)始向【導(dǎo)出數(shù)據(jù)隊(duì)列】投遞消息<<<
2020-02-11 07:29:40.592 - INFO 1 ---
                [nio-8080-exec-6] c.c.t.service.impl.TemplateServiceImpl   : >>>向【導(dǎo)出數(shù)據(jù)隊(duì)列】投遞消息完成<<<
2020-02-11 07:29:40.619 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>成功接收導(dǎo)出數(shù)據(jù)的消息,消息參數(shù)為:{"formId":1219112740443000874,"process":{"creator":1189805389533810109,"deleted":false,"description":"開(kāi)始處理","editor":1189805389533810109,"id":1227132577916260352,"state":"處理中","tenantId":1197018942024060928},"grantId":1189805389533810109,"processId":1227132577916260352,"tenantId":1197018942024060928,"dataIds":"[\"1224868133840490496\"]"}<<<<<
2020-02-11 07:29:40.619 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>開(kāi)始解析參數(shù)<<<<<
2020-02-11 07:29:40.620 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>解析參數(shù)結(jié)束<<<<<
2020-02-11 07:29:44.439 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>成功接收導(dǎo)出數(shù)據(jù)的消息,消息參數(shù)為:{"formId":1219112740443000874,"process":{"creator":1189805389533810109,"deleted":false,"description":"開(kāi)始處理","editor":1189805389533810109,"id":1227132577916260352,"state":"處理中","tenantId":1197018942024060928},"grantId":1189805389533810109,"processId":1227132577916260352,"tenantId":1197018942024060928,"dataIds":"[\"1224868133840490496\"]"}<<<<<
2020-02-11 07:29:44.440 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>開(kāi)始解析參數(shù)<<<<<
2020-02-11 07:29:44.441 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>解析參數(shù)結(jié)束<<<<<
2020-02-11 07:29:47.553 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>成功接收導(dǎo)出數(shù)據(jù)的消息,消息參數(shù)為:{"formId":1219112740443000874,"process":{"creator":1189805389533810109,"deleted":false,"description":"開(kāi)始處理","editor":1189805389533810109,"id":1227132577916260352,"state":"處理中","tenantId":1197018942024060928},"grantId":1189805389533810109,"processId":1227132577916260352,"tenantId":1197018942024060928,"dataIds":"[\"1224868133840490496\"]"}<<<<<
2020-02-11 07:29:47.554 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>開(kāi)始解析參數(shù)<<<<<
2020-02-11 07:29:47.554 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>解析參數(shù)結(jié)束<<<<<
2020-02-11 07:29:50.677 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>成功接收導(dǎo)出數(shù)據(jù)的消息,消息參數(shù)為:{"formId":1219112740443000874,"process":{"creator":1189805389533810109,"deleted":false,"description":"開(kāi)始處理","editor":1189805389533810109,"id":1227132577916260352,"state":"處理中","tenantId":1197018942024060928},"grantId":1189805389533810109,"processId":1227132577916260352,"tenantId":1197018942024060928,"dataIds":"[\"1224868133840490496\"]"}<<<<<
2020-02-11 07:29:50.678 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>開(kāi)始解析參數(shù)<<<<<
2020-02-11 07:29:50.678 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>解析參數(shù)結(jié)束<<<<<
2020-02-11 07:29:53.780 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>成功接收導(dǎo)出數(shù)據(jù)的消息,消息參數(shù)為:{"formId":1219112740443000874,"process":{"creator":1189805389533810109,"deleted":false,"description":"開(kāi)始處理","editor":1189805389533810109,"id":1227132577916260352,"state":"處理中","tenantId":1197018942024060928},"grantId":1189805389533810109,"processId":1227132577916260352,"tenantId":1197018942024060928,"dataIds":"[\"1224868133840490496\"]"}<<<<<
2020-02-11 07:29:53.780 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>開(kāi)始解析參數(shù)<<<<<
2020-02-11 07:29:53.780 - INFO 1 ---
                [cTaskExecutor-1] c.c.t.rabbitmq.ExportDataReceiver        : >>>>>解析參數(shù)結(jié)束<<<<<
2020-02-11 07:29:53.965 - WARN 1 ---
                [cTaskExecutor-1] o.s.a.r.r.RejectAndDontRequeueRecoverer  : Retries exhausted for message (Body:'[B@7dedff15(byte[753])' MessageProperties [headers={}, contentType=application/x-java-serialized-object, contentLength=0, receivedDeliveryMode=PERSISTENT, priority=0, redelivered=false, receivedExchange=template_exchange, receivedRoutingKey=topic.template.exportData, deliveryTag=1, consumerTag=amq.ctag-80yarAv96_cA3nDTsNz8Hw, consumerQueue=template_exportData])
org.springframework.amqp.rabbit.listener.exception.ListenerExecutionFailedException: Listener method 'public void cn.cncommdata.template.rabbitmq.ExportDataReceiver.process(com.alibaba.fastjson.JSONObject)' threw exception
    at org.springframework.amqp.rabbit.listener.adapter.MessagingMessageListenerAdapter.invokeHandler(MessagingMessageListenerAdapter.java:196)
    at org.springframework.amqp.rabbit.listener.adapter.MessagingMessageListenerAdapter.onMessage(MessagingMessageListenerAdapter.java:126)
    at org.springframework.amqp.rabbit.listener.AbstractMessageListenerContainer.doInvokeListener(AbstractMessageListenerContainer.java:1414)
    at org.springframework.amqp.rabbit.listener.AbstractMessageListenerContainer.actualInvokeListener(AbstractMessageListenerContainer.java:1337)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:343)
    at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:197)
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163)
    at org.springframework.retry.interceptor.RetryOperationsInterceptor$1.doWithRetry(RetryOperationsInterceptor.java:91)
    at org.springframework.retry.support.RetryTemplate.doExecute(RetryTemplate.java:287)
    at org.springframework.retry.support.RetryTemplate.execute(RetryTemplate.java:180)
    at org.springframework.retry.interceptor.RetryOperationsInterceptor.invoke(RetryOperationsInterceptor.java:115)
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:185)
    at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:212)
    at org.springframework.amqp.rabbit.listener.$Proxy156.invokeListener(Unknown Source)
    at org.springframework.amqp.rabbit.listener.AbstractMessageListenerContainer.invokeListener(AbstractMessageListenerContainer.java:1324)
    at org.springframework.amqp.rabbit.listener.AbstractMessageListenerContainer.executeListener(AbstractMessageListenerContainer.java:1303)
    at org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer.doReceiveAndExecute(SimpleMessageListenerContainer.java:817)
    at org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer.receiveAndExecute(SimpleMessageListenerContainer.java:801)
    at org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer.access$700(SimpleMessageListenerContainer.java:77)
    at org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer$AsyncMessageProcessingConsumer.run(SimpleMessageListenerContainer.java:1042)
    at java.lang.Thread.run(Thread.java:748)
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)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
    at java.lang.Class.newInstance(Class.java:442)
    at sun.font.FontManagerFactory$1.run(FontManagerFactory.java:83)
    at java.security.AccessController.doPrivileged(Native Method)
    at sun.font.FontManagerFactory.getInstance(FontManagerFactory.java:74)
    at java.awt.Font.getFont2D(Font.java:491)
    at java.awt.Font.canDisplayUpTo(Font.java:2060)
    at java.awt.font.TextLayout.singleFont(TextLayout.java:470)
    at java.awt.font.TextLayout.<init>(TextLayout.java:531)
    at org.apache.poi.ss.util.SheetUtil.getDefaultCharWidth(SheetUtil.java:275)
    at org.apache.poi.xssf.streaming.AutoSizeColumnTracker.<init>(AutoSizeColumnTracker.java:117)
    at org.apache.poi.xssf.streaming.SXSSFSheet.<init>(SXSSFSheet.java:82)
    at org.apache.poi.xssf.streaming.SXSSFWorkbook.createAndRegisterSXSSFSheet(SXSSFWorkbook.java:658)
    at org.apache.poi.xssf.streaming.SXSSFWorkbook.createSheet(SXSSFWorkbook.java:679)
    at org.apache.poi.xssf.streaming.SXSSFWorkbook.createSheet(SXSSFWorkbook.java:90)
    at com.alibaba.excel.util.WorkBookUtil.createSheet(WorkBookUtil.java:51)
    at com.alibaba.excel.context.WriteContext.currentSheet(WriteContext.java:112)
    at com.alibaba.excel.write.ExcelBuilderImpl.addContent(ExcelBuilderImpl.java:69)
    at com.alibaba.excel.ExcelWriter.write1(ExcelWriter.java:106)
    at cn.cncommdata.template.utils.HeaderUtil.uploadWithData(HeaderUtil.java:311)
    at cn.cncommdata.template.rabbitmq.ExportDataReceiver.handler(ExportDataReceiver.java:131)
    at cn.cncommdata.template.rabbitmq.ExportDataReceiver.process(ExportDataReceiver.java:90)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.springframework.messaging.handler.invocation.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:181)
    at org.springframework.messaging.handler.invocation.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:114)
    at org.springframework.amqp.rabbit.listener.adapter.DelegatingInvocableHandler.invoke(DelegatingInvocableHandler.java:128)
    at org.springframework.amqp.rabbit.listener.adapter.HandlerAdapter.invoke(HandlerAdapter.java:61)
    at org.springframework.amqp.rabbit.listener.adapter.MessagingMessageListenerAdapter.invokeHandler(MessagingMessageListenerAdapter.java:188)
    ... 24 common frames omitted
2020-02-11 07:29:53.966 - WARN 1 ---
                [cTaskExecutor-1] s.a.r.l.ConditionalRejectingErrorHandler : Execution of Rabbit message listener failed.

問(wèn)題排查

經(jīng)過(guò)測(cè)試溝通發(fā)現(xiàn),項(xiàng)目部署人員使用的jdk是openjdk,導(dǎo)致報(bào)上面的問(wèn)題。

解決方案

將openjdk換為sunjdk。

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • mybatis?like模糊查詢特殊字符報(bào)錯(cuò)轉(zhuǎn)義處理方式

    mybatis?like模糊查詢特殊字符報(bào)錯(cuò)轉(zhuǎn)義處理方式

    這篇文章主要介紹了mybatis?like模糊查詢特殊字符報(bào)錯(cuò)轉(zhuǎn)義處理方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • 淺談java字符串比較到底應(yīng)該用==還是equals

    淺談java字符串比較到底應(yīng)該用==還是equals

    這篇文章主要介紹了淺談java字符串比較到底應(yīng)該用==還是equals,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • Maven腳手架如何基于jeecg實(shí)現(xiàn)快速開(kāi)發(fā)

    Maven腳手架如何基于jeecg實(shí)現(xiàn)快速開(kāi)發(fā)

    這篇文章主要介紹了Maven腳手架如何基于jeecg實(shí)現(xiàn)快速開(kāi)發(fā),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • 使用Spring AntPathMatcher的doMatch方法

    使用Spring AntPathMatcher的doMatch方法

    這篇文章主要介紹了使用Spring AntPathMatcher的doMatch方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • java反射機(jī)制實(shí)戰(zhàn)示例分享

    java反射機(jī)制實(shí)戰(zhàn)示例分享

    這篇文章主要介紹了java反射機(jī)制實(shí)戰(zhàn)示例,需要的朋友可以參考下
    2014-03-03
  • Spring?MVC請(qǐng)求處理流程和九大組件詳解

    Spring?MVC請(qǐng)求處理流程和九大組件詳解

    這篇文章主要介紹了Spring?MVC請(qǐng)求處理流程和九大組件,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2023-12-12
  • Java中命令行參數(shù)--與-D的區(qū)別

    Java中命令行參數(shù)--與-D的區(qū)別

    本文主要介紹了Java中命令行參數(shù)--與-D的區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • java 基礎(chǔ)之final、finally和finalize的區(qū)別

    java 基礎(chǔ)之final、finally和finalize的區(qū)別

    這篇文章主要介紹了java 基礎(chǔ)之final、finally和finalize的區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • 使用Java編寫(xiě)圖形化的菜單的教程

    使用Java編寫(xiě)圖形化的菜單的教程

    這篇文章主要介紹了使用Java編寫(xiě)圖形化的菜單的教程,需要的朋友可以參考下
    2015-10-10
  • Java Unsafe 類(lèi)的講解

    Java Unsafe 類(lèi)的講解

    這篇文章主要給大家分享了 Java Unsafe 類(lèi)的講解,文章圍繞Unsafe 類(lèi)的相關(guān)資料展開(kāi)詳細(xì)內(nèi)容,具有一定的參考價(jià)值需要的朋友可以參考一下
    2021-11-11

最新評(píng)論