ubuntu上mongodb的安裝

Ubuntu上安裝MongoDB的完全步驟以及注意事項

本文我們詳細介紹了Ubuntu上安裝MongoDB的全部過程,希望本次的介紹能夠對您有所幫助。

AD: 2013大數據全球技術峯會課程PPT下載

 Ubuntu上安裝MongoDB數據庫的步驟以及注意事項是本文我們主要要介紹的內容,接下來就讓我們一起來了解一下這部分內容吧,希望能夠對您有所幫助。

 獲取最新版本

wgethttp://fastdl.mongodb.org/linux/mongodb-linux-x86_64-1.8.3.tgz

解壓縮即可執行。

tar zxvf mongodb-linux-x86_64-1.8.3.tgz

cd /usr/local/mongodb-linux-x86_64-1.8.3/bin

但是在運行前,需要創建mongodb需要的存放數據和日誌的目錄:

sudo mkdir -p /data/db/

sudo chmod -R 777 /data/db/

啓動mongodb server,-journal 代表要寫日誌,-maxConns=2400代表mongodb 可以接受2400個tcp連接,-rest代表可以允許客戶端通過rest API訪問mongdb server.

./mongod -journal -maxConns=2400 -rest

還可以使用參數—quiet啓動可以指定安靜模式減少記錄的項目數,注意使用該參數必須要同時指定日誌路徑,比如:

—quiet —logpath /data/db/journal/mongdb.log

相關說明

服務程序啓動後,終端會顯示一些信息,比如:

 

  1. Wed Aug 31 16:40:03 [initandlisten] MongoDB starting : pid=2410 port=27017 dbpath=/data/db/ 64-bit  
  2. Wed Aug 31 16:40:03 [initandlisten] db version v1.8.3, pdfile version 4.5  
  3. Wed Aug 31 16:40:03 [initandlisten] git version: c206d77e94bc3b65c76681df5a6b605f68a2de05  
  4. Wed Aug 31 16:40:03 [initandlisten] build sys info: Linux bs-linux64.10gen.cc 2.6.21.7-2.ec2.  
  5. v1.2.fc8xen #1 SMP Fri Nov 20 17:48:28 EST 2009 x86_64 BOOST_LIB_VERSION=1_41 
  6. Wed Aug 31 16:40:03 [initandlisten] journal dir=/data/db/journal  
  7. Wed Aug 31 16:40:03 [initandlisten] recover : no journal files present, no recovery needed  
  8. Wed Aug 31 16:40:06 [initandlisten] preallocateIsFaster=true 33.84  
  9. Wed Aug 31 16:40:08 [initandlisten] preallocateIsFaster=true 36.84  
  10. Wed Aug 31 16:40:11 [initandlisten] preallocateIsFaster=true 37.48  
  11. Wed Aug 31 16:40:11 [initandlisten] preallocating a journal file /data/db/journal/prealloc.0  
  12. Wed Aug 31 16:41:03 [initandlisten] preallocating a journal file /data/db/journal/prealloc.1  
  13. Wed Aug 31 16:41:55 [initandlisten] preallocating a journal file /data/db/journal/prealloc.2  
  14. Wed Aug 31 16:42:48 [initandlisten] waiting for connections on port 27017  
  15. Wed Aug 31 16:42:48 [initandlisten] —maxConns too high, can only handle 819  
  16. Wed Aug 31 16:42:48 [websvr] web admin interface listening on port 28017  
  17. Wed Aug 31 16:42:48 [dur] lsn set 0  
  18. Wed Aug 31 16:43:03 [dur] lsn set 14440  
  19. Wed Aug 31 16:44:03 [dur] lsn set 74050  
  20. Wed Aug 31 16:45:03 [dur] lsn set 133660  
  21. Wed Aug 31 16:46:03 [dur] lsn set 193270  
  22. Wed Aug 31 16:47:03 [dur] lsn set 252880  
  23. Wed Aug 31 16:48:03 [dur] lsn set 312490  
  24. Wed Aug 31 16:49:03 [dur] lsn set 372110  
  25. Wed Aug 31 16:50:03 [dur] lsn set 431720  
  26. Wed Aug 31 16:51:03 [dur] lsn set 491330  
  27. Wed Aug 31 16:52:03 [dur] lsn set 550940  
  28. Wed Aug 31 16:53:03 [dur] lsn set 610550 

 

我們可以看到進程id,監聽的TCP端口號和web管理員端口號。還能看到數據文件和日誌文件所在目錄。並且提示最大連接數達不到設置的2400.

修改系統允許的最大連接數

