激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

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

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

服務器之家 - 編程語言 - Java教程 - Java mongodb連接配置實踐

Java mongodb連接配置實踐

2021-06-19 10:56超超boy Java教程

這篇文章主要介紹了Java mongodb連接配置實踐,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

之前百度,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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品自在线拍 | 免费毛片在线 | h网站在线观看 | 免费黄色大片在线观看 | 欧美性生交xxxxx久久久 | 免费黄色免费 | 在线成人精品视频 | 久久久久久久久免费 | 国产精品欧美久久久久一区二区 | 在线观看麻豆 | 久草资源在线观看 | 成人一级视频 | 99久久久国产 | 国产呻吟 | 黄色a级片免费观看 | 蜜桃网站在线 | 黄色99视频 | 91短视频在线观看视频 | www国产成人免费观看视频 | 国产va在线观看免费 | av免费不卡国产观看 | 91短视频在线免费观看 | 国产青草视频在线观看 | 99久99| 青草av.久久免费一区 | 99国产精成人午夜视频一区二区 | 欧美一级在线免费 | 日韩在线视频导航 | 精品999久久久 | 国产成人精品区一区二区不卡 | 一级免费黄色免费片 | 女人叉开腿让男人桶 | 视频一区二区在线播放 | 精精国产xxxx视频在线野外 | 日本在线不卡免费 | 91短视频在线视频 | 久在线播放 | 国产日产精品一区四区介绍 | 精品亚洲va在线va天堂资源站 | 午夜a狂野欧美一区二区 | 国产精品视频久久久 |