MongoDB的安裝配置流程

MongoDB概述

(1)MongoDB是一個基于分布式文件存儲的數(shù)據(jù)庫。由C++語言編寫。旨在為WEB應(yīng)用提供可擴展的高性能數(shù)據(jù)存儲解決方案。

專業(yè)成都網(wǎng)站建設(shè)公司,做排名好的好網(wǎng)站,排在同行前面,為您帶來客戶和效益!成都創(chuàng)新互聯(lián)為您提供成都網(wǎng)站建設(shè),五站合一網(wǎng)站設(shè)計制作,服務(wù)好的網(wǎng)站設(shè)計公司,網(wǎng)站制作、網(wǎng)站建設(shè)負責任的成都網(wǎng)站制作公司!

(2)MongoDB是一個介于關(guān)系數(shù)據(jù)庫和非關(guān)系數(shù)據(jù)庫之間的產(chǎn)品,是非關(guān)系數(shù)據(jù)庫當中功能最豐富,最像關(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ù)建立索引。

(3)使用原理:

所謂“面向集合”(Collection-Oriented),意思是數(shù)據(jù)被分組存儲在數(shù)據(jù)集中,被稱為一個集合(Collection)。每個集合在數(shù)據(jù)庫中都有一個唯一的標識名,并且可以包含無限數(shù)目的文檔。集合的概念類似關(guān)系型數(shù)據(jù)庫(RDBMS)里的表(table),不同的是它不需要定義任何模式(schema)。Nytro MegaRAID技術(shù)中的閃存高速緩存算法,能夠快速識別數(shù)據(jù)庫內(nèi)大數(shù)據(jù)集中的熱數(shù)據(jù),提供一致的性能改進。

模式自由(schema-free),意味著對于存儲在mongodb數(shù)據(jù)庫中的文件,我們不需要知道它的任何結(jié)構(gòu)定義。如果需要的話,你完全可以把不同結(jié)構(gòu)的文件存儲在同一個數(shù)據(jù)庫里。

存儲在集合中的文檔,被存儲為鍵-值對的形式。鍵用于唯一標識一個文檔,為字符串類型,而值則可以是各種復(fù)雜的文件類型。我們稱這種存儲形式為BSON(Binary Serialized Document Format)。

MongoDB已經(jīng)在多個站點部署,其主要場景如下:

1)網(wǎng)站實時數(shù)據(jù)處理。它非常適合實時的插入、更新與查詢,并具備網(wǎng)站實時數(shù)據(jù)存儲所需的復(fù)制及高度伸縮性。

2)緩存。由于性能很高,它適合作為信息基礎(chǔ)設(shè)施的緩存層。在系統(tǒng)重啟之后,由它搭建的持久化緩存層可以避免下層的數(shù)據(jù)源過載。

3)高伸縮性的場景。非常適合由數(shù)十或數(shù)百臺服務(wù)器組成的數(shù)據(jù)庫,它的路線圖中已經(jīng)包含對MapReduce引擎的內(nèi)置支持。

不適用的場景如下:

1)要求高度事務(wù)性的系統(tǒng)。

2)傳統(tǒng)的商業(yè)智能應(yīng)用。

3)復(fù)雜的跨文檔(表)級聯(lián)查詢。

MongoDB安裝流程

1、實驗準備

名稱角色地址
Centos7-1服務(wù)載體機192.168.142.212

2、具體流程

(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)安裝服務(wù)本體并進行配置
//安裝MongoDB
[root@promote yum.repos.d]# yum install mongodb-org -y

//修改配置文件
[root@promote yum.repos.d]# vim /etc/mongod.conf
net:
  port: 27017
//使服務(wù)能夠被任意網(wǎng)絡(luò)使用
  bindIp: 0.0.0.0  # Listen to local interface only, comment to listen on all 

