https://pastein.ru/t/Sl

  скопируйте уникальную ссылку для отправки

Загрузка данных


   
Данные из heapDump - на момент средних зависаний в Heap дампе находилось более миллиарда объектов ResultSet и более 300 не закрытых соединений c бд.

public void getDynData(int labId) {
        Iterator var2 = this.rowsCount.entrySet().iterator(); 

        while(var2.hasNext()) {                                                                          //цикл, который может доходить до 22000 итераций (по количеству документов в базе)
            Entry<String, Integer> entry = (Entry)var2.next();
            int count = (Integer)entry.getValue();

            try {
                Connection con = ConnectionUtil.getXAConnection();                                       // открываем одно соединение

                try {
                    label56:                                                                              
                    for(int i = 1; i <= count; ++i) {   // еще цикл
                        PreparedStatement preparedStatement = con.prepareStatement(this.sqlDynData(i));  //открываем PrepearedStatement и ResultSet
                        preparedStatement.setString(1, (String)entry.getKey());
                        ResultSet set = preparedStatement.executeQuery();

                        while(true) {                                                                    //запускаем бесконечный цикл, который не закроется и оставит все наши соединения и resultset открытыми
                            int labCode;
                            do {                                                                          //запускаем еще цикл (Сложность алгоритма уже в районе O(n^4))
                                if (!set.next()) {
                                    continue label56;                                                           

                                if (labId <= 0) {
                                    break;
                                }

                                labCode = NumberUtils.parseInt(this.getValue(set, "labCode"));
                            } while(labCode != labId); 
  
                            ReestrModel reestrModel = new ReestrModel();                       
                            reestrModel.setDocumentID((String)entry.getKey());
                            reestrModel.setResName(this.getValue(set, "resname"));
                            reestrModel.setLabName(this.getValue(set, "labname"));
                            reestrModel.setLabNameCode(this.getValue(set, "labCode"));
                            reestrModel.setResGroup(this.getValue(set, "resgroup"));
                            reestrModel.setResGroupCode(this.getValue(set, "resGroupCode"));
                            reestrModel.setSubResGroup(this.getValue(set, "subresgroup"));
                            reestrModel.setSubResGroupCode(this.getValue(set, "subresgroupCode"));
                            reestrModel.setResMethod(this.getValue(set, "resmethod"));
                            reestrModel.setSerUnit(this.getValue(set, "serunit"));
                            reestrModel.setCoeficient(this.getValue(set, "coeficient"));
                            reestrModel.setTarCode(this.getValue(set, "tarcode"));
                            reestrModel.setBaseRate(this.getValue(set, "base_rate"));
                            reestrModel.setSerAmount(this.getValue(set, "seramount"));
                            reestrModel.setmSerAmount(this.getValue(set, "mseramount"));
                            reestrModel.setSubLabName(this.getValue(set, "subLabName"));
                            reestrModel.setSubLabNameCode(this.getValue(set, "subLabNameCode"));
                            this.reestrModels.add(reestrModel);                                
                        }
                    }
                } catch (Throwable var11) {                                                             // до сюда даже не дойдем из-за бесконечного цикла, соответственно ничего не закроем
                    if (con != null) {
                        try {
                            con.close();
                        } catch (Throwable var10) {
                            var11.addSuppressed(var10);
                        }
                    }

                    throw var11;
                }

                if (con != null) {
                    con.close();
                }
            } catch (Exception var12) {
                ;
            }
        }

    }