下載二進(jìn)制包:
#wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.0.15.tgz
#tar xf mongodb-linux-x86_64-3.0.15.tgz
#cd mongodb-linux-x86_64-3.0.15
創(chuàng)建數(shù)據(jù)存放路徑、日志存放路徑、程序路徑
#mkdir /data/mongodata -p
#mkdir /data/log/mongolog -p
#mkdir /data/mongo -p
將當(dāng)前所有文件復(fù)制
#cp -r * /data/mongo
配置環(huán)境變量
#more /etc/profile.d/mongodb.sh
export PATH=$PATH:/data/mongo/bin
#source /etc/profile.d/mongodb.sh
配置mongodb配置文件
#cd /data/mongo/bin/
#vim mongodb.conf
#數(shù)據(jù)文件存放目錄
dbpath = /data/mongodata
#日志文件存放目錄
logpath = /data/log/mongolog/mongodb.log
#端口
port = 27017
#以守護(hù)程序的方式啟用,即在后臺(tái)運(yùn)行
fork = true
nohttpinterface = true
確定服務(wù)
#mongod --dbpath=/data/mongodata --logpath=/data/log/mongolog/mongodb.log --logappend --fork
通過配置文件啟動(dòng)
#mongod -f /root/mongodb/bin/mongodb.conf
測試
#mongo
MongoDB shell version: 3.0.15
connecting to: test
show dbs
local 0.078GB
quit()
WARNING: Readahead for /data/mongodata is set to 4096KB
WARNING: You are running this process as the root user, which is not recommended.
WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.
We suggest setting it to 'never'
WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
We suggest setting it to 'never'
WARNING: soft rlimits too low. rlimits set to 3802 processes, 65536 files. Number of processes should be at least 32768 : 0.5 times number of files.
啟動(dòng)有警告,去掉
#vim /etc/rc.local
if test -f /sys/kernel/mm/transparent_hugepage/enabled; then
echo never > /sys/kernel/mm/transparent_hugepage/enabled
fi
if test -f /sys/kernel/mm/transparent_hugepage/defrag; then
echo never > /sys/kernel/mm/transparent_hugepage/defrag
fi
ulimit -u 65535
#echo never > /sys/kernel/mm/transparent_hugepage/enabled
#echo never > /sys/kernel/mm/transparent_hugepage/defrag
#runlevel
#chmod +x /etc/rc.local
文件限制數(shù)調(diào)整
#vim /etc/security/limits.conf
use admin
switched to db admin
db.shutdownServer();
配置啟動(dòng)服務(wù)
#vim /usr/lib/systemd/system/systemd-mongodb.service
[Unit]
Description=mongodb
After=network.target
[Service]
Type=forking
PIDFile=/data/mongodata/mongod.lock
ExecStart=/data/mongo/bin/mongod -f /data/mongo/bin/mongodb.conf
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target
開啟機(jī)器
#systemctl enable systemd-mongodb
進(jìn)入查看數(shù)據(jù)庫,只有一個(gè)local庫,admin庫是不存在的
show dbs
local 0.078GB
show tables;
新建賬號具有g(shù)rant權(quán)限,即:賬號管理的授權(quán)權(quán)限
use admin
switched to db admin
db.createUser(
... {
... user:"dba",
... pwd: "dba",
... roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
... }
... )
Successfully added user: {
"user" : "dba",
"roles" : [
{
"role" : "userAdminAnyDatabase",
"db" : "admin"
}
]
}
show dbs;
admin 0.078GB
local 0.078GB
user:用戶名
pwd:密碼
roles:指定用戶的角色,可以用一個(gè)空數(shù)組給新用戶設(shè)定空角色;在roles字段,可以指定內(nèi)置角色和用戶定義的角色。role里的角色可以選:
Built-In Roles(內(nèi)置角色):
Mongodb中 數(shù)據(jù)庫和集合的創(chuàng)建與刪除
插數(shù)據(jù)
show dbs //查詢所有的數(shù)據(jù)庫
admin 0.078GB
cmz 0.078GB
local 0.078GB
show collections //查詢所有的集合(表)等同于show tables
創(chuàng)建數(shù)據(jù)庫或切換到數(shù)據(jù)庫(存在就切換,不存在就創(chuàng)建)
use cmz
switched to db cmz
創(chuàng)建集合,刪除集合(一般可以不用創(chuàng)造集合,在插入數(shù)據(jù)時(shí)自動(dòng)可以創(chuàng)建集合):
db.createCollection('col') //創(chuàng)建集合
{ "ok" : 1 }
show collections
col
db.col.drop() //刪除集合
true
5、備份
-h 指明數(shù)據(jù)庫宿主機(jī)的IP
--port 指明數(shù)據(jù)庫的端口
-u 指明數(shù)據(jù)庫的用戶名
-p 指明數(shù)據(jù)庫的密碼
-d 指明數(shù)據(jù)庫的名字
-c 指明collection的名字
-o 指明到要導(dǎo)出的文件名
-q 指明導(dǎo)出數(shù)據(jù)的過濾條件
--authenticationDatabase 驗(yàn)證數(shù)據(jù)的名稱
--gzip 備份時(shí)壓縮
--oplog use oplog for taking a point-in-time snapshot
全庫備份
mongodump -h 10.0.0.4 --authenticationDatabase admin -o /mnt/
備份cmz庫
mongodump -h 10.0.0.4 --authenticationDatabase admin -d cmz -o /mnt1/
備份cmz庫的col集合
mongodump -h 10.0.0.4 --authenticationDatabase admin -d cmz -c col -o /mnt2/
創(chuàng)建test庫
use test
switched to db test
db.createUser(
... {
... user: "jrw",
... pwd: "jrw",
... roles: [
... { role: "readWrite", db: "test" }
... ]
... }
... )
Successfully added user: {
"user" : "jrw",
"roles" : [
{
"role" : "readWrite",
"db" : "test"
}
]
}
show users;
{
"_id" : "test.jrw",
"user" : "jrw",
"db" : "test",
"roles" : [
{
"role" : "readWrite",
"db" : "test"
}
]
}
參考文檔:
https://blog.51cto.com/xiaorenwutest/2137022