事务完成后Hibernate不释放Connection

时间:2013-10-02 18:38:49

标签: java spring hibernate transactions

我正在使用spring事务模板在线程中执行多个事务,因为Spring事务模板是线程安全的,但是它不会长时间释放连接。我正在使用由tomcat jndi context配置的c3p0连接池。

以下是代码段:

for (SearchProcessorType[] processorTypes : getProcessorChainTypes()) {
        if (processorTypes.length > 1) {
        ExecutorService doerService = Executors.newFixedThreadPool(processorTypes.length);

        for (final SearchProcessorType processorType : processorTypes) {
            if(searchData.getException() != null) {
                if(searchData.getException() instanceof SearchException) {
                    throw (SearchException)searchData.getException(); 
                }
                throw new RuntimeException(searchData.getException().getMessage());
            }
            doerService.submit(new Runnable() {

                @Override
                public void run() {

                    try {

                        if (!searchData.isSkipType(processorType)) {
                            final SearchProcessor processsor = SearchProcessor.get(processorType);
                            if (authentication != null) {
                                SecurityContextHolder.getContext().setAuthentication(authentication);
                            }
                            if (processsor.isTransactional()) {
                                transactionTemplate.execute(new TransactionCallbackWithoutResult() {

                                    @Override
                                    protected void doInTransactionWithoutResult(TransactionStatus status) {
                                        processsor.process(searchData, (SearchResponse<Object>) response);

                                    }
                                });
                            } else {
                                processsor.process(searchData, (SearchResponse<Object>) response);
                            }
                        }
                    } catch (Exception ex) {
                        searchData.setException(ex);
                    }
                }
            });
        }
        doerService.shutdown();
        while (!doerService.isTerminated()) {
            // Wait for processors to get completed
        }
        if(searchData.getException() != null) {
            if (searchData.getException() instanceof SearchException) {
                throw (SearchException) searchData.getException();
            } else {
                throw new RuntimeException(searchData.getException());
            }
        }
    } else if (!searchData.isSkipType(processorTypes[0])) {
        SearchProcessor.get(processorTypes[0]).process(searchData, (SearchResponse<Object>) response);
    }
}

0 个答案:

没有答案