1. 程式人生 > >Linux 平臺安裝MongoDB 4.0(最新版)

Linux 平臺安裝MongoDB 4.0(最新版)

文件格式 http rip 機制 selinux 新版 要求 錯誤 平臺

概 述

MongoDB 是由C++語言編寫的,是一個基於分布式文件存儲的開源數據庫系統。
在高負載的情況下,添加更多的節點,可以保證服務器性能。
MongoDB 旨在為WEB應用提供可擴展的高性能數據存儲解決方案。
MongoDB 將數據存儲為一個文檔,數據結構由鍵值(key=>value)對組成。MongoDB 文檔類似於 JSON 對象。字段值可以包含其他文檔,數組及文檔數組。

主要特點

  • MongoDB 是一個面向文檔存儲的數據庫,操作起來比較簡單和容易。
  • 你可以在MongoDB記錄中設置任何屬性的索引 (如:FirstName="Sameer",Address="8 Gandhi Road")來實現更快的排序。
  • 你可以通過本地或者網絡創建數據鏡像,這使得MongoDB有更強的擴展性。
  • 如果負載的增加(需要更多的存儲空間和更強的處理能力) ,它可以分布在計算機網絡中的其他節點上這就是所謂的分片。
  • Mongo支持豐富的查詢表達式。查詢指令使用JSON形式的標記,可輕易查詢文檔中內嵌的對象及數組。
  • MongoDb 使用update()命令可以實現替換完成的文檔(數據)或者一些指定的數據字段 。
  • Mongodb中的Map/reduce主要是用來對數據進行批量處理和聚合操作。
  • Map和Reduce。Map函數調用emit(key,value)遍歷集合中所有的記錄,將key與value傳給Reduce函數進行處理。
  • Map函數和Reduce函數是使用Javascript編寫的,並可以通過db.runCommand或mapreduce命令來執行MapReduce操作。
  • GridFS是MongoDB中的一個內置功能,可以用於存放大量小文件。
  • MongoDB允許在服務端執行腳本,可以用Javascript編寫某個函數,直接在服務端執行,也可以把函數的定義存儲在服務端,下次直接調用即可。
  • MongoDB支持各種編程語言:RUBY,PYTHON,JAVA,C++,PHP,C#等多種語言。
  • MongoDB安裝簡單。

適用領域

MongoDB可以為Web應用提供可擴展的高性能數據存儲解決方案。MongoDB主要適用領域有網站數據、分布式場景、數據緩存和JSON文件格式存儲。適用大數據量、高並發、若事務的互聯網應用,其內置的水平擴展機制提供了從幾百萬到十億級別的數據處理能力,可以很好地滿足Web2.0和移動互聯網應用數據存儲的要求。

系統環境

  • 操作系統:CentOs 7.3
  • 軟件包:mongodb-linux-x86_64-rhel70-4.0.0.tgz 密碼:hc17
  • 關閉防火墻及Selinux

部署安裝

1.安裝支持軟件包

yum -y install openssl-devel libcurl

2.解壓縮mongdb軟件包

tar zxvf mongodb-linux-x86_64-rhel70-4.0.0.tgz -C /opt

3.重命名並移動目錄至/usr/local/目錄下

mv /opt/mongodb-linux-x86_64-rhel70-4.0.0 /usr/local/mongodb

4.創建mongodb的數據存儲目錄、日誌存儲目錄及日誌文件

mkdir -p /data/mongodb1
mkdir -p /data/logs/mongodb
touch /data/logs/mongodb/mongodb1.log
chmod -R 777 /data/logs/mongodb/mongodb1.log

5.調整shell資源的設置,以防頻繁訪問mongodb產生錯誤導致無法連接mongdb實例

ulimit -n 25000    #同一時刻最多開啟文件數
ulimit -u 25000     #同一時刻最多開啟程序數

6.創建配置文件(啟動參數)

vim /usr/local/mongodb/bin/mongodb1.conf

port=27017
dbpath=/data/mongodb1
logpath=/data/logs/mongodb/mongodb1.log
logappend=true
fork=true
maxConns=5000
storageEngine=mmapv1

技術分享圖片

7.設置內核參數(當某個節點可用內存不足時,系統會從其他節點分配內存)

echo 0 > /proc/sys/vm/zone_reclaim_mode
sysctl -w vm.zone_reclaim_mode=0
echo never > /sys/kernel/mm/transparent_hugepage/enabled
echo never > /sys/kernel/mm/transparent_hugepage/defrag

8.MongoDB 的可執行文件位於 bin 目錄下,所以可以將其添加到 PATH 路徑中:

vim /etc/profile

#在文件末尾追加以下語句
export PATH=/usr/local/mongodb/bin:$PATH\

9.重新加載環境變量

source /etc/profile

10.設置mongodb開機自啟動

vim /etc/rc.local

#在文件末尾追加以下語句
rm -rf /data/mongodb1/mongodb.lock
/usr/local/mongodb/bin/mongod -f /usr/local/mongodb/bin/mongodb1.conf #啟動

11.啟動mongodb

mongod -f /usr/local/mongodb/bin/mongodb1.conf

技術分享圖片

12.檢查mongodb進程

netstat -tunlp | grep mongod

技術分享圖片

停止momngodb

mongod -f /usr/local/mongodb/bin/mongodb1.conf --shutdown

技術分享圖片

13.連接並訪問mongodb數據庫

mongo

技術分享圖片

Linux 平臺安裝MongoDB 4.0(最新版)