之前百度,google了很多,發現并沒有介紹mongodb生產環境如何配置的文章, 當時想參考下都不行, 所以寫篇文章,大家可以一塊討論下.
1. mongoclientoptions中的連接池配置:
配置如下:
1
2
3
4
5
6
7
8
9
|
connectionpoolsettings = connectionpoolsettings.builder() .minsize(getminconnectionsperhost()) .maxsize(getconnectionsperhost()) .maxwaitqueuesize(getthreadsallowedtoblockforconnectionmultiplier() * getconnectionsperhost()) .maxwaittime(getmaxwaittime(), milliseconds) .maxconnectionidletime(getmaxconnectionidletime(), milliseconds) .maxconnectionlifetime(getmaxconnectionlifetime(), milliseconds) .build(); |
minsize: 線程池空閑時保持的最小連接數, 默認是0.
maxsize: 線程池允許的最大連接數,默認是100.
maxwaitqueuesize: 線程池等待隊列的大小, 默認是500.
maxwaittime: 線程等待連接變為可用的最長時間.默認為2分鐘. 值為0意味著它不會等待. 負值意味著它將無限期地等待
maxconnectionidletime: 線程池中連接的最大空閑時間, 0標志udine空閑時間沒有限制,超過這個時間會被關閉.
maxconnectionlifetime: 線程池中連接的最長生存時間. 0表示沒有限制. 超過壽命的會被關閉,必要時通過新連接進行替換.
2. mongoclientoptions初始化
mongodb驅動中 mongoclientoptions 使用buidler模式配置,有關所有屬性的默認值,都是在builder里邊配置的.
關于builder 的配置如下:
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
|
public static class builder { private string description; private string applicationname; //讀取偏好, 這里默認的是從主節點讀取. private readpreference readpreference = readpreference.primary(); //使用服務器默認的寫關注? private writeconcern writeconcern = writeconcern.acknowledged; //使用服務的默認讀關注,默認是local private readconcern readconcern = readconcern. default ; private codecregistry codecregistry = mongoclient.getdefaultcodecregistry(); private final list<commandlistener> commandlisteners = new arraylist<commandlistener>(); private final list<clusterlistener> clusterlisteners = new arraylist<clusterlistener>(); private final list<serverlistener> serverlisteners = new arraylist<serverlistener>(); private final list<servermonitorlistener> servermonitorlisteners = new arraylist<servermonitorlistener>(); private int minconnectionsperhost; private int maxconnectionsperhost = 100 ; private int threadsallowedtoblockforconnectionmultiplier = 5 ; //設置服務器選擇超時(以毫秒為單位),它定義驅動程序在拋出異常之前等待服務器選擇成功的時間 //值為0表示如果沒有可用的服務器,它將立即超時。 負值意味著無限期等待 private int serverselectiontimeout = 1000 * 30 ; //線程等待連接變為可用的最長時間 private int maxwaittime = 1000 * 60 * 2 ; // 線程池中連接的最大空閑時間 private int maxconnectionidletime; private int maxconnectionlifetime; //連接超時時間,必須大于0 private int connecttimeout = 1000 * 10 ; //socket超時時間 private int sockettimeout = 0 ; //socket是否保活 private boolean socketkeepalive = false ; private boolean sslenabled = false ; private boolean sslinvalidhostnameallowed = false ; private boolean alwaysusembeans = false ; //設置心跳頻率。 這是驅動程序將嘗試確定群集中每個服務器的當前狀態的頻率。 默認值為10,000毫秒 private int heartbeatfrequency = 10000 ; //設置最小心跳頻率。 如果驅動程序必須經常重新檢查服務器的可用性,它將至少在上一次檢查后等待很長時間,以避免浪費精力。 默認值為500毫秒。 private int minheartbeatfrequency = 500 ; //設置用于集群心跳的連接的連接超時 private int heartbeatconnecttimeout = 20000 ; //設置用于集群心跳的連接的套接字超時 private int heartbeatsockettimeout = 20000 ; //本地閾值 private int localthreshold = 15 ; private string requiredreplicasetname; private dbdecoderfactory dbdecoderfactory = defaultdbdecoder.factory; private dbencoderfactory dbencoderfactory = defaultdbencoder.factory; private socketfactory socketfactory; private boolean cursorfinalizerenabled = true ; ...} |
3. 需要關心的配置
這里就因人而異了, 我這列出比較重要的幾個配置,具體的值看業務場景.
3.1 讀寫相關
這應該是程序最應該關注的配置了,讀關注,寫關注,讀取偏好.
1
2
3
4
5
6
|
//讀取偏好, 首先從從節點讀取. private readpreference readpreference = readpreference.secondarypreferred(); //寫關注為1 ,寫入主節點即返回. private writeconcern writeconcern = writeconcern.w1; //使用服務的默認讀關注,默認是local(決定到某個讀取數據時,能讀到什么樣的數據) private readconcern readconcern = readconcern.local; |
3.2 線程池配置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
//線程池空閑時保持的最小連接數 minconnectionsperhost= 20 //線程池允許的最大連接數 connectionsperhost= 100 //connectionsperhost* 5 =最大隊列數 threadsallowedtoblockforconnectionmultiplier= 5 //線程池中連接的最大空閑時間,5分鐘 maxconnectionidletime = 5 * 60 * 1000 // 線程池中連接的最長生存時間,采用默認值 maxconnectionlifetime |
3.3 連接配置
1
2
3
4
5
6
7
8
9
10
|
//設置服務器選擇超時(以毫秒為單位),它定義驅動程序在拋出異常之前等待服務器選擇成功的時間 //值為0表示如果沒有可用的服務器,它將立即超時。 負值意味著無限期等待 private int serverselectiontimeout = 1000 * 30 ; //連接超時時間,必須大于0 private int connecttimeout = 1000 * 5 ; //線程等待連接變為可用的最長時間. maxwaittime= 6000 |
這里建議 這兩個參數: maxwaittime,connecttimeout,根據公司具體的業務來..
這是目前我在公司的配置參數, 借鑒了其他的連接池配置比如: redis和mysql的,并不是最優的,還在摸索實踐....
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:https://www.cnblogs.com/jycboy/p/10077080.html