您好,登錄后才能下訂單哦!
(1)MongoDB是一個基于分布式文件存儲的數據庫。由C++語言編寫。旨在為WEB應用提供可擴展的高性能數據存儲解決方案。
(2)MongoDB是一個介于關系數據庫和非關系數據庫之間的產品,是非關系數據庫當中功能最豐富,最像關系數據庫的。它支持的數據結構非常松散,是類似json的bson格式,因此可以存儲比較復雜的數據類型。Mongo最大的特點是它支持的查詢語言非常強大,其語法有點類似于面向對象的查詢語言,幾乎可以實現類似關系數據庫單表查詢的絕大部分功能,而且還支持對數據建立索引。
(3)使用原理:
所謂“面向集合”(Collection-Oriented),意思是數據被分組存儲在數據集中,被稱為一個集合(Collection)。每個集合在數據庫中都有一個唯一的標識名,并且可以包含無限數目的文檔。集合的概念類似關系型數據庫(RDBMS)里的表(table),不同的是它不需要定義任何模式(schema)。Nytro MegaRAID技術中的閃存高速緩存算法,能夠快速識別數據庫內大數據集中的熱數據,提供一致的性能改進。
模式自由(schema-free),意味著對于存儲在mongodb數據庫中的文件,我們不需要知道它的任何結構定義。如果需要的話,你完全可以把不同結構的文件存儲在同一個數據庫里。
存儲在集合中的文檔,被存儲為鍵-值對的形式。鍵用于唯一標識一個文檔,為字符串類型,而值則可以是各種復雜的文件類型。我們稱這種存儲形式為BSON(Binary Serialized Document Format)。
MongoDB已經在多個站點部署,其主要場景如下:
1)網站實時數據處理。它非常適合實時的插入、更新與查詢,并具備網站實時數據存儲所需的復制及高度伸縮性。
2)緩存。由于性能很高,它適合作為信息基礎設施的緩存層。在系統重啟之后,由它搭建的持久化緩存層可以避免下層的數據源過載。
3)高伸縮性的場景。非常適合由數十或數百臺服務器組成的數據庫,它的路線圖中已經包含對MapReduce引擎的內置支持。
不適用的場景如下:
1)要求高度事務性的系統。
2)傳統的商業智能應用。
3)復雜的跨文檔(表)級聯查詢。
名稱 | 角色 | 地址 |
---|---|---|
Centos7-1 | 服務載體機 | 192.168.142.212 |
[root@promote yum.repos.d]# vim MongoDB.repo
[mongodb-org]
name=mongodb
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
[root@promote yum.repos.d]# yum install mongodb-org -y
//修改配置文件
[root@promote yum.repos.d]# vim /etc/mongod.conf
net:
port: 27017
//使服務能夠被任意網絡使用
bindIp: 0.0.0.0 # Listen to local interface only, comment to listen on all
//開啟服務
[root@promote yum.repos.d]# systemctl start mongod.service
[root@promote yum.repos.d]# netstat -atnp | grep 27017
tcp 0 0 0.0.0.0:27017 0.0.0.0:* LISTEN 39695/mongod
//進入MongoDB數據庫
[root@promote mongodb]# mongo --port 27017
此時,MongoDB服務已經安裝完畢,但實驗并不會到此結束,下面要開始的便是其安裝的引申過程
//在安裝完MongoDB的基礎上
[root@promote etc]# cp -p mongod.conf mongod2.conf
//修改第二個實例的配置文件
[root@promote yum.repos.d]# vim /etc/mongod2.conf
systemLog:
destination: file
logAppend: true
path: /data/mongodb/mongod2.log //日志文件路徑(需要區別于第一個)
storage:
dbPath: /data/mongodb/mongo //數據文件路徑(同樣)
journal:
enabled: true
net:
port: 27018 //設定一個與之前不同端口號
bindIp: 0.0.0.0 # Listen to local interface only, comment to listen on all int
//建立二號實例站點
[root@promote etc]# mkdir -p /data/mongodb //創建二號實例數據存放位置
[root@promote etc]# cd /data/mongodb/
[root@promote mongodb]# mkdir mongo
[root@promote mongodb]# touch mongod2.log //創建二號實例日志文件存放位置
[root@promote mongodb]# chmod 777 mongod2.log
//啟動二號實例
[root@promote mongodb]# mongod -f /etc//mongod2.conf
[root@promote mongodb]# mongo --port 27018 //通過不同的端口號進行不同的實例中
在MongoDB中進行
mysql">> show dbs/databases #查看所有數據庫
> show collections/tables #查看數據庫中所有集合
> db.info.find(條件) #查看集合中內容
例:> db.info.find({"id":20}) #查看id為20的信息
> use school; #不存在數據庫會創建并進入,而又不建立集合則并不進行顯示
> db.createCollection('info') #建立集合(數據表)info
> db.info.insert({"id":10,"name":zhangsan,"鍵名":值}) #在集合中插入值
> db.info.insert({"hobby":["game","read","值"]}) #在集合中添加字符串數組
> a=db.info.find() #將查找結果定義別名
> for (var i=11;i<=100;i++)db.info.insert({"id":i,"name":"liuliu"+i}) #循環插入鍵值對
> db.info.update({"id":20},{$set:{"name":"kaili"}}) #更改數據
##將id=20中的name更改為kaili
> db.info.count() #統計集合中有多少數據
> db.test.drop() #刪除某個集合
> db.test.remove({"id":8}) #刪除某個數據
> db.dropDatabase() #刪除整個數據庫(在進入該數據庫的前提下)
> db.copyDatabase("school","shell") #將school數據庫復制為shell數據庫(改名字拷貝)
導出
[root@promote mongodb]# mongoexport -d school -c info -o /opt/school.json
“-d” 指定數據庫
“-c” 指定集合
“-o” 指定導出路徑
導入(導入數據庫可不存在)
[root@promote mongodb]# mongoimport -d school -c info --file=/opt/school.json
“--file” 指定導入的json文件
條件導出
[root@promote mongodb]# mongoexport -d school -c info -q '{"id":{"$eq":20}}' -o /opt/ttt.json
“-q” 條件判斷(大于:gt;小于:lt;等于:eq。沒有大于等于、小于等于)
備份
[root@promote mongodb]# mongodump -d school -o /opt/
恢復
[root@promote mongodb]# mongorestore -d school --dir=/opt/school
“--dir” 指定備份目錄路徑
前提:MongoDB多實例的情況下
[root@promote mongodb]# mongo --port 27018 #進入第二個實例
#從本機的27017端口的MongoDB數據庫中克隆其中school.info集合到本實例中
> db.runCommand({"cloneCollection":"school.info","from":"192.168.142.212:27017"})
> use admin #該數據庫默認存在
> db.createUser({"user":"root","pwd":"123123","roles":["root"]}) #建立管理用戶
"user" #管理用戶名
"pwd" #密碼
"roles":["root"] #權限為管理員身份
> db.auth("root","123123") #驗證
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。