佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > mongodb運維_動力節(jié)點Java學院整理

mongodb運維_動力節(jié)點Java學院整理

熱門標簽:Linux服務器 網(wǎng)站排名優(yōu)化 呼叫中心市場需求 地方門戶網(wǎng)站 百度競價排名 鐵路電話系統(tǒng) 服務外包 AI電銷

我們以管理員的視角來看mongodb,作為一名管理員,我們經(jīng)常接觸到的主要有4個方面:

1.  安裝部署

2.  狀態(tài)監(jiān)控

3.  安全認證

4.  備份和恢復,

下面我們就一點一點的講解。

一:安裝部署

        我之前的文章都是采用console程序來承載,不過在生產(chǎn)環(huán)境中這并不是最佳實踐,誰也不愿意在機器重啟后滿地找牙似找mongodb,在mongodb里面提供了一個叫做“服務寄宿”的模式,我想如果大家對wcf比較熟悉的話很容易聽懂。好了,我們實踐一下,這里我開一下D盤里面的mongodb。

這里要注意的有兩點:

   1> logpath: 當我們使用服務寄宿的時候,用眼睛都能想明白肯定不會用console來承載日志信息了。

   2> install:   開啟安裝服務寄宿,很happy啊,把管理員的手工操作降低到最小,感謝mongodb。

好了,console程序叫我看log日志,那我就看看,發(fā)現(xiàn)mongodb已經(jīng)提示我們?nèi)绾伍_啟mongodb,接著我照做就是了。 

還要提醒大家一點的就是,這些命令參數(shù)很多很復雜也就很容易忘,不過沒關系,數(shù)據(jù)庫給我們提供了一個help方法,我們可以拿mongod和mongo說事。

mongod:

mongo:

二:狀態(tài)監(jiān)控

     監(jiān)控可以讓我們實時的了解數(shù)據(jù)庫的健康狀況以及性能調(diào)優(yōu),在mongodb里面給我們提供了三種方式。

1:http監(jiān)視器

     這個我在先前的文章中也提到了,這里就不贅述了。

2:serverStatus()

    這個函數(shù)可以獲取到mongodb的服務器統(tǒng)計信息,其中包括 :全局鎖,索引,用戶操作行為等等這些統(tǒng)計信息,對管理員來說非常重要。

    這里還是截個圖混個眼熟。

3:mongostat

      前面那些統(tǒng)計信息再牛X,那也是靜態(tài)統(tǒng)計,不能讓我觀看實時數(shù)據(jù)變化,還好,mongodb里面提供了這里要說的mongodstat監(jiān)視器,這玩意會每秒刷新,在實際生產(chǎn)環(huán)境中大有用處,還是截張圖,很有意思,是不是感覺大軍壓境了。

三: 安全認證

     作為數(shù)據(jù)庫軟件,我們肯定不想誰都可以訪問,為了確保數(shù)據(jù)的安全,mongodb也會像其他的數(shù)據(jù)庫軟件一樣可以采用用戶驗證的方法,那么該怎么做呢?其實很簡單,mongodb提供了addUser方法,還有一個注意點就是如果在admin數(shù)據(jù)庫中添加將會被視為“超級管理員”。

上面的admin用戶將會被視為超級管理員,“jack”用戶追加的第三個參數(shù)表示是否是“只讀用戶”,好了,該添加的我們都添加了,我們第一次登錄時不是采用驗證模式,現(xiàn)在我們使用--reinstall重啟服務并以--auth驗證模式登錄。

好了,我們進入test集合翻翻數(shù)據(jù)看看情況,我們發(fā)現(xiàn)jack用戶始終都是沒有寫入的權限,不管是授權或者未授權。

四:備份和恢復

      這玩意的重要性我想都不需要我來說了吧,這玩意要是搞不好會死人的,mongodb里面常用的手段有3種。

1: 直接copy

       這個算是最簡單的了,不過要注意一點,在服務器運行的情況下直接copy是很有風險的,可能copy出來時,數(shù)據(jù)已經(jīng)遭到

        破壞,唯一能保證的就是要暫時關閉下服務器,copy完后重開。

2:mongodump和mongorestore

      這個是mongo給我們提供的內(nèi)置工具,很好用,能保證在不關閉服務器的情況下copy數(shù)據(jù)。

為了操作方便,我們先刪除授權用戶。

好了,我們轉入正題,這里我先在D盤建立一個backup文件夾用于存放test數(shù)據(jù)庫。

快看,數(shù)據(jù)已經(jīng)備份過來了,太爽了,現(xiàn)在我們用mongorestore恢復過去,記住啊,它是不用關閉機器的。

提一點的就是 drop選項,這里是說我將test數(shù)據(jù)恢復之前先刪除原有數(shù)據(jù)庫里面的數(shù)據(jù),同樣大家可以通過help查看。

3:主從復制

    其實上面的1,2兩點都不能保證獲取數(shù)據(jù)的實時性,因為我們在備份的時候可能還有數(shù)據(jù)灌在內(nèi)存中不出來,那么我們想說能不能把數(shù)據(jù)暴力的刷到硬盤上,當然是可以的,mongodb給我們提供了fsync+lock機制就能滿足我們提的需求。

fsync+lock首先會把緩沖區(qū)數(shù)據(jù)暴力刷入硬盤,然后給數(shù)據(jù)庫一個寫入鎖,其他實例的寫入操作全部被阻塞,直到fsync+lock釋放鎖為止。

這里就不測試了。

 加鎖:    db.runCommand({"fsync":1,"lock":1})
 釋放鎖: db.$cmd.unlock.findOne()

總結

以上所述是小編給大家介紹的mongodb運維的相關知識,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • java 中mongodb的各種操作查詢的實例詳解
  • Java操作Mongodb數(shù)據(jù)庫實現(xiàn)數(shù)據(jù)的增刪查改功能示例
  • mongodb增刪改查詳解_動力節(jié)點Java學院整理
  • mongodb聚合_動力節(jié)點Java學院整理
  • Java連接MongoDB進行增刪改查的操作
  • Mongodb3.0.5 副本集搭建及spring和java連接副本集配置詳細介紹
  • MongoDB快速入門筆記(八)之MongoDB的java驅(qū)動操作代碼講解
  • java操作mongoDB查詢的實例詳解

標簽:仙桃 湖南 銅川 黃山 湘潭 衡水 蘭州 崇左

巨人網(wǎng)絡通訊聲明:本文標題《mongodb運維_動力節(jié)點Java學院整理》,本文關鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    浦江县| 霞浦县| 伽师县| 绍兴县| 西城区| 思南县| 沙洋县| 开封市| 苗栗市| 奎屯市| 海宁市| 迁西县| 驻马店市| 房山区| 鲜城| 大邑县| 老河口市| 葵青区| 西吉县| 康乐县| 永平县| 大悟县| 来安县| 双辽市| 乳源| 巴东县| 永安市| 铁岭县| 涿州市| 千阳县| 绥宁县| 承德市| 澄迈县| 固安县| 湛江市| 陵水| 临江市| 东明县| 龙州县| 慈利县| 紫金县|