From 7d03d9fe3714a10fdd51f24e3c84da31a36f4ad8 Mon Sep 17 00:00:00 2001
From: wzp <2040239371@qq.com>
Date: 星期二, 15 七月 2025 14:28:14 +0800
Subject: [PATCH] fix:修复docker转化pdf文件卡顿和IO暴涨问题。 用单例控制docker转化,并监控docker状态

---
 src/main/java/com/ots/common/utils/poi/WordUtil.java |  178 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 172 insertions(+), 6 deletions(-)

diff --git a/src/main/java/com/ots/common/utils/poi/WordUtil.java b/src/main/java/com/ots/common/utils/poi/WordUtil.java
index 785a6ea..44f60fa 100644
--- a/src/main/java/com/ots/common/utils/poi/WordUtil.java
+++ b/src/main/java/com/ots/common/utils/poi/WordUtil.java
@@ -12,6 +12,7 @@
 import com.ots.project.exam.domain.TReportTemplate;
 import com.ots.project.exam.dto.JAQTableStyle;
 import com.ots.project.exam.dto.WordParam;
+import com.ots.project.tool.PdfDockerUtil;
 import com.ots.project.tool.PdfUtil;
 import com.ots.project.tool.ShellTool;
 import com.ots.project.tool.exam.ExamUtil;
@@ -22,6 +23,8 @@
 import com.ots.project.tool.report.APIFan.chart.APIFanChart;
 import com.ots.project.tool.report.CIAQ.chart.CIAQChart;
 import com.ots.project.tool.report.JAQ.condition.JAQTeam;
+import com.ots.project.tool.report.LAQ.chart.LAQAllChart;
+import com.ots.project.tool.report.LAQ.chart.LAQAllPng;
 import com.ots.project.tool.report.LAQ.chart.LAQChart;
 import com.ots.project.tool.report.MAQTR.chart.MAQTRChart;
 import com.ots.project.tool.report.PAQ.chart.PAQChart;
@@ -50,6 +53,9 @@
 import java.io.*;
 import java.time.LocalDate;
 import java.util.*;
+import java.util.concurrent.CompletableFuture;
+import java.util.concurrent.ExecutorService;
+import java.util.concurrent.Executors;
 import java.util.regex.Matcher;
 import java.util.regex.Pattern;
 
@@ -1231,7 +1237,7 @@
         } catch (Exception e) {
             e.printStackTrace();
         }
-
+        //鍒犻櫎鏂囦欢
         deleteFileByStr(deleteFileStrList);
         return AjaxResult.success(fileName + ".zip");
     }
@@ -1256,15 +1262,23 @@
             reportType = getTypeIfIsSAQ(tReportTemplate, reportType);
             reportType = getPositionIfJAQ(textMap, reportType);
             reportName = textMap.get("sendEmailFileName") + "_" + reportType + "_" + ReportTypeNameEnum.valueOf(tReportTemplate.getTemplateType()).getCode() + "_" + ReportTypeNameEnum.valueOf(tReportTemplate.getLangType()).getCode() + ".docx";
+            reportName = reportName.replace("\t","");
             reportName = reportName.replaceAll(" ", "_");
 
             //妯℃澘鏂囦欢闇�瑕佸姞閿�
             out = getDownLoadFileOutputStream(reportName);
             //synchronized (fileName.intern()){
                 //String templateType = tReportTemplate.getTemplateType();
-                setChageWord(fileName, out, textMap, tReportTemplate.getReportType(),tReportTemplate.getDataPath(), autoTableMap);
-                out.flush();
-                changColorIfJAQ(textMap, out, reportName, tReportTemplate.getReportType());
+            long startTime1 = System.currentTimeMillis();
+            setChageWord(fileName, out, textMap, tReportTemplate.getReportType(), tReportTemplate.getDataPath(), autoTableMap);
+            // 鑾峰彇缁撴潫鏃堕棿
+            long endTime1 = System.currentTimeMillis();
+            // 璁$畻鑰楁椂锛堝崟浣嶏細姣锛�
+            long duration1 = endTime1 - startTime1;
+            log.info("setChageWord 绋嬪簭鎵ц鑰楁椂锛�" + duration1 + " 姣锛岀敓鎴愭姤鍛婏細"+reportName);
+
+            out.flush();
+            changColorIfJAQ(textMap, out, reportName, tReportTemplate.getReportType());
             //}
 
             //PAQ銆丮AQTR閲囩敤銆丆IAQ銆丄PIFan鏂扮殑doc杞琾df
