新聞中心
MongoDB概述
MongoDB是一個介于關(guān)系數(shù)據(jù)庫和非關(guān)系數(shù)據(jù)庫之間的產(chǎn)品,是非關(guān)系數(shù)據(jù)庫當(dāng)中功能最豐富,最像關(guān)系數(shù)據(jù)庫的。它支持的數(shù)據(jù)結(jié)構(gòu)非常松散,是類似json的bson格式,因此可以存儲比較復(fù)雜的數(shù)據(jù)類型。Mongo最大的特點是它支持的查詢語言非常強大,其語法有點類似于面向?qū)ο蟮牟樵冋Z言,幾乎可以實現(xiàn)類似關(guān)系數(shù)據(jù)庫單表查詢的絕大部分功能,而且還支持對數(shù)據(jù)建立索引。
在鹿城等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè) 網(wǎng)站設(shè)計制作按需求定制開發(fā),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計,全網(wǎng)營銷推廣,外貿(mào)營銷網(wǎng)站建設(shè),鹿城網(wǎng)站建設(shè)費用合理。
MongoDB特點
面向集合存儲,易存儲對象類型的數(shù)據(jù);
模式自由、支持查詢、支持動態(tài)查詢;
支持完全索引,包含內(nèi)部對象;
支持復(fù)制和故障恢復(fù);
使用高效的二進制數(shù)據(jù)存儲,包括大型對象(如視頻等);
自動處理碎片,以支持云計算層次的擴展性;
支持RUBY,PYTHON,JAVA,C++,PHP,C#等多種語言;
文件存儲格式為BSON(一種JSON的擴展);
可通過網(wǎng)絡(luò)訪問。
在Linux安裝MongoDB
#配置yum源倉庫
cd /etc/yum.repos.d/
vim mongodb-org.repo
[mongodb-org]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.6/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-3.6.asc
#安裝 MongoDB
yum install mongodb-org -y
#修改配置文件
vim /etc/mongod.conf
#修改第30行的監(jiān)聽地址
bindIp: 0.0.0.0
#開啟服務(wù)
systemctl start mongod.service
#關(guān)閉防火墻和安全功能
systemctl stop firewalld.service
setenforce 0
#查看服務(wù)端口狀態(tài)
netstat -ntap | grep mongod
#復(fù)制配置文件,以開啟多實例
cp -p /etc/mongod.conf /etc/mongod2.conf
#修改配置文件
vim /etc/mongod2.conf
#第10行,修改日志文件目錄
path: /var/log/mongodb/mongod2.log
#第14行,修改數(shù)據(jù)存儲目錄
dbPath: /data/mongodb/mongo
#第29行,修改服務(wù)端口號
port: 27018
#創(chuàng)建實例的目錄和日志文件
mkdir -p /data/mongodb
cd /data/mongodb/
mkdir mongo
touch mongod2.log
#目錄授權(quán)
chmod 777 mongod2.log
#啟動實例
mongod -f /etc/mongod2.conf
#指定實例的端口
mongo --port 27018
#查看服務(wù)端口狀態(tài)
netstat -ntap
MongoDB 基礎(chǔ)操作
#查看版本
db.version()
#查看數(shù)據(jù)庫
show dbs;
#查看當(dāng)前數(shù)據(jù)庫機器的連接地址
db.getMongo()
#顯示集合操作命令
db.集合名.help
#顯示用戶
show users
增刪改查
use school;
#打開school數(shù)據(jù)庫, 不存在會創(chuàng)建,不建立集合又會刪除
db.createCollection('info')
#創(chuàng)建集合
db.info.insert({"id":1,"name":"zhangsan","hobby":["game","talk"]})
#添加數(shù)據(jù)
db.info.find()
#查看info集合中所有文檔
show collections
#查看數(shù)據(jù)庫中所有集合
db.info.update({"id":10},{$set:{"name":"tom"}})
#更改數(shù)據(jù)
db.info.remove({"id":2})
#移除info集合中的id2的數(shù)據(jù)
db.info.drop()
#刪除info集合
db.dropDatabase()
#刪除數(shù)據(jù)庫 先use到要刪的數(shù)據(jù)庫里在刪
db.info.count()
#統(tǒng)計有多少條數(shù)據(jù)
MongoDB 數(shù)據(jù)類型
String
#字符串,最常用,必須是utf-8
Boolean
#布爾值,true 或者false
Integer
#整數(shù)型
Double
#浮點型
Arrays
#數(shù)組或者列表,多個值存儲到一個鍵
Object
#用于嵌入文檔,即一個值為一個文檔
Null
#存儲null值
Binary Data
#二進制數(shù)據(jù),用于存儲二進制數(shù)據(jù)
Date
#存儲當(dāng)前日期或時間unix時間格式
查看數(shù)據(jù)類型
a=db.info.findOne({"id":1})
#查找指定記錄并賦予別名a
ypeof(a.id)
#查看屬性類型
備份與恢復(fù)數(shù)據(jù)
導(dǎo)出工具:mongoexport
導(dǎo)入工具:mongoimport
常見選項:
-h,--host :代表遠程連接的數(shù)據(jù)庫地址,默認連接本地Mongo數(shù)據(jù)庫;
--port:代表遠程連接的數(shù)據(jù)庫的端口,默認連接的遠程端口27017;
-u,--username:代表連接遠程數(shù)據(jù)庫的賬號,如果設(shè)置數(shù)據(jù)庫的認證,需要指定用戶賬號;
-p,--password:代表連接數(shù)據(jù)庫的賬號對應(yīng)的密碼;
-d,--db:代表連接的數(shù)據(jù)庫;
-c,--collection:代表連接數(shù)據(jù)庫中的集合;
-f, --fields:代表集合中的字段,可以根據(jù)設(shè)置選擇導(dǎo)出的字段;
--type:代表導(dǎo)出輸出的文件類型,包括csv和json文件;
-o, --out:代表導(dǎo)出的文件名;
-q, --query:代表查詢條件;
--skip:跳過指定數(shù)量的數(shù)據(jù);
--limit:讀取指定數(shù)量的數(shù)據(jù)記錄;
--sort:對數(shù)據(jù)進行排序,可以通過參數(shù)指定排序的字段,并使用 1 和 -1 來指定排序的方式,其中 1 為升序排列,而-1是用于降序排列,如sort({KEY:1})。
for(var i=1;i<=100;i++)db.info.insert({"id":i,"name":"jack"+i})
#循環(huán)寫入100條數(shù)據(jù)
mongoexport -d school -c info -o /opt/info.json
#導(dǎo)出指定文件
mongoimport -d school -c info1 --file /opt/info.json
#導(dǎo)入到info1集合
mongoexport -d school -c info1 -q '{"id":{"$eq":10}}' -o /opt/top10.json
#查詢指定第10行條件導(dǎo)出
備份與恢復(fù)
備份工具:mongodump
恢復(fù)工具:mongorestore
常用選項:
-h 指定Mongodb所在服務(wù)器的地址也可以指定端口(例:-h 127.0.0.1:27017)
-d :需要備份的數(shù)據(jù)庫;
-o :備份數(shù)據(jù)存放的目錄 該目錄需提前創(chuàng)建
mkdir /backup
#創(chuàng)建存放目錄
mongodump -d school -o /backup/
#備份school數(shù)據(jù)庫
mongorestore -d school1 --dir=/backup/school
#恢復(fù)到school1數(shù)據(jù)庫
復(fù)制數(shù)據(jù)庫:
db.copyDatabase("school","school2")
#復(fù)制數(shù)據(jù)庫school 到school2中
克隆數(shù)據(jù)庫:
把數(shù)據(jù)庫school的info集合 克隆到實例2
先進入實例2的MongoDB
mongo --port 27018
db.runCommand({"cloneCollection":"school.info","from":"192.168.142.152:27017"})
安全管理
創(chuàng)建管理用戶;
啟動時必須指定 auth=true;
可以將用戶分配角色;
內(nèi)置數(shù)據(jù)庫用戶角色: read 、 readWrite;
數(shù)據(jù)庫管理員角色: dbAmin 、 dbOwner 、 userAdmin;
超級用戶管理員用戶:root
#編輯配置文件
vim /etc/mongod.conf
auth=true
#添加指定
use admin
db.createUser({"yj":"root","pwd":"123","roles":["root"]})
#創(chuàng)建用戶yj 密碼123 分配root角色
db.auth("root","123")
#驗證用戶
進程管理
查看當(dāng)前正在運行的進程: db.currentOp()
終止正在運行的進程: db.killOp(opid值)
db.currentOp()
#查看當(dāng)前運行進程
db.killOp(4872)
#終止4872進程
MongoDB 監(jiān)控
MongoDB提供一些內(nèi)置工具可以監(jiān)測數(shù)據(jù)庫的狀態(tài)信息
查看數(shù)據(jù)庫實例的狀態(tài)信息: db.serverStatus()
查看數(shù)據(jù)庫的統(tǒng)計信息: db.stats()
此外也可以通過web界面查看系統(tǒng)監(jiān)控信息需要在配置文件中加入
##編輯配置文件
vim /etc/mongod.conf
#開啟http服務(wù)
httpinterface=true
當(dāng)前文章:非關(guān)系數(shù)據(jù)庫------MongoDB的安裝與使用
URL鏈接:http://fisionsoft.com.cn/article/goiidd.html