MongoDB基礎安裝(實戰部署)

MongoDB基礎安裝

MongoDB概述

(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的擴展);

可經過網絡訪問。

MongoDB安裝流程

一、實驗準備

名稱 角色 地址
Centos7-1 服務載體機 192.168.142.212

二、具體流程

(1)配置本地YUM源(路徑位置:/etc/yum.repos.d/)

[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

(2)安裝服務本體並進行配置

//安裝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服務已經安裝完畢,但實驗並不會到此結束,下面要開始的即是其安裝的引伸過程

(3)創建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基本操做

在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數據庫(更名字拷貝)

MongoDB導入、導出

導出

[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。沒有大於等於、小於等於)

MongoDB備份、恢復

備份

[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")                    #驗證
相關文章
相關標籤/搜索