@@ -1272,7 +1286,17 @@
                     || ReportTypeEnum.CIAQ.getCode().equals(reportType) ||ReportTypeEnum.API_Fan.getCode().equals(reportType)){
                 PdfUtil.convertPDF(EssConfig.getProfile() + "/" + reportName);
             }else if(ReportTypeEnum.LAQ.getCode().equals(reportType)){
-                PdfUtil.dockerConvertPDF(EssConfig.getProfile(),EssConfig.getDocx2pdfPath(),reportName);
+                // 鑾峰彇寮�濮嬫椂闂�
+                long startTime = System.currentTimeMillis();
+//                PdfUtil.dockerConvertPDF(EssConfig.getProfile(),EssConfig.getDocx2pdfPath(),reportName);
+                PdfDockerUtil.convertPDF(EssConfig.getProfile(),EssConfig.getDocx2pdfPath(),reportName);
+
+                // 鑾峰彇缁撴潫鏃堕棿
+                long endTime = System.currentTimeMillis();
+                // 璁$畻鑰楁椂锛堝崟浣嶏細姣锛�
+                long duration = endTime - startTime;
+                log.info("dockerConvertPDF 绋嬪簭鎵ц鑰楁椂锛�" + duration + " 姣锛岀敓鎴愭姤鍛婏細"+reportName);
+
             }else{
                 ShellTool.execLibreofficeCommand("pdf", EssConfig.getProfile() + "/" + reportName, EssConfig.getProfile() + "/");
                 // ShellTool shellTool = ShellTool.builder();
@@ -1294,6 +1318,128 @@
         }
         return zipFilePath;
     }
+
+
+    /**
+     * LAQ浣跨敤-----澶參浜嗐�傚お鎱簡
+     * @param fileName
+     * @param tReportTemplate
+     * @param textMap
+     * @param autoTableMap
+     * @param deleteFileStrList
+     * @return
+     */
+    private static List<String> reportNameList = new ArrayList<>();
+//    public static String makeReportFileForLAQ(String fileName, TReportTemplate tReportTemplate, Map<String, Object> textMap, Map<Integer, Map<Integer, List<String[]>>> autoTableMap, List<String> deleteFileStrList,Integer index,Integer totalNum,Boolean cleanFlag) {
+//        String returnMessage = "瀵煎嚭妯℃澘杞Щ閿欒:";
+//        InputStream in = null;
+//        FileOutputStream out = null;
+//        String zipFilePath = "";
+//        String reportName = "";
+//
+//        if(cleanFlag)
+//        {
+//            reportNameList = new ArrayList<>();
+//        }
+//
+//        try {
+//
+//            String reportType = tReportTemplate.getReportType();
+//            reportName = textMap.get("sendEmailFileName") + "_" + reportType + "_" + ReportTypeNameEnum.valueOf(tReportTemplate.getTemplateType()).getCode() + "_" + ReportTypeNameEnum.valueOf(tReportTemplate.getLangType()).getCode() + ".docx";
+//            reportName = reportName.replaceAll(" ", "_");
+//
+//            reportNameList.add(reportName);
+//
+//            //妯℃澘鏂囦欢闇�瑕佸姞閿�
+//            out = getDownLoadFileOutputStream(reportName);
+//
+//            long startTime1 = System.currentTimeMillis();
+//            setChageWord(fileName, out, textMap, tReportTemplate.getReportType(), tReportTemplate.getDataPath(), autoTableMap);
+//            // 鑾峰彇缁撴潫鏃堕棿
+//            long endTime1 = System.currentTimeMillis();
+//            // 璁$畻鑰楁椂锛堝崟浣嶏細姣锛�
+//            long duration1 = endTime1 - startTime1;
+//            log.info("setChageWord 绋嬪簭鎵ц鑰楁椂锛�" + duration1 + " 姣锛岀敓鎴愭姤鍛婏細"+reportName);
+//
+//            out.flush();
+//
+////            if(ReportTypeEnum.LAQ.getCode().equals(reportType)){
+////                // 鑾峰彇寮�濮嬫椂闂�
+////                long startTime = System.currentTimeMillis();
+////
+////                PdfUtil.dockerConvertPDF(EssConfig.getProfile(),EssConfig.getDocx2pdfPath(),reportName);
+////                // 鑾峰彇缁撴潫鏃堕棿
+////                long endTime = System.currentTimeMillis();
+////                // 璁$畻鑰楁椂锛堝崟浣嶏細姣锛�
+////                long duration = endTime - startTime;
+////                log.info("dockerConvertPDF 绋嬪簭鎵ц鑰楁椂锛�" + duration + " 姣锛岀敓鎴愭姤鍛婏細"+reportName);
+////            }
+//            if(Objects.equals(index, totalNum))
+//            {
+//                //骞惰杞崲
+//                execLAQ2PDF(reportNameList);
+//            }
+//
+//            zipFilePath = getPdfPath(reportName);
+//
+//            deleteFileStrList.add(EssConfig.getProfile() + "/" + reportName);
+//        } catch (Exception ex) {
+//            returnMessage = returnMessage + ex.getMessage();
+//            deleteFileStrList.add(EssConfig.getProfile() + "/" + reportName);
+//            log.error("瀵煎嚭妯℃澘杞Щ閿欒锛歿}\n妫�鏌ユ枃浠讹細" + fileName, returnMessage, ex);
+//        } finally {
+//            closeChannel(out);
+//            closeChannel(in);
+//        }
+//        return zipFilePath;
+//    }
+
+
+    private static void execLAQ2PDF(List<String> reportNames)
+    {
+        // 鑾峰彇寮�濮嬫椂闂�
+        long startTime = System.currentTimeMillis();
+        // 鎺у埗骞惰鎵ц鐨勬渶澶х嚎绋嬫暟
+        int parallelism = 2; // 璁剧疆涓轰綘甯屾湜鐨勫苟琛屾暟閲�
+
+        // 鍒涘缓涓�涓浐瀹氬ぇ灏忕殑绾跨▼姹�
+        ExecutorService executor = Executors.newFixedThreadPool(parallelism);
+
+        // 鍒涘缓涓�涓� CompletableFuture 鍒楄〃锛屾瘡涓� CompletableFuture 琛ㄧず涓�涓紓姝ヤ换鍔�
+        List<CompletableFuture<Void>> futures = new ArrayList<>();
+
+        // 鏋勫缓寮傛浠诲姟鍒楄〃
+        for (String reportName : reportNames) {
+            CompletableFuture<Void> future = CompletableFuture.runAsync(() -> {
+                try {
+                    long oneTime = System.currentTimeMillis();
+                    PdfUtil.dockerConvertPDF(EssConfig.getProfile(), EssConfig.getDocx2pdfPath(), reportName);
+                    long twoTime = System.currentTimeMillis();
+                    long dura = twoTime - oneTime;
+                    log.info("杞崲鎴愬姛锛� " + reportName + " successfully.鑰楁椂锛�"+dura);
+                } catch (Exception e) {
+                    log.info("杞崲澶辫触锛� " + reportName + ": " + e.getMessage());
+                }
+            }, executor); // 浣跨敤鎸囧畾鐨勭嚎绋嬫睜鎵ц浠诲姟
+            futures.add(future);
+        }
+
+        // 绛夊緟鎵�鏈夊紓姝ヤ换鍔″畬鎴�
+        CompletableFuture.allOf(futures.toArray(new CompletableFuture[0])).join();
+
+        // 鍏抽棴绾跨▼姹�
+        executor.shutdown();
+        // 鑾峰彇缁撴潫鏃堕棿
+        long endTime = System.currentTimeMillis();
+        // 璁$畻鑰楁椂锛堝崟浣嶏細姣锛�
+        long duration = endTime - startTime;
+        log.info("execLAQ2PDF 绋嬪簭鎵ц鑰楁椂锛�" + duration + " 姣");
+        log.info("鎵�鏈夌嚎绋嬮兘鎵ц瀹屾垚锛�");
+    }
+
+
+
+
     @Nullable
     private static String getPositionIfJAQ(Map<String, Object> textMap, String reportType) {
         if (Objects.equals(reportType, "JAQ")) {
@@ -1315,10 +1461,14 @@
     private static String getPdfPath(String reportName) {
         return reportName.substring(0, reportName.lastIndexOf(".")) + ".pdf";
     }
+
+
+    //鍒犻櫎鏂囦欢
     public static void deleteFileByStr(List<String> deleteFileStrList) {
 
         for (String deleteStr : deleteFileStrList) {
             File file = new File(deleteStr);
+            log.info("鍒犻櫎鏂囦欢锛�"+deleteStr);
             file.delete();
         }
     }
@@ -1407,6 +1557,12 @@
 
         //璁剧疆鍥捐〃鎺т欢
         changChart(textMap, document, reportType,dataPath);
+
+        //濡傛灉鏄疞AQ鐨勫叏鏅浘锛岃缃浘琛�
+        if (StringUtils.equals(reportType, ReportTypeEnum.LAQ.getCode())&& textMap.containsKey("allList")){
+            LAQAllPng.changeChart(document,textMap);
+        }
+
         document.write(out);
     }
 
@@ -1563,7 +1719,17 @@
             } else if (StringUtils.equals(reportType, ReportTypeEnum.CIAQ.getCode())) {
                 CIAQChart.changeChart(document, textMap);
             } else if (StringUtils.equals(reportType, ReportTypeEnum.LAQ.getCode())) {
-                LAQChart.changeChart(document, textMap);
+                if(textMap.containsKey("allList"))
+                {
+                    log.info("銆愮敓鎴愬叏鏅浘鎶ュ憡銆�");
+                    //濡傛灉鍖呭惈allList锛屽垯娓叉煋鍏ㄦ櫙鍥惧浘琛�
+                    LAQAllChart.changeChart(document,textMap);
+                }
+                else
+                {
+                    log.info("鐢熸垚鐨勬槸涓汉鐢ㄦ埛鎶ュ憡");
+                    LAQChart.changeChart(document, textMap);
+                }
             } else if(StringUtils.equals(reportType, ReportTypeEnum.API_Fan.getCode()))
             {
                 APIFanChart.changeChart(document,textMap);

--
Gitblit v1.9.1