//開啟服務(wù)
[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數(shù)據(jù)庫
[root@promote mongodb]# mongo --port 27017

此時,MongoDB服務(wù)已經(jīng)安裝完畢,但實驗并不會到此結(jié)束,下面要開始的便是其安裝的引申過程

(3)建立MongoDB多實例
//在安裝完MongoDB的基礎(chǔ)上
[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            //日志文件路徑(需要區(qū)別于第一個)
storage:
  dbPath: /data/mongodb/mongo                //數(shù)據(jù)文件路徑(同樣)
  journal:
    enabled: true
net:
  port: 27018                     //設(shè)定一個與之前不同端口號
  bindIp: 0.0.0.0  # Listen to local interface only, comment to listen on all int

//建立二號實例站點
[root@promote etc]# mkdir -p /data/mongodb            //創(chuàng)建二號實例數(shù)據(jù)存放位置
[root@promote etc]# cd /data/mongodb/
[root@promote mongodb]# mkdir mongo
[root@promote mongodb]# touch mongod2.log          //創(chuàng)建二號實例日志文件存放位置
[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                     #查看所有數(shù)據(jù)庫
> show collections/tables            #查看數(shù)據(jù)庫中所有集合
> db.info.find(條件)                 #查看集合中內(nèi)容
    例:> db.info.find({"id":20})         #查看id為20的信息
> use school;                    #不存在數(shù)據(jù)庫會創(chuàng)建并進入,而又不建立集合則并不進行顯示
> db.createCollection('info')                   #建立集合(數(shù)據(jù)表)info
> db.info.insert({"id":10,"name":zhangsan,"鍵名":值})            #在集合中插入值
> db.info.insert({"hobby":["game","read","值"]})                #在集合中添加字符串數(shù)組           
> a=db.info.find()               #將查找結(jié)果定義別名
> for (var i=11;i<=100;i++)db.info.insert({"id":i,"name":"liuliu"+i})                #循環(huán)插入鍵值對
> db.info.update({"id":20},{$set:{"name":"kaili"}})                    #更改數(shù)據(jù)
##將id=20中的name更改為kaili
> db.info.count()               #統(tǒng)計集合中有多少數(shù)據(jù)
> db.test.drop()                #刪除某個集合
> db.test.remove({"id":8})        #刪除某個數(shù)據(jù)
> db.dropDatabase()        #刪除整個數(shù)據(jù)庫(在進入該數(shù)據(jù)庫的前提下)
> db.copyDatabase("school","shell")        #將school數(shù)據(jù)庫復(fù)制為shell數(shù)據(jù)庫(改名字拷貝)
MongoDB導(dǎo)入、導(dǎo)出

導(dǎo)出

[root@promote mongodb]# mongoexport -d school -c info -o /opt/school.json

“-d”    指定數(shù)據(jù)庫
“-c”    指定集合
“-o”    指定導(dǎo)出路徑

導(dǎo)入(導(dǎo)入數(shù)據(jù)庫可不存在)

[root@promote mongodb]# mongoimport -d school -c info --file=/opt/school.json

“--file”   指定導(dǎo)入的json文件

條件導(dǎo)出

[root@promote mongodb]# mongoexport -d school -c info -q '{"id":{"$eq":20}}' -o /opt/ttt.json

“-q”  條件判斷(大于:gt;小于:lt;等于:eq。沒有大于等于、小于等于)

MongoDB備份、恢復(fù)

備份

[root@promote mongodb]# mongodump -d school -o /opt/

恢復(fù)

[root@promote mongodb]# mongorestore -d school --dir=/opt/school

“--dir”      指定備份目錄路徑

克隆某實例中的集合

前提:MongoDB多實例的情況下

[root@promote mongodb]# mongo --port 27018             #進入第二個實例

#從本機的27017端口的MongoDB數(shù)據(jù)庫中克隆其中school.info集合到本實例中
> db.runCommand({"cloneCollection":"school.info","from":"192.168.142.212:27017"})
創(chuàng)建管理用戶
> use admin               #該數(shù)據(jù)庫默認存在
> db.createUser({"user":"root","pwd":"123123","roles":["root"]})     #建立管理用戶
"user"     #管理用戶名
"pwd"     #密碼
"roles":["root"]      #權(quán)限為管理員身份
> db.auth("root","123123")                    #驗證

文章標題:MongoDB的安裝配置流程
網(wǎng)頁URL:http://muchs.cn/article30/ijdepo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護、網(wǎng)站排名、定制網(wǎng)站企業(yè)建站、標簽優(yōu)化、外貿(mào)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)