MongoDB基础安装(实战部署)
2019-12-22 20:33
1086 查看
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=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") #验证
相关文章推荐
- MongoDB实战全攻略(含安装常用命令备份恢复及主从(含副本集合)部署)
- Nginx实战基础篇一 源码包编译安装部署web服务器
- Nginx实战基础篇六 通过源码包编译安装部署LNMP搭建Discuz论坛 推荐
- Nginx实战基础篇一 源码包编译安装部署web服务器
- Nginx实战基础篇一 源码包编译安装部署web服务器 推荐
- Nginx实战基础篇一 源码包编译安装部署web服务器
- VS.NET2005安装部署之实战
- Linux-Ubuntu14.04下mongodb安装部署
- ELK日志分析系统实战(一)安装和部署
- Nginx实战基础篇七 最新源码包通过脚本部署LAMP搭建Discuz论坛 推荐
- OpenStack实战安装部署
- 《统一沟通-微软-实战》-1-部署-基础环境-2-ADCS
- mongodb在window下和linux下的部署 和 安装可视化工具
- centos7下安装部署mongodb集群(副本集模式)
- Win7下MongoDB的安装和部署测试
- Windows Server 2012 虚拟化实战:SCVMM的安装和部署
- Mongodb安装,主从部署
- mongodb 监控工具 mongo-monitor 安装部署
- 基于.NET平台的Windows编程实战(九)— 安装与部署