mongodb在linux下的安裝

1. 下載MongoDBlinux

2. 解壓文件到某目錄下,而後重命名:mongodb

  1. [root@localhost      var]# tar -xzvf mongodb-linux-x86_64-enterprise-rhel62-3.4.9.tgz          shell

  2. [root@localhost var]# mv mongodb-linux-x86_64-enterprise-rhel62-3.4.9      /usr/local/mongodb  數據庫


bin
下的mongod就是MongoDB的服務端進程,mongo就是其客戶端,其它的命令用於MongoDB的其它用途如MongoDB文件導出等。安全

3. 啓動MongoDB.服務器

    要先創建好MongoDB 存放數據文件和日誌文件的目錄,此處創建在/data下:app

  1. [root@localhost var]# cd /data/db        yii

  2. [root@localhost db]# mkdir mongodb_datatcp

  3. [root@localhost db]# mkdir mongodb_logide

  4. [root@localhost db]# ls   

  5. mongodb_data  mongodb_log  

   在MongoDB安裝目錄下的bin下使用mongod啓動MongoDB,

  1. ./mongod --dbpath=/data/db/mongodb_data/ --logpath=/data/db/mongodb_log/mongodb.log --logappend&       

等待啓動成功後,可查看是否啓動成功了,默認端口號是27017,固然在啓動時也能夠指定未使用的其它端口。

  先經過查看端口號看MongoDB是否啓動了。

  1. [root@localhost /db]# netstat -lanp | grep "27017"  

  2. tcp        0      0 0.0.0.0:27017               0.0.0.0:*                   LISTEN           2442/mongod                 

unix  2      [ ACC ]     STREAM     LISTENING     18203   2442/mongod         /tmp/mongodb-27017.sock  

  能夠看到,已啓動成功,如今使用mongo客戶端訪問一下該數據庫。

  1. [root@localhost      bin]# ./mongo

  2. MongoDB shell      version v3.4.9

  3. connecting      to: mongodb://127.0.0.1:27017

  4. MongoDB      server version: 3.4.9 

  5. connecting to: test        

  6. >   

  安裝成功

4. 額外工做。

   把mongod放到服務自啓動項中

    編輯/etc/rc.d/rc.local,加入下述代碼而後再保存便可。 

   #add mongonDB service   

   rm -rf /data/db/mongodb_data/* && /usr/local/mongodb/bin/mongod --dbpath=/data/db/mongodb_data/ --logpath=/data/db/mongodb_log/mongodb.log --logappend&  

   咱們重啓計算機再看MongoDB是否啓動,重啓後能夠直接使用 mongo命令登陸,最終發現是能夠成功的。

   另外,咱們使用mongo命令登陸 MongoDB還要轉到mongo命令所在目錄再執行./mongo,這樣是否是有些麻煩?所以,咱們能夠簡化這點,將該命令文件copy到/usr/bin下,這樣就能夠在任何目錄下使用mongo命令了。

  1. [root@localhost bin]# ls   

  2. bsondump  dbbak  mongo  mongod  mongodump  mongoexport  mongofiles  mongoimport  mongorestore  mongos  mongosniff  mongostat        

  3. [root@localhost bin]# cp mongo /usr/bin/  

     轉到任一目錄試下mongo命令:

  1. [root@localhost bin]# cd /        

  2. [root@localhost /]# mongo   

  3. MongoDB shell version: 1.8.1        

  4. connecting to: test        

  5. >   

  能夠看到登陸成功了,說明咱們能夠像使用ls命令同樣使用mongo命令了。

 

 

鏈接數據庫(若是test不存在,則直接建立一個test)

use test

 

顯示數據庫:

show dbs

 

插入一條記錄(切換到指定數據庫下以後,須要插入至少一個文檔後纔會在show dbs中顯示數據庫名):

db.items.insert({"name":"yiibai tutorials"})

 

建立用戶和密碼(在admin庫上):

db.createUser({user: "lich",pwd: "goodjob1234",roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]})

 

驗證用戶權限(返回1則用戶存在):

db.auth('lich','goodjob1234')

 

查看admin庫裏面的所有用戶:
use admin;
db.system.users.find();

 

查看全部表:

show tables;

 

 

另外除了以上的默認啓動方式,還能夠經過配置mongod.conf的方式來啓動mongodb(未測試成功)

啓動MongoDB2種方式,一種是直接默認啓動,另外一種是指定配置文件。啓動方式以下:
1:  /etc/init.d/mongod start service mongod start 
2:  mongod --config /etc/mongodb.conf
下面咱們看看配置文件:
vi /etc/mongod.conf

# 日誌文件位置
logpath=/var/log/mongo/mongod.log

# 以追加方式寫入日誌
logappend=true

# 是否以守護進程方式運行
fork = true

# 默認27017
#port = 27017

# 數據庫文件位置
dbpath=/var/lib/mongo

# 啓用按期記錄CPU利用率和 I/O 等待
#cpu = true

# 是否以安全認證方式運行,默認是不認證的非安全方式
#noauth = true
#auth = true

# 詳細記錄輸出
#verbose = true

# Inspect all client data for validity on receipt (useful for
# developing drivers)用於開發驅動程序時驗證客戶端請求
#objcheck = true

# Enable db quota management
# 啓用數據庫配額管理
#quota = true
# 設置oplog記錄等級
# Set oplogging level where n is
#   0=off (default)
#   1=W
#   2=R
#   3=both
#   7=W+some reads
#diaglog=0

# Diagnostic/debugging option 動態調試項
#nocursors = true

# Ignore query hints 忽略查詢提示
#nohints = true
# 禁用http界面,默認爲localhost28017
#nohttpinterface = true

# 關閉服務器端腳本,這將極大的限制功能
# Turns off server-side scripting.  This will result in greatly limited
# functionality
#noscripting = true
# 關閉掃描表,任何查詢將會是掃描失敗
# Turns off table scans.  Any query that would do a table scan fails.
#notablescan = true
# 關閉數據文件預分配
# Disable data file preallocation.
#noprealloc = true
# 爲新數據庫指定.ns文件的大小,單位:MB
# Specify .ns file size for new databases.
# nssize =

# Replication Options 複製選項
# in replicated mongo databases, specify the replica set name here
#replSet=setname
# maximum size in megabytes for replication operation log
#oplogSize=1024
# path to a key file storing authentication info for connections
# between replica set members
#指定存儲身份驗證信息的密鑰文件的路徑
#keyFile=/path/to/keyfile

 

 

或者使用如下的配置:(可作複製集測試配置,注意端口號和複製集的名稱,複製集名稱必須都一致)

28001.conf

 

bind_ip=192.168.20.144

port=28001

logpath=/data/db/mongodb_log/28001.log

logappend=true

dbpath=/data/db/mongodb_data28001

replSet=imooc

fork=true

 

 

28002.conf

 

bind_ip=192.168.20.144

port=28002

logpath=/data/db/mongodb_log/28002.log

logappend=true

dbpath=/data/db/28002

replSet=imooc

fork=true

 

 

28003.conf

 

bind_ip=192.168.20.144

port=28003

logpath=/data/db/mongodb_log/28003.log

logappend=true

dbpath=/data/db/28003

replSet=imooc

fork=true

 

 

指定端口啓用mongo :

cd /usr/local/mongo/bin

 

./mongo 192.168.20.144:28001/admin

相關文章
相關標籤/搜索