一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Spring Boot中使用MongoDB的連接池配置的方法

Spring Boot中使用MongoDB的連接池配置的方法

2021-04-09 11:36翟永超 Java教程

本文介紹了Spring Boot中使用MongoDB的連接池配置的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

因為今天開發遇到了性能問題,可能與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 下(前綴可自己隨意配置):

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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 代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
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
@Validated
public 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 ,代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
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;
 
@Configuration
public 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 時,增加修改自己需要的配置參數。

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

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

原文鏈接:http://blog.didispace.com/spring-boot-mongodb-connection-pool

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 天天色综合久久 | 热久久最新视频 | 好深快点再快点好爽视频 | 国产精品视频一区二区三区经 | 6080窝窝理论 | 国产精品女主播大秀在线 | 日本不卡免费新一二三区 | 国产午夜久久精品 | 纲手被强喷水羞羞漫画 | 欧美香蕉| 国产成人一区二区三区 | 亚洲人成在线播放 | 男男gaygays18中国 | 亚洲人成网站在线观看播放青青 | 挺进白嫩老师下面视频 | 欧美一卡二卡科技有限公司 | 色cccwww在线播放 | 日韩免费视频一区 | 特黄a级三级三级野战 | 成人永久免费福利视频网站 | 成成人看片在线 | 精品视频网站 | 91久| 国产成人精品高清在线 | 亚洲国产经典 | 亚洲酒色1314狠狠做 | 男gay网站视频免费观看 | 日韩日韩日韩手机看片自拍 | 韩国三级动漫 | 四虎精品成人a在线观看 | 国产一区日韩二区欧美三区 | 乌克兰一级毛片 | videodesexo中国妞 | 亚洲国产一区二区三区青草影视 | 国产精品久久国产三级国电话系列 | 欧美高清在线精品一区 | 911色_911色sss在线观看 | 青青草影院在线观看 | 香蕉久久一区二区不卡无毒影院 | 波多野结衣同性系列698 | 成全动漫视频在线观看 |