热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MongoDB基础安装(实战部署)

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

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

推荐阅读
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • Linux如何安装Mongodb的详细步骤和注意事项
    本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
  • vue使用
    关键词: ... [详细]
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • Windows7 64位系统安装PLSQL Developer的步骤和注意事项
    本文介绍了在Windows7 64位系统上安装PLSQL Developer的步骤和注意事项。首先下载并安装PLSQL Developer,注意不要安装在默认目录下。然后下载Windows 32位的oracle instant client,并解压到指定路径。最后,按照自己的喜好对解压后的文件进行命名和压缩。 ... [详细]
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
  • 如何查询zone下的表的信息
    本文介绍了如何通过TcaplusDB知识库查询zone下的表的信息。包括请求地址、GET请求参数说明、返回参数说明等内容。通过curl方法发起请求,并提供了请求示例。 ... [详细]
  • SpringMVC接收请求参数的方式总结
    本文总结了在SpringMVC开发中处理控制器参数的各种方式,包括处理使用@RequestParam注解的参数、MultipartFile类型参数和Simple类型参数的RequestParamMethodArgumentResolver,处理@RequestBody注解的参数的RequestResponseBodyMethodProcessor,以及PathVariableMapMethodArgumentResol等子类。 ... [详细]
  • 本文介绍了如何使用JSONObiect和Gson相关方法实现json数据与kotlin对象的相互转换。首先解释了JSON的概念和数据格式,然后详细介绍了相关API,包括JSONObject和Gson的使用方法。接着讲解了如何将json格式的字符串转换为kotlin对象或List,以及如何将kotlin对象转换为json字符串。最后提到了使用Map封装json对象的特殊情况。文章还对JSON和XML进行了比较,指出了JSON的优势和缺点。 ... [详细]
author-avatar
企鹅
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有