All Downloads are FREE. Search and download functionalities are using the official Maven repository.

me.wuwenbin.modules.mongodb.factory.MongoFactory Maven / Gradle / Ivy

package me.wuwenbin.modules.mongodb.factory;

import com.mongodb.MongoClient;
import com.mongodb.MongoClientOptions;
import com.mongodb.MongoCredential;
import com.mongodb.ServerAddress;
import me.wuwenbin.modules.mongodb.dao.MongoAccessor;
import me.wuwenbin.modules.mongodb.dao.MongoDbTemplate;
import me.wuwenbin.modules.mongodb.support.MongoContextHolder;
import me.wuwenbin.modules.mongodb.support.core.MongoDataSource;
import me.wuwenbin.modules.mongodb.support.exception.DataSourceKeyNotExistException;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.data.mongodb.MongoDbFactory;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.SimpleMongoDbFactory;
import org.springframework.stereotype.Component;

import java.util.Hashtable;
import java.util.List;
import java.util.Map;

/**
 * 和spring一起初始化做一些操作,并实例化MongoClient集群
 * Created by wuwenbin on 2017/4/22.
 */
@Component
public class MongoFactory implements InitializingBean {


    /**
     * 多个mongo连接(一个集群是在一个mongo中)此处的多个仅仅是指配置上的多台mongo数据源,并不是集群
     */
    private Map mongoDataSources;

    /**
     * 存放mongoDao的map类
     */
    private Map mongoDaoMap = new Hashtable<>();

    private MongoDataSource defaultMongoDataSource;

    private MongoDataSource dynamicMongoDataSource;

    /**
     * 此Mongo连接的默认操作的数据库的dao
     */
    public MongoAccessor defaultMongoDao;

    /**
     * 此Mongo连接的动态操作数据库的dao,默认值和{@link #defaultMongoDao}一样
     */
    public MongoAccessor dynamicMongoDao;

    public void setMongoDataSources(Map mongoDataSources) {
        this.mongoDataSources = mongoDataSources;
    }

    /**
     * 根据xml中配置设置默认的MongoDao
     *
     * @param dataSource
     */
    public synchronized void setDefaultMongoDao(MongoDataSource dataSource) {
        this.defaultMongoDataSource = dataSource;
        this.dynamicMongoDataSource = this.defaultMongoDataSource;
        List seeds = dataSource.getSeeds();
        MongoClientOptions options = dataSource.getMongoClientOptions();
        List credentials = dataSource.getMongoCredentials();
        MongoClient mongoClient = new MongoClient(seeds, credentials, options);
        MongoDbFactory dbFactory = new SimpleMongoDbFactory(mongoClient, dataSource.getDefaultDatabase());
        this.defaultMongoDao = new MongoDbTemplate(new MongoTemplate(dbFactory, dataSource.getMongoConverter()));
        this.dynamicMongoDao = this.defaultMongoDao;
    }


    /**
     * 根据当前线程中的key变量值来动态数据源。
     * 

* 有3中情况切换. * 1、仅切换数据源,即根据xml中配置的key来切换不同数据源的mongo。变动数据源,默认数据库按照初始化的不变 * 2、仅切换默认操作文档(数据库),即变更此同一数据源下的文档(数据库)。数据源不变,变动操作文档(数据库) * 3、以上两种情况同时发生 */ public synchronized void determineDynamicMongoDao() { String currentThreadKey = MongoContextHolder.getHolder().getKey(); String currentThreadDatabase = MongoContextHolder.getHolder().getDatabase(); if (!mongoDataSources.containsKey(currentThreadKey)) { throw new DataSourceKeyNotExistException(); } this.dynamicMongoDataSource = mongoDataSources.get(currentThreadKey); this.dynamicMongoDao = getMongoDbDaoByKeyAndDataBase(currentThreadKey, currentThreadDatabase); } public synchronized void determineDynamicMongoDaoByKey() { String currentThreadKey = MongoContextHolder.getHolder().getKey(); if (!mongoDataSources.containsKey(currentThreadKey)) { throw new DataSourceKeyNotExistException(); } this.dynamicMongoDataSource = mongoDataSources.get(currentThreadKey); this.dynamicMongoDao = getMongoDbDaoByKey(currentThreadKey); } public synchronized void determineDynamicMongoDaoByDatabase() { String currentThreadDatabase = MongoContextHolder.getHolder().getDatabase(); this.dynamicMongoDao = getMongoDbDaoByDataBase(currentThreadDatabase); } @Override public void afterPropertiesSet() throws Exception { if (mongoDataSources != null && mongoDataSources.size() > 0 && !mongoDataSources.isEmpty()) { for (String key : mongoDataSources.keySet()) { if (mongoDaoMap == null || !mongoDaoMap.containsKey(key)) { mongoDaoMap.put(key, getMongoDbDaoByKey(key)); } } } } /** * 根据key和默认数据库(文档)来获取MongoDbDao实例 * * @param key * @param defaultDatabase * @return */ private MongoAccessor getMongoDbDaoByKeyAndDataBase(String key, String defaultDatabase) { if (mongoDataSources.containsKey(key)) { MongoDataSource dataSource = mongoDataSources.get(key); List seeds = dataSource.getSeeds(); MongoClientOptions options = dataSource.getMongoClientOptions(); List credentials = dataSource.getMongoCredentials(); MongoClient mongoClient = new MongoClient(seeds, credentials, options); MongoDbFactory dbFactory = new SimpleMongoDbFactory(mongoClient, defaultDatabase); return new MongoDbTemplate(new MongoTemplate(dbFactory, dataSource.getMongoConverter())); } else { throw new DataSourceKeyNotExistException(); } } /** * 同{@link #getMongoDbDaoByKeyAndDataBase(String, String)},默认数据库为初始化设置的 * * @param key * @return */ private MongoAccessor getMongoDbDaoByKey(String key) { if (mongoDataSources.containsKey(key)) { MongoDataSource dataSource = mongoDataSources.get(key); List seeds = dataSource.getSeeds(); MongoClientOptions options = dataSource.getMongoClientOptions(); List credentials = dataSource.getMongoCredentials(); MongoClient mongoClient = new MongoClient(seeds, credentials, options); MongoDbFactory dbFactory = new SimpleMongoDbFactory(mongoClient, dataSource.getDefaultDatabase()); return new MongoDbTemplate(new MongoTemplate(dbFactory, dataSource.getMongoConverter())); } else { throw new DataSourceKeyNotExistException(); } } /** * 同{@link #getMongoDbDaoByKeyAndDataBase(String, String)},默认数据源不变,切换数据库(文档) * * @param database * @return */ private MongoAccessor getMongoDbDaoByDataBase(String database) { MongoDataSource dataSource = this.defaultMongoDataSource; List seeds = dataSource.getSeeds(); MongoClientOptions options = dataSource.getMongoClientOptions(); List credentials = dataSource.getMongoCredentials(); MongoClient mongoClient = new MongoClient(seeds, credentials, options); MongoDbFactory factory = new SimpleMongoDbFactory(mongoClient, database); return new MongoDbTemplate(new MongoTemplate(factory, dataSource.getMongoConverter())); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy