Spring Boot «необработанное исключение, возникшее в DoneCallback» закрывает приложение, несмотря на обработку исключения - PullRequest
0 голосов
/ 06 ноября 2018

Я запускаю приложение, которое работает параллельно с 30 параллельными загрузками, поэтому у меня есть проблемы со столкновениями, с которыми мне нужно иметь дело.

Я получаю приведенное ниже исключение из следующего кода. Мне не понятно, почему исключение не обрабатывается.

Исключение вызывает остановку работы приложения Spring Boot, даже если у меня есть логика для перехвата исключений в коде, который вызывает этот код. Существует несколько уровней обработки исключений, но исключение не обрабатывается.

    // check to see if the product exists
    if (repository.existsByAsin(asin))
       sPFBT2 = repository.findByAsin(asin).get(
    } else {

      //product does not exists.. create product
     sPFBT2 = new SProduct(asin, new Long(0));
     sPFBT2.setDownload(new Download(sPFBT2)));
    try {
        repository.saveAndFlush(sPFBT2);
    } catch (Exception e)
      //product does exists.. find in database
      sPFBT2 = null;
      sPFBT2 = findByAsin(asin).get(0);
      sPFBT2.setDownload(new Download(sPFBT2);
      repository.saveAndFlush(sPFBT2);
     }
    }




<record>
  <date>2018-11-06T11:29:51</date>
  <millis>1541503791418</millis>
  <sequence>211</sequence>
  <logger>org.jdeferred.impl.AbstractPromise</logger>
  <level>SEVERE</level>
  <class>org.jdeferred.impl.AbstractPromise</class>
  <method>triggerDone</method>
  <thread>23</thread>
  <message>an uncaught exception occured in a DoneCallback</message>
  <exception>
    <message>org.springframework.dao.DataIntegrityViolationException: could not execute statement; SQL [n/a]; constraint [idx_downloadProduct]; nested exception is org.hibernate.exception.ConstraintViolationException: could not execute statement</message>
    <frame>
      <class>org.springframework.orm.jpa.vendor.HibernateJpaDialect</class>
      <method>convertHibernateAccessException</method>
      <line>259</line>
    </frame>
    <frame>
      <class>org.springframework.orm.jpa.vendor.HibernateJpaDialect</class>
      <method>translateExceptionIfPossible</method>
      <line>225</line>
    </frame>
    <frame>
      <class>org.springframework.orm.jpa.AbstractEntityManagerFactoryBean</class>
      <method>translateExceptionIfPossible</method>
      <line>527</line>
    </frame>
    <frame>
      <class>org.springframework.dao.support.ChainedPersistenceExceptionTranslator</class>
      <method>translateExceptionIfPossible</method>
      <line>61</line>
    </frame>
    <frame>
      <class>org.springframework.dao.support.DataAccessUtils</class>
      <method>translateIfNecessary</method>
      <line>242</line>
    </frame>
    <frame>
      <class>org.springframework.dao.support.PersistenceExceptionTranslationInterceptor</class>
      <method>invoke</method>
      <line>153</line>
    </frame>
    <frame>
      <class>org.springframework.aop.framework.ReflectiveMethodInvocation</class>
      <method>proceed</method>
      <line>185</line>
    </frame>
    <frame>
      <class>org.springframework.data.jpa.repository.support.CrudMethodMetadataPostProcessor$CrudMethodMetadataPopulatingMethodInterceptor</class>
      <method>invoke</method>
      <line>135</line>
    </frame>
    <frame>
      <class>org.springframework.aop.framework.ReflectiveMethodInvocation</class>
      <method>proceed</method>
      <line>185</line>
    </frame>
    <frame>
      <class>org.springframework.aop.interceptor.ExposeInvocationInterceptor</class>
      <method>invoke</method>
      <line>92</line>
    </frame>
    <frame>
      <class>org.springframework.aop.framework.ReflectiveMethodInvocation</class>
      <method>proceed</method>
      <line>185</line>
    </frame>
    <frame>
      <class>org.springframework.data.repository.core.support.SurroundingTransactionDetectorMethodInterceptor</class>
      <method>invoke</method>
      <line>61</line>
    </frame>
    <frame>
      <class>org.springframework.aop.framework.ReflectiveMethodInvocation</class>
      <method>proceed</method>
      <line>185</line>
    </frame>
    <frame>
      <class>org.springframework.aop.framework.JdkDynamicAopProxy</class>
      <method>invoke</method>
      <line>212</line>
    </frame>
    <frame>
      <class>com.sun.proxy.$Proxy81</class>
      <method>saveAndFlush</method>
    </frame>
    <frame>
      <class>com.jahtoe.tech.fbtdownloader.KEEPA</class>
      <method>lambda$getProductsInfo$1</method>
      <line>222</line>
    </frame>
    <frame>
      <class>org.jdeferred.impl.AbstractPromise</class>
      <method>triggerDone</method>
      <line>107</line>
    </frame>
    <frame>
      <class>org.jdeferred.impl.AbstractPromise</class>
      <method>triggerDone</method>
      <line>98</line>
    </frame>
    <frame>
      <class>org.jdeferred.impl.DeferredObject</class>
      <method>resolve</method>
      <line>70</line>
    </frame>
    <frame>
      <class>com.keepa.api.backend.KeepaAPI</class>
      <method>lambda$sendRequest$2</method>
      <line>180</line>
    </frame>
    <frame>
      <class>java.util.concurrent.ThreadPoolExecutor</class>
      <method>runWorker</method>
      <line>1149</line>
    </frame>
    <frame>
      <class>java.util.concurrent.ThreadPoolExecutor$Worker</class>
      <method>run</method>
      <line>624</line>
    </frame>
    <frame>
      <class>java.lang.Thread</class>
      <method>run</method>
      <line>748</line>
    </frame>
  </exception>
</record>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...