千家信息网

MongoDB基础安装

发表于:2025-11-13 作者:千家信息网编辑
千家信息网最后更新 2025年11月13日,MongoDB基础安装MongoDB概述(1)MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。(2)MongoDB是一个介于关系数
千家信息网最后更新 2025年11月13日MongoDB基础安装

MongoDB基础安装

MongoDB概述

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

(2)MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。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=mongodbbaseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.6/x86_64/gpgcheck=1enabled=1gpgkey=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.confnet:  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 27017tcp        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.confsystemLog:  destination: file  logAppend: true  path: /data/mongodb/mongod2.log            //日志文件路径(需要区别于第一个)storage:  dbPath: /data/mongodb/mongo                //数据文件路径(同样)  journal:    enabled: truenet:  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")                    #验证
数据 数据库 实例 支持 文件 存储 路径 服务 查询 对象 语言 管理 配置 不同 位置 备份 条件 用户 基础 前提 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 南京企业软件开发管理方法 村村通网络安全ppt 华为软件开发值得去吗 慈溪敏捷软件开发工具 和平精英咋退出服务器 网络安全与工程的复试科目 青岛恒峰网络技术有限公司 深泽新时代软件开发服务咨询报价 软件开发中测试是做什么的 网络安全 安恒信息 暗黑重制版哪个服务器不卡 课程的目录怎么存放在数据库中 photo服务器 宿迁网络技术学院 安徽众人互联网科技有限公司 控制策略软件开发岗位信息 广州电信dns服务器 阿里云服务器如何查看到期时间 笔记本电脑打开数据库 贵州迈瑞网络技术有限公司 access数据库数据类型 平度商城软件开发系统 沈阳网络技术培训 福建长乐网络技术有限公司 怎么查看联想服务器系统版本 搜云数据库怎么用 利用云盘作为服务器 安徽网络安全非标机箱上哪找 数据库建表时如何连接外键 战术小队没有官方服务器
0