java实现mongodb的数据库连接池
作者:xiaojimanman 发布时间:2023-11-23 14:23:09
标签:java,mongodb,数据库
MongoDB是介于关系数据库和非关系数据库之间的一种产品,文件的存储格式为BSON(一种JSON的扩展),这里就主要介绍Java通过使用mongo-2.7.3.jar包实现mongodb连接池,具体的java代码实现如下:
数据库连接池配置参数:
/**
*@Description: mongo连接池配置文件
*/
package cn.lulei.mongo.pool;
public class MongoConfig {
private static String userName;//用户名
private static String pwd;//密码
private static String[] host;//主机地址
private static int[] port;//端口地址
private static String dbName;//数据库名
private static int connectionsPerHost = 20;//每台主机最大连接数
private static int threadsAllowedToBlockForConnectionMultiplier = 10;//线程队列数
private static boolean authentication = false;//是否需要身份验证
public static String getUserName() {
return userName;
}
public static void setUserName(String userName) {
MongoConfig.userName = userName;
}
public static String getPwd() {
return pwd;
}
public static void setPwd(String pwd) {
MongoConfig.pwd = pwd;
}
public static String[] getHost() {
return host;
}
public static void setHost(String[] host) {
MongoConfig.host = host;
}
public static int[] getPort() {
return port;
}
public static void setPort(int[] port) {
MongoConfig.port = port;
}
public static String getDbName() {
return dbName;
}
public static void setDbName(String dbName) {
MongoConfig.dbName = dbName;
}
public static int getConnectionsPerHost() {
return connectionsPerHost;
}
public static void setConnectionsPerHost(int connectionsPerHost) {
MongoConfig.connectionsPerHost = connectionsPerHost;
}
public static int getThreadsAllowedToBlockForConnectionMultiplier() {
return threadsAllowedToBlockForConnectionMultiplier;
}
public static void setThreadsAllowedToBlockForConnectionMultiplier(
int threadsAllowedToBlockForConnectionMultiplier) {
MongoConfig.threadsAllowedToBlockForConnectionMultiplier = threadsAllowedToBlockForConnectionMultiplier;
}
public static boolean isAuthentication() {
return authentication;
}
public static void setAuthentication(boolean authentication) {
MongoConfig.authentication = authentication;
}
}
数据库连接池管理类:
/**
*@Description: mongo数据库连接池管理类
*/
package cn.lulei.mongo.pool;
import java.util.ArrayList;
import java.util.List;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.Mongo;
import com.mongodb.MongoOptions;
import com.mongodb.ReadPreference;
import com.mongodb.ServerAddress;
public class MongoManager {
private static Mongo mongo;
private DB db;
static{
init();
}
/**
* @param dbName
* @param userName
* @param pwd
* 实例化dbName一个DB
*/
public MongoManager(String dbName, String userName, String pwd) {
if (dbName == null || "".equals(dbName)) {
throw new NumberFormatException("dbName is null");
}
db = mongo.getDB(dbName);
if(MongoConfig.isAuthentication() && !db.isAuthenticated()){
if (userName == null || "".equals(userName)) {
throw new NumberFormatException("userName is null");
}
if (pwd == null || "".equals(pwd)) {
throw new NumberFormatException("pwd is null");
}
db.authenticate(userName, pwd.toCharArray());
}
}
/**
* 使用配置参数实例化
*/
public MongoManager() {
this(MongoConfig.getDbName(), MongoConfig.getUserName(), MongoConfig.getPwd());
}
/**
* @param tableName
* @return
* @Description: 获取表tableName的链接DBCollection
*/
public DBCollection getDBCollection(String tableName) {
return db.getCollection(tableName);
}
/**
* @Description: mongo连接池初始化
*/
private static void init() {
if (MongoConfig.getHost() == null || MongoConfig.getHost().length == 0) {
throw new NumberFormatException("host is null");
}
if (MongoConfig.getPort() == null || MongoConfig.getPort().length == 0) {
throw new NumberFormatException("port is null");
}
if (MongoConfig.getHost().length != MongoConfig.getPort().length) {
throw new NumberFormatException("host's length is not equals port's length");
}
try {
//服务列表
List<ServerAddress> replicaSetSeeds = new ArrayList<ServerAddress>();
for (int i = 0; i < MongoConfig.getHost().length; i++) {
replicaSetSeeds.add(new ServerAddress(MongoConfig.getHost()[i], MongoConfig.getPort()[i]));
}
//连接池参数设置
MongoOptions options = new MongoOptions();
options.connectionsPerHost = MongoConfig.getConnectionsPerHost();
options.threadsAllowedToBlockForConnectionMultiplier = MongoConfig.getThreadsAllowedToBlockForConnectionMultiplier();
mongo = new Mongo(replicaSetSeeds, options);
//从服务器可读
mongo.setReadPreference(ReadPreference.SECONDARY);
} catch (Exception e){
e.printStackTrace();
}
}
}
下面通过一个简单的测试类,来看下如何使用这个连接池~
/**
*@Description:mongo测试
*/
package cn.lulei.mongo.test;
import cn.lulei.mongo.pool.MongoConfig;
import cn.lulei.mongo.pool.MongoManager;
public class Test {
public static void main(String[] args) {
// TODO Auto-generated method stub
String[] host = {"127.0.0.1"};
int[] port = {27001};
MongoConfig.setHost(host);
MongoConfig.setPort(port);
MongoConfig.setDbName("novel");
MongoManager mongoManager = new MongoManager();
mongoManager.getDBCollection("chapter");
}
}
在使用上述管理类时,只需要初始化MongoConfig类即可。对类MongoManager的实例话,既可以使用MongoConfig的配置也可以自己通过参数来设置,每次获取DBCollection 时,只需要调用getDBCollection(String tableName)方法即可。
0
投稿
猜你喜欢
- UI 妹纸又给了个图叫我做,我一看是这样的:我们首先把这个控件划分成 几个部分:1.底下部分的直线 :2.左右两边的半圆
- 简介Arthas 是Alibaba开源的Java诊断工具,动态跟踪Java代码;实时监控JVM状态,可以在不中断程序执行的情况下轻松完成JV
- 报错翻译: compileSdkVersion android-24”需要JDK 1.8或更高版本编译。报错现象如下图:原因:st
- 前言在我们平时使用图形化界面的时候,会发现来建立一个文件夹或者一个文档的时候很简单,只需要在桌面单击鼠标右键就可以了。但是,在我们写项目的时
- idea spring Initializr创建项目勾选项目所需要的依赖pom.xml文件会加载勾选的依赖,也可以不勾选后面通过自己常用的p
- 在IntelliJ IDEA 中这个查看一个类也就是当前类的所有继承关系,包括实现的所有的接口和继承的类,这个继承,不仅仅是一级的继承关系,
- Interface Segregation Principle,ISP接口隔离原则主张使用多个专门的接口比使用单一的总接口要好。一个类对另外
- 免责声明:本教程所有资源均来源于网络;仅用于学习交流,请勿用于任何商业行为;如需要,请使用正版授权;侵权联删。推荐最新 IntelliJ I
- 在阻塞队里中,除了对元素进行增加和删除外,我们可以把元素的删除做一个延迟的处理,即使用DelayQueue的方法。本文就来和大家聊聊Java
- 按行读取文件package test; import java.io.*; import java.util.*; public class
- 前言gps定位服务的学习是这段时间gps课程的学习内容,之前老师一直在将概念,今天终于是实践课(其实就是给了一个案例,让自己照着敲).不过在
- C#串口模块的使用。使用VS .net框架下WinForm程序应用开发。C#开发的串口通信小工具。相比于QT添加的串口类,WinForm是通
- 自动登录是我们在软件开发时一个非常常见的功能,例如我们登录 QQ 邮箱:很多网站我们在登录的时候都会看到类似的选项,毕竟总让用户输入用户名密
- 自然排序TreeSet集合在存储数据时有一定的顺序,它会将一些数据进行比较,比较调用的是comparaTo()方法,该方法是在Compara
- Java8新特性系列我们已经介绍了Stream、Lambda表达式、DateTime日期时间处理,最后以“NullPointerExcept
- 这节主要完成一些基本的增删改查以及Service、Dao和Action的抽取。1. Service层的抽取  
- 一、Monkey 是什么?Monkey 就是SDK中附带的一个工具。二、Monkey 测试的目的?:该工具用于进行压力测试。 然后开发人员结
- 前言LocalDateTime、LocalDate、LocalTime 是 Java8 全新的日期框架,加强了对时间的管理,有很多特别好用的
- 格式要求:SU MO TU WE TH FR SA &nb
- 本文实例完成人机猜拳互动游戏的开发,供大家参考,具体内容如下阶段一:实验——分析业务,创建用户类1.分析业务,抽象出类、类的特征和行为2.创