java實現mongodb的資料庫連接池_java

來源:互聯網
上載者:User

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)方法即可。

以上就是本文的全部內容,希望本文所述對大家學習java程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.