加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 服务器 > 系统 > 正文

MongoDB的安装配置步骤

发布时间:2023-10-11 15:13:27 所属栏目:系统 来源:
导读:MongoDB概述

(1)MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。

(2)MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据
MongoDB概述
 
(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)复杂的跨文档(表)级联查询。
 
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中进行
 
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数据库(改名字拷贝)
 
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")                    #验证
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章