java实现MongoDB连接池

1.写pom加驱动依赖

 <dependency>
        <groupId>org.mongodb</groupId>
        <artifactId>mongo-java-driver</artifactId>
        <version>3.12.0</version>
 </dependency>

2.建MongoManager类

package com.csii.mongodb;


import cn.hutool.json.JSONArray;
import com.mongodb.MongoClient;
import com.mongodb.MongoClientOptions;
import com.mongodb.ReadPreference;
import com.mongodb.ServerAddress;
import com.mongodb.client.FindIterable;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoCursor;
import com.mongodb.client.MongoDatabase;
import entities.DatabaseConnectionInfo;
import org.bson.Document;

import java.util.ArrayList;
import java.util.List;


public class MongoManager {

    private static MongoClient mongo;



    /**
     * @param
     * @param userName
     * @param pwd
     * 实例化dbName一个DB
     */
    public MongoManager( String userName, String pwd,DatabaseConnectionInfo databaseConnectionInfo ) {


        if(databaseConnectionInfo.isAuthentication()){
            if (userName == null || "".equals(userName)) {
                throw new NumberFormatException("userName is null");
            }
            if (pwd == null || "".equals(pwd)) {
                throw new NumberFormatException("pwd is null");
            }

        }
    }

    public MongoManager() {

    }


    /**
     * 使用配置参数实例化
     */
    /*public MongoManager() {
        this(MongoConfig.getDbName(), MongoConfig.getUserName(), MongoConfig.getPwd());
    }*/

    /**
     * @param tableName
     * @return
     * @Description: 获取表tableName的链接MongoCollection
     */
    public MongoCollection<Document> getDBCollection(String tableName, MongoDatabase db) {
        return db.getCollection(tableName);
    }

    /**
     * @Date:2014-3-19
     * @Author:lulei
     * @Description: mongo连接池初始化
     */
    public MongoClient init(DatabaseConnectionInfo databaseConnectionInfo) {
        if (databaseConnectionInfo.getHostIp() == null || databaseConnectionInfo.getHostIp().length() == 0) {
            throw new NumberFormatException("host is null");
        }
        if (databaseConnectionInfo.getPort() == null || databaseConnectionInfo.getPort().length() == 0) {
            throw new NumberFormatException("port is null");
        }

        try {
            //服务列表
            List<ServerAddress> replicaSetSeeds = new ArrayList<ServerAddress>();

             replicaSetSeeds.add(new ServerAddress(databaseConnectionInfo.getHostIp(), Integer.parseInt(databaseConnectionInfo.getPort())));

            //连接池参数设置

            MongoClientOptions clientOptions = new MongoClientOptions
                    .Builder().connectionsPerHost( databaseConnectionInfo.getConnectionsPerHost())
                    .threadsAllowedToBlockForConnectionMultiplier(databaseConnectionInfo.getThreadsAllowedToBlockForConnectionMultiplier()).maxWaitTime(2000).build();
            mongo = new MongoClient(replicaSetSeeds,clientOptions);

            //从服务器可读
            mongo.setReadPreference(ReadPreference.secondary());

        } catch (Exception e){
            e.printStackTrace();
        }
        return mongo;
    }

    /**
     * 使用配置参数实例化
     */
  /*  public MongoManager() {
        this(mongoDBConfig.getDbName(), mongoDBConfig.getUserName(), mongoDBConfig.getPwd());
    }*/

    /**
     * @Title: queryList
     * @Description: TODO 查询出全部的 记录
     * @param dbCollection
     * @return: void
     */
    public  List<Document> queryList(MongoCollection dbCollection) {
        JSONArray json = new JSONArray();
        //检索所有文档
        /**
         * 1. 获取迭代器FindIterable<Document>
         * 2. 获取游标MongoCursor<Document>
         * 3. 通过游标遍历检索出的文档集合
         * */
        FindIterable<Document> findIterable = dbCollection.find();
        MongoCursor<Document> mongoCursor = findIterable.iterator();

        List<Document> documentList = new ArrayList<Document>();

        Document document =new Document();
        try{
            while(mongoCursor.hasNext()){
                document=mongoCursor.next();

                documentList.add(document);
            }
        }catch (Exception e){
            System.err.println( e.getClass().getName() + ": " + e.getMessage() );
        }



        return documentList;
    }
   /* public static void main(String[] args) {
        String[] host = {"115.182.90.220"};
        int[] port = {31459};
        mongoDBConfig.setHost(host);
        mongoDBConfig.setPort(port);
        mongoDBConfig.setUserName("csdn");
        mongoDBConfig.setPwd("123456");
        MongoManager mongoManager = new MongoManager();


        // 查询该数据库所有的集合名
        for(String name : mongo.getDatabaseNames()){
            System.out.println(name);
        }

        String dtname = "";
        // 查询该数据库所有的集合名
        for(String name : mongo.getDatabaseNames()){
            dtname += name+",";
        }
        System.out.println("dtname:"+dtname);
        mongoDBConfig.setDbName("csii_dbus");

        db = mongo.getDB(mongoDBConfig.getDbName());
        DBCollection coll=mongoManager.getDBCollection("csii_dbus");
        mongoManager.queryList(coll);

    }*/



}

