Spring Batch Несколько сессий DataSource / Entitymanager закрыто - PullRequest
0 голосов
/ 09 декабря 2018

Я пытаюсь извлечь записи из базы данных SQLServer для сохранения в Mysql, используя Spring Boot и Sprin Batch (JpaPagingItemReader и JpaItemWriter).Я настроил несколько источников данных.Как бы я ни сталкивался с приведенной ниже ошибкой.

    org.springframework.batch.item.ItemStreamException: Error while closing item reader
    at org.springframework.batch.item.support.AbstractItemCountingItemStreamItemReader.close(AbstractItemCountingItemStreamItemReader.java:138)
    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.beans.factory.support.DisposableBeanAdapter.invokeCustomDestroyMethod(DisposableBeanAdapter.java:337)
    at org.springframework.beans.factory.support.DisposableBeanAdapter.destroy(DisposableBeanAdapter.java:271)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.destroyBean(DefaultSingletonBeanRegistry.java:571)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.destroySingleton(DefaultSingletonBeanRegistry.java:543)
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.destroySingleton(DefaultListableBeanFactory.java:957)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.destroySingletons(DefaultSingletonBeanRegistry.java:504)
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.destroySingletons(DefaultListableBeanFactory.java:964)
    at org.springframework.context.support.AbstractApplicationContext.destroyBeans(AbstractApplicationContext.java:1041)
    at org.springframework.context.support.AbstractApplicationContext.doClose(AbstractApplicationContext.java:1017)
    at org.springframework.context.support.AbstractApplicationContext.close(AbstractApplicationContext.java:967)
    at org.springframework.batch.core.launch.support.CommandLineJobRunner.start(CommandLineJobRunner.java:377)
    at org.springframework.batch.core.launch.support.CommandLineJobRunner.main(CommandLineJobRunner.java:597)
    at net.com.org.batch.MyApplication.main(MyApplication.java:15)
Caused by: java.lang.IllegalStateException: Session/EntityManager is closed
    at org.hibernate.internal.AbstractSharedSessionContract.checkOpen(AbstractSharedSessionContract.java:344)
    at org.hibernate.engine.spi.SharedSessionContractImplementor.checkOpen(SharedSessionContractImplementor.java:137)
    at org.hibernate.internal.AbstractSharedSessionContract.checkOpenOrWaitingForAutoClose(AbstractSharedSessionContract.java:350)
    at org.hibernate.internal.SessionImpl.close(SessionImpl.java:413)
    at org.springframework.batch.item.database.JpaPagingItemReader.doClose(JpaPagingItemReader.java:232)
    at org.springframework.batch.item.support.AbstractItemCountingItemStreamItemReader.close(AbstractItemCountingItemStreamItemReader.java:135)
    ... 17 common frames omitted
20:10:55.875 [main] DEBUG org.springframework.beans.factory.support.DefaultListableBeanFactory - Retrieved dependent beans for bean 'jpaMappingContext': [mySqljobRepository, sqlServerLogsRepository]

Ниже моя партия, пошаговая конфигурация

   @Autowired
private StepBuilderFactory stepBuilderFactory;

@Autowired
@Qualifier("mysqlEntityManager")
private LocalContainerEntityManagerFactoryBean mysqlLocalContainerEntityManagerFactoryBean;

@Autowired
@Qualifier("secondarySqlEntityManager")
private LocalContainerEntityManagerFactoryBean localContainerEntityManagerFactoryBean;

@Autowired
@Qualifier("mysqlTransactionManager")
private PlatformTransactionManager mySqlplatformTransactionManager;


@Autowired
@Qualifier("secondaryTransactionManager")
private PlatformTransactionManager secondaryTransactionManager;


@Autowired
private JobBuilderFactory jobBuilderFactory;

@Bean
public JpaPagingItemReader itemReader(PlatformTransactionManager secondaryTransactionManager) {
    JpaPagingItemReader<SqlServerJobLogs> serverJobLogsJpaPagingItemReader = new JpaPagingItemReader<>();
    serverJobLogsJpaPagingItemReader.setMaxItemCount(1000);
    serverJobLogsJpaPagingItemReader.setPageSize(100);
    serverJobLogsJpaPagingItemReader.setEntityManagerFactory(localContainerEntityManagerFactoryBean.getNativeEntityManagerFactory());
    serverJobLogsJpaPagingItemReader.setQueryString("select p from SqlServerJobLogs p");
    return serverJobLogsJpaPagingItemReader;
}

@Bean
public ItemProcessor itemProcessor() {
    return new DataItemProcessor();
}

@Bean
public ItemWriter itemWriter(PlatformTransactionManager mySqlplatformTransactionManager) {
    DataWriter dataWriter = new DataWriter();
    return dataWriter;
}

@Bean
public Step step() {
    return stepBuilderFactory.get("myJob").chunk(100).reader(itemReader(secondaryTransactionManager)).processor(itemProcessor()).writer(itemWriter(mySqlplatformTransactionManager)).build();
}

@Bean(name = "myJob")
public Job myJob() throws Exception {
    return jobBuilderFactory.get("myJob").start(step()).build();
}

@Bean
public ResourcelessTransactionManager resourcelessTransactionManager(){
    return new ResourcelessTransactionManager();
}

@Bean
public JobRepository jobRepository() throws Exception{
    MapJobRepositoryFactoryBean mapJobRepositoryFactoryBean = new MapJobRepositoryFactoryBean(resourcelessTransactionManager());
    return  mapJobRepositoryFactoryBean.getObject();
}
@Bean
public SimpleJobLauncher jobLauncher() throws Exception {
    SimpleJobLauncher simpleJobLauncher = new SimpleJobLauncher();
    simpleJobLauncher.setJobRepository(jobRepository());
    return simpleJobLauncher;
}

Я пытался настроить BatchConfigurer. Но не повезло.Пожалуйста, дайте мне знать, если мне нужно настроить что-то еще, кроме вышеупомянутых деталей

Заранее спасибо

1 Ответ

0 голосов
/ 11 января 2019

Я хотел бы ответить на вопрос.Большое спасибо @ MahmoudBenHassine

  1. Предоставление настраиваемого менеджера транзакций путем переопределения DefaultBatchConfigurer # getTransactionManager работает только с Spring Batch v4.1 +, как сказано в комментариях.Нам нужно использовать Spring Boot v2.1, чтобы иметь Spring Batch 4.1
...