DataSourcePoolService.java 3.92 KB
Newer Older
eddie.woo's avatar
eddie.woo committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14
package pwc.taxtech.atms.service.impl;

import com.alibaba.druid.pool.DruidDataSource;
import com.google.common.collect.Maps;
import org.apache.commons.lang3.StringUtils;
import org.apache.commons.pool2.impl.GenericKeyedObjectPool;
import org.apache.commons.pool2.impl.GenericKeyedObjectPoolConfig;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.SqlSessionTemplate;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
15
import org.springframework.jdbc.core.JdbcTemplate;
eddie.woo's avatar
eddie.woo committed
16 17 18 19 20
import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;
import org.springframework.stereotype.Service;
import pwc.taxtech.atms.common.datasource.DataSourceConfig;
import pwc.taxtech.atms.common.datasource.DataSourceFactory;
import pwc.taxtech.atms.common.datasource.ShardingContextHolder;
21
import pwc.taxtech.atms.exception.ParameterException;
eddie.woo's avatar
eddie.woo committed
22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45

import javax.annotation.PostConstruct;
import javax.sql.DataSource;

@Service("DynamicDataSource")
public class DataSourcePoolService extends AbstractRoutingDataSource {
    private GenericKeyedObjectPool<String, DruidDataSource> dataSourcePool;

    @Value("${jdbc_url_demo}")
    private String demoUrl;
    @Value("${jdbc_user}")
    private String jdbcUser;
    @Value("${jdbc_password}")
    private String jdbcPwd;

    @PostConstruct
    public void init() throws Exception {
        DataSourceConfig config = new DataSourceConfig();
        config.setUrl(demoUrl);
        config.setUsername(jdbcUser);
        config.setPassword(jdbcPwd);
        GenericKeyedObjectPoolConfig poolConfig = new GenericKeyedObjectPoolConfig();
        poolConfig.setTestOnBorrow(true);
        poolConfig.setTestOnReturn(true);
eddie.woo's avatar
eddie.woo committed
46 47
        poolConfig.setMaxTotalPerKey(1);
        poolConfig.setMaxIdlePerKey(1);
eddie.woo's avatar
eddie.woo committed
48 49 50 51 52 53 54 55 56 57
        dataSourcePool = new GenericKeyedObjectPool<>(new DataSourceFactory(config), poolConfig);
        this.setTargetDataSources(Maps.newHashMap());
    }

    @Override
    protected Object determineCurrentLookupKey() {
        return ShardingContextHolder.getDataSourceKey();
    }

    @Override
eddie.woo's avatar
eddie.woo committed
58
    protected synchronized DataSource determineTargetDataSource() {
eddie.woo's avatar
eddie.woo committed
59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
        try {
            String key = ShardingContextHolder.getDataSourceKey();
            DruidDataSource dataSource = dataSourcePool.borrowObject(key);
            dataSourcePool.returnObject(key, dataSource);
            return dataSource;
        } catch (Exception e) {
            throw new RuntimeException("determineTargetDataSource error.", e);
        }
    }

    private void createDataSource(String key) {
        if (StringUtils.isBlank(key)) {
            throw new ParameterException("DataSource name is empty.");
        }
        try {
            dataSourcePool.addObject(key);
        } catch (Exception e) {
            throw new RuntimeException("createDataSource error.", e);
        }
    }

    @Bean
    public SqlSessionFactory dynamicSqlSessionFactory(
            @Qualifier("DynamicDataSource") DataSource dynamicDataSource)
            throws Exception {
        SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
        bean.setDataSource(dynamicDataSource);
        bean.setMapperLocations(new PathMatchingResourcePatternResolver()
87
                .getResources("classpath*:pwc/taxtech/atms/vat/dao/*Mapper.xml"));
eddie.woo's avatar
eddie.woo committed
88 89 90 91 92 93 94 95 96 97 98
        return bean.getObject();

    }

    @Bean
    public SqlSessionTemplate dynamicSqlSessionTemplate(
            @Qualifier("dynamicSqlSessionFactory") SqlSessionFactory sqlSessionFactory)
            throws Exception {
        return new SqlSessionTemplate(sqlSessionFactory);
    }

99 100 101 102 103
    @Bean
    public JdbcTemplate dynamicJdbcTemplate(@Qualifier("DynamicDataSource")DataSource dynamicDataSource) {
        return new JdbcTemplate(dynamicDataSource);
    }

eddie.woo's avatar
eddie.woo committed
104
}