3.调用对应MongManager方法

  @GetMapping("/mongodb/database/coll")
    public CommonResult databaseColl(DatabaseConnectionInfo databaseConnectionInfo)
    {


        mongo= mongoManager.init(databaseConnectionInfo);

        String dtname = "";

        try{
            if(mongo!=null){
                if("database".equals(databaseConnectionInfo.getFlagType())){
                    for(String name : mongo.getDatabaseNames()){
                        dtname += name+",";
                    }
                    dtname.substring(0,dtname.length()-1);
                }else if("coll".equals(databaseConnectionInfo.getFlagType())){
                    db = mongo.getDatabase(databaseConnectionInfo.getDbName());
                    // 查询该数据库所有的集合名
                    MongoCollection<Document> coll=mongoManager.getDBCollection(databaseConnectionInfo.getDbName(),db);
                    dtname=mongoManager.queryList(coll).toString();
                }


            }
        }catch (Exception e){
            System.err.println( e.getClass().getName() + ": " + e.getMessage() );

        }finally {
            mongo.close();
        }
        if (dtname != null) {
            return new CommonResult(200, "查询成功" + dtname);
        } else {
            return new CommonResult(444, "没有对应记录"+null);
        }

    }

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
当使用Spring MVC和MongoDB时,可以使用MongoDB的官方Java驱动程序来连接。下面是一个示例配置: 1. 首先,确保已在项目中添加了MongoDBJava驱动程序依赖项。可以在Maven的pom.xml文件中添加以下依赖项: ```xml <dependency> <groupId>org.mongodb</groupId> <artifactId>mongo-java-driver</artifactId> <version>3.12.8</version> </dependency> ``` 2. 创建一个MongoDB连接的配置类。可以使用Spring的@Configuration注解和@Bean注解来定义连接的配置。例如: ```java import com.mongodb.MongoClient; import com.mongodb.MongoClientURI; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.mongodb.core.MongoTemplate; @Configuration public class MongoDBConfig { @Bean public MongoClient mongoClient() { String connectionString = "mongodb://localhost:27017/mydatabase"; MongoClientURI uri = new MongoClientURI(connectionString); return new MongoClient(uri); } @Bean public MongoTemplate mongoTemplate() { return new MongoTemplate(mongoClient(), "mydatabase"); } } ``` 上述代码创建了一个名为`mongoClient`的`MongoClient` bean,它使用`MongoClientURI`来指定MongoDB连接字符串。然后,它创建一个名为`mongoTemplate`的`MongoTemplate` bean,它使用`mongoClient` bean来连接MongoDB。 3. 在Spring MVC的配置文件中引入MongoDB配置类。例如,在`web.xml`中添加以下内容: ```xml <context-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/spring-mvc-servlet.xml</param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> ``` 4. 在Spring MVC的配置文件中引入MongoDB配置类。例如,在`spring-mvc-servlet.xml`中添加以下内容: ```xml <!-- 导入MongoDB配置类 --> <import resource="classpath:com/example/MongoDBConfig.java" /> <!-- 启用MongoDB的注解支持 --> <mongo:repositories base-package="com.example.repository" /> <!-- 其他Spring MVC的配置 --> ... ``` 上述代码通过`<import>`标签引入了之前创建的MongoDB配置类。然后,使用`<mongo:repositories>`标签启用MongoDB的注解支持,指定了存储库接口的基本包。 现在,你可以在Spring MVC的控制器或服务类中注入`MongoTemplate` bean,并使用它来执行对MongoDB的操作。例如: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.stereotype.Service; @Service public class MyService { private final MongoTemplate mongoTemplate; @Autowired public MyService(MongoTemplate mongoTemplate) { this.mongoTemplate = mongoTemplate; } // 在这里编写对MongoDB的操作方法 } ``` 以上是一个简单的Spring MVC和MongoDB连接的示例。你可以根据自己的需求进行调整和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

任错错

如果对您有帮助我很开心

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值