mongodb的封装和监控

1.mongo-order.xml

<?xml version="1.0" encoding="utf-8"?>

<config> 
  <value>{"maxConnectionIdleTime":60000,"connectionsPerHost":20,"threadsAllowedToBlockForConnectionMultiplier":15,"maxWaitTime":5000, "connectTimeout":3000,"socketTimeout":3000,"serverSelectionTimeout":3000,"standalone":false,"readPreference":"secondaryPreferred","servers":["mongo-replic-r1-car-all-test-db.01zhuanche.com:27017","mongo-replic-r2-car-all-test-db.01zhuanche.com:27017","mongo-replic-r3-car-all-test-db.01zhuanche.com:27017"]}</value> 
</config>

2.MongoEnum

public enum MongoEnum implements IMongo {
    OrderMongo("mongo-order"),
    DriverMongoMaster("mongo-driver-master"),
    DriverMongoSlave("mongo-driver-slave"),
    DispatcherOrderMongo("mongo-disp-order"),
    ;

    MongoEnum(String configName) {
        this.configName = configName;
    }

    @Override
    public String configKey() {
        return configName;
    }

    private String configName;

}

3.MongoConfig

@Configuration
public class MongoConfig {

    @Bean(name = "driverMongoTemplate" )
    public MongoTemplate getDriverMongoTemplate() {
        return new MongoTemplate( new SqMongoDbFactory(MongoEnum.DriverMongoSlave.get(),  "DriverDB" ));
    }

    @Bean(name = "driverMongoTemplateMaster" )
    public MongoTemplate getDriverMasterMongoTemplate() {
        return new MongoTemplate( new SqMongoDbFactory(MongoEnum.DriverMongoMaster.get(),  "DriverDB" ));
    }

    @Bean(name = "operatingMongoTemplate" )
    public MongoTemplate getMongoTemplate() {
        return new MongoTemplate( new SqMongoDbFactory(MongoEnum.DriverMongoSlave.get(),  "OperatingDB" ));
    }

    @Bean(name = "orderDispatcherMongoTemplate" )
    public MongoTemplate getOrderDispatcherMongoTemplate() {
        return new MongoTemplate( new SqMongoDbFactory(MongoEnum.DispatcherOrderMongo.get(),  "OrderDB" ));
    }
}

4.SqMongoDbFactory

public class SqMongoDbFactory implements DisposableBean, MongoDbFactory {

    private final MongoClientHolder holder;

    private final String databaseName;

    private final PersistenceExceptionTranslator exceptionTranslator;

    private WriteConcern writeConcern;

    public SqMongoDbFactory(MongoClientHolder holder, String databaseName) {

        Assert.hasText(databaseName, "Database name must not be empty");
        Assert.isTrue(databaseName.matches("[\\w-]+"),
                "Database name must only contain letters, numbers, underscores and dashes!");
        this.holder = holder;
        this.databaseName = databaseName;
        this.exceptionTranslator = new MongoExceptionTranslator();
    }

    public void setWriteConcern(WriteConcern writeConcern) {
        this.writeConcern = writeConcern;
    }

    @Override
    public void destroy() throws Exception {
        holder.getClient().close();
    }

    @Override
    public DB getDb() throws DataAccessException {
        return getDb(databaseName);
    }

    @Override
    public DB getDb(String dbName) throws DataAccessException {
        Assert.hasText(dbName, "Database name must not be empty.");
        DB db = holder.getDB(dbName);
        if (writeConcern != null) {
            db.setWriteConcern(writeConcern);
        }
        return db;
    }

    @Override
    public PersistenceExceptionTranslator getExceptionTranslator() {
        return this.exceptionTranslator;
    }
}

5.IMongo

public int
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot是一个开源的Java开发框架,用于简化Spring应用的开发和部署。MongoDB是一个面向文档的NoSQL数据库,具有高性能、可扩展和灵活的特点。在使用Spring Boot开发应用程序时,可以通过封装MongoDB来简化与数据库的交互。 在Spring Boot中使用MongoDB,通常需要引入相关的依赖库。可以在项目的pom.xml文件中添加以下依赖: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency> ``` 引入该依赖后,Spring Boot会自动配置MongoDB的连接信息,包括数据库地址、端口号、用户名和密码等。可以在配置文件中设置相关的配置参数,如application.properties或application.yml。 通过MongoTemplate类,可以进行MongoDB的各种操作,例如插入数据、查询数据、更新数据和删除数据等。在使用MongoTemplate时,可以通过编写相应的Repository接口来定义数据库操作的方法。Spring Boot会根据方法的命名规则自动生成查询语句。 除了使用MongoTemplate进行数据库操作外,还可以使用Spring Data MongoDB来简化数据库操作。Spring Data MongoDB提供了各种注解和接口,可以通过编写实体类、定义接口方法和使用注解来进行数据访问和操作。 通过封装MongoDB,可以避免编写繁琐的数据库访问代码,提高开发效率。同时,Spring Boot提供了丰富的功能和插件,可以帮助开发者进行数据库操作的扩展和优化。使用Spring Boot和MongoDB的组合,可以轻松构建高性能、可扩展和灵活的应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值