(1)MongoDB是一個基於分佈式文件存儲的數據庫。由C++語言編寫。旨在爲WEB應用提供可擴展的高性能數據存儲解決方案。java
(2)MongoDB是一個介於關係數據庫和非關係數據庫之間的產品,是非關係數據庫當中功能最豐富,最像關係數據庫的。它支持的數據結構很是鬆散,是相似json的bson格式,所以能夠存儲比較複雜的數據類型。Mongo最大的特色是它支持的查詢語言很是強大,其語法有點相似於面向對象的查詢語言,幾乎能夠實現相似關係數據庫單表查詢的絕大部分功能,並且還支持對數據創建索引。mysql
(3)特色:sql
面向集合存儲,易存儲對象類型的數據;mongodb
模式自由、支持查詢、支持動態查詢;shell
支持徹底索引,包含內部對象;數據庫
支持複製和故障恢復;json
使用高效的二進制數據存儲,包括大型對象(如視頻等);vim
自動處理碎片,以支持雲計算層次的擴展性;數組
支持RUBY,PYTHON,JAVA,C++,PHP,C#等多種語言;網絡
文件存儲格式爲BSON(一種JSON的擴展);
可經過網絡訪問。
名稱 | 角色 | 地址 |
---|---|---|
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中進行
> 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") #驗證