1.MongoDB是一款基於分佈式文件存儲的開源的文檔數據庫,而且是業內領先的NoSQL數據庫,用C++編寫而成。
2.在高負載的狀況下,添加更多的節點,能夠保證服務器性能。
3.MongoDB是一個介於關係型數據庫和非關係型數據庫之間的產品,不採用關係模型主要是爲了得到更好的擴展性,MongoDB再也不有行的概念,其運行方式基於兩個概念:集合與文檔。
4. MongoDB 旨在爲WEB應用提供可擴展的高性能數據存儲解決方案。
5.MongoDB 將數據存儲爲一個文檔,數據結構由鍵值(key=>value)對組成。MongoDB 文檔相似於 JSON 對象。字段值能夠包含其餘文檔,數組及文檔數組。linux
1.MongoDB安裝簡單,提供了面向文檔存儲功能,操做起來比較容易。
2.MongoDB提供了複製、高可用性和自動分片功能。若是負載增長(須要更多的存儲空間和更強的處理能力),它能夠分佈在計算機網絡中的其餘節點上,這就是所謂的分片。
3.MongoDB支持豐富的查詢表達式,查詢指令使用JSON形式的標記,可輕易查詢文檔中內嵌的對象及數組。
4.MongoDB支持各類編程語言:Ruby、Python、Java、C++、PHP、C#等多種語言。
5.MongoDB使用update()命令能夠實現替換完成的文檔(數據)或者一些指定的數據字段 。
6.MongoDB中的Map/reduce主要是用來對數據進行批量處理和聚合操做。web
MongoDB能夠爲web應用提供可擴展的高性能數據存儲解決方案。MongoDB主要適用領域有網站數據、分佈式場景、數據緩存和JSON文檔格式存儲。適合大數據量、高併發、弱事務的互聯網應用,其內置的水平擴展機制提供了從幾百萬到十億級別的數據處理能力,能夠很好的知足web2.0和移動互聯網應用數據存儲的要求。mongodb
安裝環境:
操做系統:CentOs 7
軟件包:https://pan.baidu.com/s/1xI38QSzie6DK2UL7wQ6K9g
關閉防火牆及Selinuxshell
1.安裝支持軟件包
yum -y install openssl-devel libcurl
數據庫
2.用winscp工具將軟件包複製到CentOs 7根目錄下
編程
3.解壓縮MongoDB軟件包
tar zxvf mongodb-linux-x86_64-rhel70-4.0.0.tgz -C /opt
vim
4.重命名並移動目錄至/usr/local/目錄下
mv /opt/mongodb-linux-x86_64-rhel70-4.0.0 /usr/local/mongodb
數組
5.建立MongoDB的數據存儲目錄、日誌存儲目錄及日誌文件
mkdir -p /data/mongodb/mongodb1緩存mkdir -p /data/conf/服務器
mkdir -p /data/logs/
touch /data/logs/mongodb1.log
chmod -R 777 /data/logs/mongodb1.log
6.調整shell資源的設置,以防頻繁訪問MongoDB產生錯誤致使沒法鏈接MongoDB實例
ulimit -n 25000 #同一時刻最多開啓文件數
ulimit -u 25000 #同一時刻最多開啓程序數
7.建立配置文件(啓動參數)
vim /data/conf/mongodb1.conf
修改以下:
#mongod.conf
#for documentation of all options, see:
#http://docs.mongodb.org/manual/reference/configuration-options/
#where to write logging data.
systemLog:
destination: file
logAppend: true
path: /data/logs/mongodb1.log //mongodb1的日誌文件路徑
#Where and how to store data.
storage:
dbPath: /data/mongodb/mongodb1/ //mongodb1的數據文件路徑
journal:
enabled: true
#engine:
#mmapv1:
#wiredTiger:
#how the process runs
processManagement:
fork: true # fork and run in background
pidFilePath: /data/mongodb/mongodb1/mongod.pid # location of pidfile
timeZoneInfo: /usr/share/zoneinfo
#network interfaces
net:
port: 27017 //mongodb1的進程號
bindIp: 0.0.0.0 # Listen to local interface only, comment to listen on all interfaces.
#security:
#operationProfiling:
replication: //刪除「#」,開啓複製集功能
replSetName: test-rc //名稱爲test-rc
#sharding:
##Enterprise-Only Options
#auditLog:
#snmp:
8.設置內核參數(當某個節點可用內存不足時,系統會從其餘節點分配內存)
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
9.MongoDB 的可執行文件位於 bin 目錄下,因此能夠將其添加到 PATH 路徑中:
vim /etc/profile
在文件末尾追加如下語句
export PATH=/usr/local/mongodb/bin:$PATH\
而後從新加載環境變量:
source /etc/profile
10.設置MongoDB開機自啓動
vim /etc/rc.local
rm -rf /data/mongodb/mongodb1/mongod.lock
/usr/local/mongodb/bin/mongod -f /data/conf/mongodb1.conf //啓動實例
11.啓動MongoDB數據庫
mongod -f /data/conf/mongodb1.conf
12.檢查MongoDB進程
netstat -tunlp | grep mongod
13.關閉MongoDB數據庫
mongod -f /data/conf/mongodb1.conf --shutdown
14.本地客戶端鏈接並訪問MongoDB數據庫(默認端口爲:27017)
用命令mongo 直接進
到此結束!