MongoDB是一個基於分佈式文件存儲的數據庫。由C++語言編寫。旨在爲WEB應用提供可擴展的高性能數據存儲解決方案。 MongoDB是一個介於關係數據庫和非關係數據庫之間的產品,是非關係數據庫當中功能最豐富,最像關係數據庫的。他支持的數據結構很是鬆散,是相似json的bjson格式,所以能夠存儲比較複雜的數據類型。Mongo最大的特色是他支持的查詢語言很是強大,其語法有點相似於面向對象的查詢語言,幾乎能夠實現相似關係數據庫單表查詢的絕大部分功能,並且還支持對數據創建索引。 |
MongoDB集羣包括必定數量的mongod(分片存儲數據)、mongos(路由處理)、config server(配置節點)、clients(客戶端)、arbiter(仲裁節點:爲了選舉某個分片存儲數據節點那臺爲主節點)。 |
一、shards:一個shard爲一組mongod,一般一組爲兩臺,主從或互爲主從,這一組mongod中的數據時相同的,具體可見《mongodb分佈式之數據複製》。數據分割按有序分割方式,每一個分片上的數據爲某一範圍的數據塊,故可支持指定分片的範圍查詢,這同google的BigTable 相似。數據塊有指定的最大容量,一旦某個數據塊的容量增加到最大容量時,這個數據塊會切分紅爲兩塊;當分片的數據過多時,數據塊將被遷移到系統的其餘分片中。另外,新的分片加入時,數據塊也會遷移。二、mongos:能夠有多個,至關於一個控制中心,負責路由和協調操做,使得集羣像一個總體的系統。mongos能夠運行在任何一臺服務器上,有些選擇放在shards服務器上,也有放在client 服務器上的。mongos啓動時須要從config servers上獲取基本信息,而後接受client端的請求,路由到shards服務器上,而後整理返回的結果發回給client服務器。三、config server:存儲集羣的信息,包括分片和塊數據信息。主要存儲塊數據信息,每一個config server上都有一份全部塊數據信息的拷貝,以保證每臺config server上的數據的一致性。四、shard key:爲了分割數據集,須要制定分片key的格式,相似於用於索引的key格式,一般由一個或多個字段組成以分發數據,好比:{ name : 1 }{ _id : 1 }{ lastname : 1, firstname : 1 }{ tag : 1, timestamp : -1 }mongoDB的分片爲有序存儲(1爲升序,-1爲降序),shard key相鄰的數據一般會存在同一臺服務(數據塊)上。
服務器部署能夠有多種方式。首先,每臺config server、mongos、mongod均可以是單獨的服務器,但這樣會致使某些服務器的浪費,好比config server。下圖爲物理機共享的集羣部署,不須要額外加機器。php
固然也有其餘的方案,好比把mongos部署在全部的mongod(server1-6)上,又或者在每一個運用服務器(server7)上部署mongos。這樣部署有個好處在於,appserver和mongos之間的通訊創建在localhost interface上,減小了通訊成本。固然,此乃官方說法,但本人有想法,儘管減小了appserver和mongos之間的通訊成本,但mongos與mongod之間的通訊成本卻增長了,並且把mongos部署在appserver上並非很利於sa管理,mongoDB應該是一個相對獨立的系統,與應用的耦合度應該儘可能降到最低,萬一應用想要換數據庫,也能多少減小些工做量。 |
4、mongodb分佈式的安裝html
一、下載mysql
wget http://fastdl.mongodb.org/linux/mongodb-linux-x86_64-2.0.4.tgz
二、安裝linux
tar zxvf mongodb-linux-2.0.4.tgzcp -fr mongodb-linux-*2.0.4/* /data/mongodb/mkdir -p /data/mongodb/data/ #建立數據存儲目錄mkdir -p /data/mongodb/log/ #建立日誌存儲目錄mkdir -p /data/mongodb/config/ #建立配置存儲目錄mkdir -p /data/mongodb/arbiter/ #建立仲裁節點存儲目錄
三、單機模式以及個參數說明redis
mongod --fork --bind_ip 127.0.0.1 --port 11811 --dbpath /data0/mongodb/data --directoryperdb --logpath /data0/mongodb/log/db1.log --logappend --nohttpinterfacenetstat -ntlp|grep mongod
簡單的參數說明:–logpath 日誌文件路徑–master 指定爲主機器–slave 指定爲從機器–source 指定主機器的IP地址–pologSize 指定日誌文件大小不超過64M.由於resync是很是操做量大且耗時,最好經過設置一個足夠大的oplogSize來避免resync(默認的 oplog大小是空閒磁盤大小的5%)。–logappend 日誌文件末尾添加–port 啓用端口號–fork 在後臺運行–only 指定只複製哪個數據庫–slavedelay 指從複製檢測的時間間隔–auth 是否須要驗證權限登陸(用戶名和密碼)–noauth 不須要驗證權限登陸(用戶名和密碼)
5、集羣模式mongos,mongod,configsvrsql
1.Shard分片--第一組分片 192.168.200.226: /data/mongodb/bin/mongod --replSet rep1 --fork --port 11813 --maxConns 65535 --dbpath /data/mongodb/data --directoryperdb --logpath /data/mongodb/log/db.log --logappend --nohttpinterface#啓動rep1分片的一個數據節點/data/mongodb/bin/mongos --configdb 192.168.201.226:11812 --port 11811 --fork --chunkSize 256 --logpath /data/mongodb/log/ms.log #啓動路由節點,讀取201.226上的配置節點的配置文件,(在配置節點啓動後啓動)/data/mongodb/bin/mongod --replSet rep1 --fork --port 11814 --dbpath /data/mongodb/arbiter --directoryperdb --logpath /data/mongodb/log/arbiter.log --logappend --nohttpinterface#啓動分片的仲裁節點192.168.201.226: /data/mongodb/bin/mongod --replSet rep1 --fork --port 11813 --maxConns 65535 --dbpath /data/mongodb/data --directoryperdb --logpath /data/mongodb/log/db.log --logappend --nohttpinterface#啓動rep1分片的第二個數據節點/data/mongodb/bin/mongos --configdb 192.168.201.226:11812 --port 11811 --fork --chunkSize 256 --logpath /data/mongodb/log/ms.log #啓動第二個路由節點 (在配置節點啓動後啓動)2.ConfigServer--- #啓動config server 192.168.201.226: /data/mongodb/bin/mongod --configsvr --dbpath /data/mongodb/config --port 11812 --fork --logpath /data/mongodb/log/mc.log#啓動配置節點,注意配置節點應該優先啓動,否則路由節點讀取不到配置節點信息則會啓動失敗。3.Mongos路由--- #啓動mongos,指定config server, chunkSize 256M 192.168.201.226: /data/mongodb/bin/mongos --configdb 192.168.201.226:11812 --port 11811 --fork --chunkSize 256 --logpath /data/mongodb/log/ms.log#啓動路由節點
因爲機器有限,只配置了一個shard分片,該分片裏有2個節點,新增長分片只需對應改replSet 名稱便可。mongodb
4.配置replSet: 鏈接任一mongod membersmongo 192.168.201.226:11813config = {_id: 'rep1', members: [{_id: 0, host: '192.168.200.226:11813', priority: 2}, #priority 爲定義優先級,默認爲1,高優先級會被認爲是主節點優先啓用。{_id: 1, host: '192.168.201.226:11813'},{_id: 2, host: '192.168.200.226:11814', arbiterOnly: true}]} rs.initiate(config); rs.status()
5.鏈接mongos增長shard 80G mongo 192.168.201.226:11811/admin show dbs use admin db.runCommand({addshard:'rep1/192.168.201.226:11813,192.168.200.226:11813',maxsize:81920}) db.runCommand({listshards:1})
6.鏈接mongos增長建立test庫和c1集合,並測試數據庫
mongo 192.168.201.226:11811/adminapache
db.runCommand({enablesharding:'test'})json
printShardingStatus()
db.runCommand({shardcollection:'test.auto_increment_id', key:{_id:1}, unique : true})
db.runCommand({shardcollection:'test.c1', key:{_id:1}, unique : true})
for (var i = 1; i <= 100; i++)db.c1.save({id:i,value1:"1234567890",value2:"1234567890",value3:"1234567890",value4:"1234567890"})
db.c1.stats()
db.createCollection("cap_coll", {capped:true, size:100000, max:100});
db.mycoll.validate();
7.檢查: db.printCollectionStats()
8.管理: mongo 127.0.0.1:11811
show dbs
use admin
show collections
db.serverStatus()
db.shutdownServer()
exit
9.索引:db.product_data.ensureIndex({data_id: 1}, {unique: true,dropDups: true}); #建立索引db.product_data.dropIndexes(); #刪除索引
至此,mongodb的分佈式架構就架起來了,而且經過測試和log的分析,可看服務是否正常,下面就須要php客戶端的支持,和程序的運行,以後加到監控裏,就能夠在線上部署使用了。 |
6、PHP的MongoDB拓展的安裝
# wget http://pecl.php.net/get/mongo-1.2.6.tgz # tar zxvf mongo-1.2.6.tgz # cd mongo-1.2.6 # /usr/local/php5/bin/phpize # ./configure --enable-mongo=share--with-php-config=/usr/local/php5/bin/php-config # make && make installl
PHP支持mongodb
將生成的拓展mongo.so文件添加到php.ini中,重啓php-fpm,或者apache,而後查看下phpinfo()請編輯php.ini文件。添加以下一行:extension=mongo.so而後用php輸出:phpinfo,就能夠看到mongo的信息了。。這樣就說明你安裝成功的了!
7、監控配置:
早在去年已經出現MongoDB和Redis的Cacti模板,使用它,你能夠對你的MongoDB和Redis服務進行流量監控。cacti的模板一直在更新,若企業已經用到nosql這種非關係數據庫如mongodb和redis。可按照如下教程,對mongodb和redis進行監控。
該模板能夠監控如下資源:
mongodb:
redis:
1、下載模板:
wget http://mysql-cacti-templates.googlecode.com/files/better-cacti-templates-1.1.8.tar.gz
2、配置ssh公私鑰無需密碼登陸:
由於cacti監控mongodb是須要登陸到mongodb的服務端運行mongo的狀態獲取命令,因此須要ssh鏈接登陸。
因此須要配置非交互式賬號密碼登陸。這裏採用公私鑰模式。
先在監控服務器生成一對公私鑰。
ssh-keygen ##若是是root用戶,生成的默認目錄爲/root/.ssh下2個文件id_rsa(公鑰) id_rsa.pub(私鑰)cd /root/.ssh/ && chmod 600 id_rsa* 把這2個文件修改權限,爲600 ssh-copy-id -i /root/.ssh/id_rsa root@192.168.200.1 #加被監控節點公私鑰認證
把id_rsa.pub複製出來,放到被監控機器上,而後公鑰的內容追加到須要被監控的主機也就是mongodb和redis的服務端。追加到.ssh/authorized_keys
而後用ssh鏈接你所安裝mongodb或者redis的服務端,若是不需輸密碼鏈接上。則正常。下面就能夠開始添加監控文件了。
3、配置監控腳本:
mongodb或redis的監控所需到的是你下載目錄中的better-cacti-templates-1.1.8\scripts下的ss_get_by_ssh.php 這個腳本 這個腳本須要放在cacti的服務端。若是你cacti是裝到/var/www/html/cacti/目錄下。把該文件放在其下面的scripts目錄下。別忘了看下權限。要有執行權限。
而後修改該文件。主要修改一下選項,大概在40行。
# ============================================================================$ssh_user = 'root'; # SSH username$ssh_port = 22; # SSH port$ssh_iden = '-i /root/.ssh/id_rsa'; # SSH identity##修改根據你的配置,你的ssh鏈接用戶,還有認證私鑰的位置。
大該在50行,還能夠修改其默認的去探測的端口(若是redis不是正常默認端口啓動須要修改這些)。
$memcache_port = 11211; # Which port memcached listens on$redis_port = 6379; # Which port redis listens on
若是是mongodb不是正常端口啓動,則須要這樣修改。找到如下字段,添加紅色字段,這裏注意mongo這個命令必定要找對。
function mongodb_cmdline ( $options ) {return 「echo \」db._adminCommand({serverStatus:1, repl:1})\」 | /usr/local/mongo/mongodb/bin/mongo –port 10000″;}
配置完後保存退出。
能夠先用測試命令測一下。語法以下:
php /var/www/html/scripts/ss_get_by_ssh.php --type mongodb --host 192.168.200.1 --items c,de,df,dg,dh,di,dj,dk,dl,dm,dn,do,dp,dq,dr,ds,dt,du
若是有數據輸出。則表示正常。
4、在cacti裏添加mongodb和redis模板:
4.1 模板導入
模板目錄爲better-cacti-templates-1.1.8\templates
4.2 導入後對被監控機添加模板:
4.3 添加後爲其繪圖:
五:實際效果測試:
此文凝聚筆者很多心血請尊重筆者勞動,轉載請註明出處。
linux運維培訓 http://www.magedu.com
喜歡linux,或者有問題還能夠來QQ羣89342115交流。