Spring Boot中使用MongoDB的串連池配置的方法,springmongodb

來源:互聯網
上載者:User

Spring Boot中使用MongoDB的串連池配置的方法,springmongodb

因為今天開發遇到了效能問題,可能與MongoDB的串連有關,所以稍稍深入看了一下,正好搜到原來有人寫過這篇相關的內容,所以轉載過來。回頭有時間可以寫個擴充到SpringForAll裡,主體思路還是一樣的。感謝這位美女程式媛的文章!

說明

Spring Boot中通過依賴 spring-boot-starter-data-mongodb ,來實現 spring-data-mongodb 的自動設定。

但是預設情況下,Spring Boot 中,並沒有像使用MySQL或者Redis一樣,提供了串連池配置的功能。因此,我們需要自行重寫 MongoDbFactory ,實現MongoDB用戶端串連的參數配置擴充。

需要說明的是,MongoDB的用戶端本身就是一個串連池,因此,我們只需要配置用戶端即可。

設定檔

為了統一Spring Boot的配置,我們要將重寫的配置也配置到 application.yml 中,首碼為 spring.data.mongodb.custom 下(首碼可自己隨意配置):

spring: data: mongodb:  custom:  hosts:   - 10.0.5.1   - 10.0.5.1  ports:   - 27017   - 27018  replica-set: mgset-3590061  username: jancee  password: abc123  database: jancee  authentication-database: admin  connections-per-host: 20  min-connections-per-host: 20

該配置例子中,配置了複本集,其中包含了主機 10.0.5.1:27017 和 10.0.5.1:27018 ,其它配置與Spring Boot的標準配置類似,另外, connections-per-host 為用戶端的串連數, in-connections-per-host 為用戶端最小串連數。

將配置封裝成類

為方便調用和可讀性,將上述配置封裝成一個配置實體類, MongoConfig.java 代碼如下:

package com.feidiao.jancee.fdiot.api.config.mongo;import org.hibernate.validator.constraints.NotBlank;import org.hibernate.validator.constraints.NotEmpty;import org.springframework.stereotype.Component;import org.springframework.validation.annotation.Validated;import java.util.List;@Component@Validatedpublic class MongoSettingsProperties { @NotBlank private String database; @NotEmpty private List<String> hosts; @NotEmpty private List<Integer> ports; private String replicaSet; private String username; private String password; private String authenticationDatabase; private Integer minConnectionsPerHost = 10; private Integer connectionsPerHost = 2; public MongoSettingsProperties() { } public String getDatabase() {  return database; } public void setDatabase(String database) {  this.database = database; } public List<String> getHosts() {  return hosts; } public void setHosts(List<String> hosts) {  this.hosts = hosts; } public List<Integer> getPorts() {  return ports; } public void setPorts(List<Integer> ports) {  this.ports = ports; } public String getReplicaSet() {  return replicaSet; } public void setReplicaSet(String replicaSet) {  this.replicaSet = replicaSet; } public String getUsername() {  return username; } public void setUsername(String username) {  this.username = username; } public String getPassword() {  return password; } public void setPassword(String password) {  this.password = password; } public String getAuthenticationDatabase() {  return authenticationDatabase; } public void setAuthenticationDatabase(String authenticationDatabase) {  this.authenticationDatabase = authenticationDatabase; } public Integer getMinConnectionsPerHost() {  return minConnectionsPerHost; } public void setMinConnectionsPerHost(Integer minConnectionsPerHost) {  this.minConnectionsPerHost = minConnectionsPerHost; } public Integer getConnectionsPerHost() {  return connectionsPerHost; } public void setConnectionsPerHost(Integer connectionsPerHost)  {  this.connectionsPerHost = connectionsPerHost; }}

覆蓋MongoDbFactory

接下來,就是覆蓋Spring Boot原有的 MongoDbFactory Bean,建立檔案 MongoConfig.java ,代碼如下:

import com.mongodb.MongoClient;import com.mongodb.MongoClientOptions;import com.mongodb.MongoCredential;import com.mongodb.ServerAddress;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.context.properties.ConfigurationProperties;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.data.mongodb.MongoDbFactory;import org.springframework.data.mongodb.core.SimpleMongoDbFactory;import java.util.ArrayList;import java.util.List;@Configurationpublic class MongoConfig { // 注入配置實體 @Autowired private MongoSettingsProperties mongoSettingsProperties; @Bean @ConfigurationProperties(   prefix = "spring.data.mongodb.custom") MongoSettingsProperties mongoSettingsProperties() {  return new MongoSettingsProperties(); } // 覆蓋預設的MongoDbFactory @Bean MongoDbFactory mongoDbFactory() {  //用戶端配置(串連數、複本集群驗證)  MongoClientOptions.Builder builder = new MongoClientOptions.Builder();  builder.connectionsPerHost(mongoSettingsProperties.getConnectionsPerHost());  builder.minConnectionsPerHost(mongoSettingsProperties.getMinConnectionsPerHost());  if (mongoSettingsProperties.getReplicaSet() != null) {   builder.requiredReplicaSetName(mongoSettingsProperties.getReplicaSet());  }  MongoClientOptions mongoClientOptions = builder.build();  // MongoDB地址清單  List<ServerAddress> serverAddresses = new ArrayList<>();  for (String host : mongoSettingsProperties.getHosts()) {   Integer index = mongoSettingsProperties.getHosts().indexOf(host);   Integer port = mongoSettingsProperties.getPorts().get(index);   ServerAddress serverAddress = new ServerAddress(host, port);   serverAddresses.add(serverAddress);  }  System.out.println("serverAddresses:" + serverAddresses.toString());  // 串連認證  List<MongoCredential> mongoCredentialList = new ArrayList<>();  if (mongoSettingsProperties.getUsername() != null) {   mongoCredentialList.add(MongoCredential.createScramSha1Credential(     mongoSettingsProperties.getUsername(),     mongoSettingsProperties.getAuthenticationDatabase() != null ? mongoSettingsProperties.getAuthenticationDatabase() : mongoSettingsProperties.getDatabase(),     mongoSettingsProperties.getPassword().toCharArray()));  }  System.out.println("mongoCredentialList:" + mongoCredentialList.toString());  //建立用戶端和Factory  MongoClient mongoClient = new MongoClient(serverAddresses, mongoCredentialList, mongoClientOptions);  MongoDbFactory mongoDbFactory = new SimpleMongoDbFactory(mongoClient, mongoSettingsProperties.getDatabase());  return mongoDbFactory; }}

在這裡,實現了MongoDB串連時,前面配置的參數的設定,按照自己的實際情況,可以在 new SimpleMongoDbFactory 時,增加修改自己需要的配置參數。

至此,就完成了全部配置,運行測試即可。

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援幫客之家。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.