MongoDBのインストールベース(戦闘の展開)

MongoDBはインストールベース

MongoDBの概要

(1)MongoDBは、分散ファイルストレージベースのデータベースです。C ++言語で書かれました。WEBアプリケーションのためのスケーラブルで高性能データ・ストレージ・ソリューションを提供するために設計されています。

(2)MongoDBはリレーショナルデータベースと非リレーショナル・データベース、最も豊富間の非リレーショナルデータベース機能と最もリレーショナルデータベース等との機能を持つ製品です。より複雑なデータ型を格納することが可能で、データ構造が非常に緩んでいる同様の形式BSON JSONをサポートしています。Mongoの最大の特徴は、その構文は、機能の大部分は、ほぼ単一テーブルは、リレーショナルデータベースに似照会達成するだけでなく、データのインデックス作成をサポートすることができ、オブジェクト指向のクエリ言語に多少似ているが、それは非常に強力なクエリ言語をサポートしていることです。

(3)特徴:

セットは、データオブジェクトタイプの容易なストレージのために格納されます。

フリーモードでは、サポートクエリ、動的照会のためのサポート。

完全にインデックス化支持体は、内部オブジェクトが含まれています。

サポートレプリケーションとフェイルオーバー。

ラージ・オブジェクト(例えば、ビデオ、等)を含む効率的なバイナリデータストレージを使用して、

支持クラウド・コンピューティング・スケーラビリティレベルへの自動処理チップ。

サポートRUBY、PYTHON、JAVA、C ++、PHP、C#や他の言語。

BSONのファイル保存形式(一種のJSON拡張)。

これは、ネットワークを介してアクセスすることができます。

MongoDBのインストールプロセス

1、テストの準備

名前 役割 アドレス
Centos7-1 サービスキャリアマシン 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)のインストールと設定

//安装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; :.式に等しいより大きくない、以下に等しい)の分析します

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")                    #验证

おすすめ

転載: blog.51cto.com/14484404/2460798