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

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产欧美一区二区精品性色99 | 五月天网站 | 男人天堂网av | 人与禽交3d动漫羞羞动漫 | 亚洲一区二区福利视频 | 国产午夜小视频 | 欧美高清milf在线播放 | 69日本xxxhd| 全黄h全肉细节文在线观看 全彩成人18h漫画 | 亚洲日本aⅴ片在线观看香蕉 | 国产成人久久 | 人人做人人爽人人爱 | 91制片厂制作传媒网站 | aⅴ导航站 | 好紧好爽的午夜寂寞视频 | 日韩精品一区二区三区中文在线 | 91制片在线观看 | 娇小性色 | 日本一卡二卡3卡四卡网站精品 | 高清在线看 | 农村老少伦小说 | 日韩亚洲人成在线综合 | 91tm视频| 国产精品微拍 | 美女在线看永久免费网址 | 国产91素人搭讪系列天堂 | 亚洲色图丝袜 | 日韩精品在线一区二区 | 久久久无码精品亚洲A片软件 | 俺去俺去啦最新官网在线 | 色先锋av资源中文字幕 | 女主被男主做哭失禁高h | 国内自拍网红在线综合 | 精品videoss另类日本 | 狠狠操社区 | 欧美视频网址 | 调教开发新婚娇妻放荡 | 能播放18xxx18女同 | 99九九国产精品免费视频 | 草莓香蕉绿巨人丝瓜榴莲18 | 性欧美高清强烈性视频 |