上面的最大連接數目的限制原因是Linux系統默認最大文件打開數目爲1024,用ulimit -a 命令檢查,可以看到下面這行:

open files (-n) 1024

修改/etc/security/limits.conf 配置文件。

在文件中增加* soft nofile 3000* hard nofile 20000* 表示該配置對所有用戶均有效。

soft 軟限制 可以超過的配置數。

hard 硬限制 最大不能超過的配置數。

nofile表示 max number of open files。

重新啓動計算機,然後再用ulimit -a 命令查看:

open files (-n) 3000

已經生效了。現在再啓動mongodb server,問題解決。

設置開機啓動

在/etc/init.d/目錄下新建腳本文件mongodb

 

  1. #!/bin/sh    
  2. ### BEGIN INIT INFO    
  3. # Provides:     mongodb    
  4. # Required-Start:    
  5. # Required-Stop:    
  6. # Default-Start:        2 3 4 5    
  7. # Default-Stop:         0 1 6    
  8. # Short-Description: mongodb    
  9. # Description: mongo db server    
  10. ### END INIT INFO    
  11. . /lib/lsb/init-functions    
  12. PROGRAM=/usr/local/mongodb-linux-x86_64-1.8.3/bin/mongod    
  13. MONGOPID=`ps -ef | grep 'mongod' | grep -v grep | awk '{print $2}'`    
  14. test -x $PROGRAM || exit 0    
  15. case "$1" in    
  16. start)    
  17. log_begin_msg "Starting MongoDB server"     
  18. #/usr/bin/mongod --fork --quiet --dbpath /data/db --logpath /var/log/mongodb.log    
  19. /usr/local/mongodb-linux-x86_64-1.8.3/bin/mongod --fork --quiet -journal -maxConns=2400 -rest --logpath /data/db/journal/mongdb.log    
  20. log_end_msg 0    
  21. ;;    
  22. stop)    
  23. log_begin_msg "Stopping MongoDB server"     
  24. if [ ! -z "$MONGOPID" ]; then     
  25. kill -15 $MONGOPID    
  26. fi    
  27. log_end_msg 0    
  28. ;;    
  29. status)    
  30. ;;    
  31. *)    
  32. log_success_msg "Usage: /etc/init.d/mongodb {start|stop|status}"     
  33. exit 1    
  34. esac    
  35. exit 0   

 

請注意,用sudo chmod +x /etc/init.d/mongdb 命令允許該腳本可被執行。

接着運行下面的命令註冊開機腳本:

 

  1. update-rc.d mongodb defaults  
  2. Adding system startup for /etc/init.d/mongodb ...  
  3. /etc/rc0.d/K20mongodb -> ../init.d/mongodb  
  4. /etc/rc1.d/K20mongodb -> ../init.d/mongodb  
  5. /etc/rc6.d/K20mongodb -> ../init.d/mongodb  
  6. /etc/rc2.d/S20mongodb -> ../init.d/mongodb  
  7. /etc/rc3.d/S20mongodb -> ../init.d/mongodb  
  8. /etc/rc4.d/S20mongodb -> ../init.d/mongodb  
  9. /etc/rc5.d/S20mongodb -> ../init.d/mongodb 

 

你也可以通過update-rc.d -f mongodb remove 刪除。

重新啓動,通過ps -def | grep mongod 可以查看到自啓動的服務進程,然後可以通過下面的命令關閉/啓動服務

sudo service mongodb stop

sudo service mongodb start

客戶端登錄服務器

啓動日誌如上,服務端啓動如上,現在我們在另外一個終端測試服務器是否正常。

進入/usr/local/mongodb-linux-x86_64-1.8.3/bin,執行./mongo。

出現:

MongoDB shell version: 1.8.3

connecting to: test

執行db.foo.save({1 : “Hello world”})

然後查找db.foo.find();

看到{ "_id" : ObjectId("4e4b395986738efa2d0718b9"), "1" : "hello world" }

執行到這裏恭喜你,成功安裝好了mongodb。

也可以通過下面這種方式連接遠程的mongodb server,默認端口爲27017,比如:

./mongo 192.168.30.25

創建數據庫

如果沒有mydb數據庫的話,在客戶端中使用命令:use mydb,將創建mydb數據庫,而且當前數據庫切換爲mydb。此時show dbs不顯示該數據庫名稱。使用db.stats()命令檢查當前數據庫狀態。

此文章轉載於http://database.51cto.com/art/201109/288576.htm

令附:mongodb管理工具的安裝:http://rockmongo.com/wiki/introduction?lang=zh_cn

發佈了46 篇原創文章 · 獲贊 4 · 訪問量 2萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章