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/)

[[email protected] 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
[[email protected] yum.repos.d]# yum install mongodb-org -y

//修改配置文件
[[email protected] 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 

//开启服务
[[email protected] yum.repos.d]# systemctl start mongod.service
[[email protected] yum.repos.d]# netstat -atnp | grep 27017
tcp        0      0 0.0.0.0:27017           0.0.0.0:*               LISTEN      39695/mongod

//进入MongoDB数据库
[[email protected] mongodb]# mongo --port 27017

此时,MongoDB服务已经安装完毕,但实验并不会到此结束,下面要开始的便是其安装的引申过程

(3)建立MongoDB多实例

//在安装完MongoDB的基础上
[[email protected] etc]# cp -p mongod.conf mongod2.conf
//修改第二个实例的配置文件
[[email protected] 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

//建立二号实例站点
[[email protected] etc]# mkdir -p /data/mongodb            //创建二号实例数据存放位置
[[email protected] etc]# cd /data/mongodb/
[[email protected] mongodb]# mkdir mongo
[[email protected] mongodb]# touch mongod2.log          //创建二号实例日志文件存放位置
[[email protected] mongodb]# chmod 777 mongod2.log

//启动二号实例
[[email protected] mongodb]# mongod -f /etc//mongod2.conf
[[email protected] 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导入、导出

导出

[[email protected] mongodb]# mongoexport -d school -c info -o /opt/school.json

“-d” 指定数据库
“-c” 指定集合
“-o” 指定导出路径

导入(导入数据库可不存在)

[[email protected] mongodb]# mongoimport -d school -c info --file=/opt/school.json

“--file” 指定导入的json文件

条件导出

[[email protected] mongodb]# mongoexport -d school -c info -q ‘{"id":{"$eq":20}}‘ -o /opt/ttt.json

“-q” 条件判断(大于:gt;小于:lt;等于:eq。没有大于等于、小于等于)

MongoDB备份、恢复

备份

[[email protected] mongodb]# mongodump -d school -o /opt/

恢复

[[email protected] mongodb]# mongorestore -d school --dir=/opt/school

“--dir” 指定备份目录路径

克隆某实例中的集合

前提:MongoDB多实例的情况下

[[email protected] 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")                    #验证

原文地址:https://blog.51cto.com/14484404/2460798

时间: 2024-10-05 05:07:01

MongoDB基础安装(实战部署)的相关文章

vue + experss项目搭建 + mongodb下载安装 + 实战篇

一:vue 项目搭建 二:experss项目搭建 三:mongodb下载安装(转自网络)Ayers 四:实战篇(转自网络)highsea

MongoDB基础安装、操作

内容要点: MongoDB介绍 linux系统安装MongoDB MongoDB基础操作 一.MongoDB : (1)MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案. (2)MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的.它支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型.Mongo最大的特点是它支持的查询语言非常强大,其语法有点

MongoDB基础--安装与问题

W7下安装: 安装mongoDB 解压mongodb; 新建文件夹C:\DATA\DB,这是mongoDB的默认数据文件夹; 添加path; 运行 cmd打开运行mongod 打开新的cmd运行mongo

一、MongoDB的下载、安装与部署

1.什么是MongoDB? 它是介于关系型数据库和非关系型数据库之间的一种NoSQL数据库,用C++编写,是一款集敏捷性.可伸缩性.扩展性于一身的高性能的面向文档的通用数据库. 2.为什么要用MongoDB? 它具有以下几个特征: a).灵活的文档数据模型 可以非常容易的存储不同结构的的数据,并且还能动态的修改这些数据的源结构模式 b).可伸缩可扩展性 从单个服务器到数千个节点,MongoDB可以很轻松的进行水平扩展,部署多个数据中心 c).二级索引 包括在完全一致的任何字段上的索引.地理空间.

MongoDB的下载、安装与部署

1.什么是MongoDB? 它是介于关系型数据库和非关系型数据库之间的一种NoSQL数据库,用C++编写,是一款集敏捷性.可伸缩性.扩展性于一身的高性能的面向文档的通用数据库. 2.为什么要用MongoDB? 它具有以下几个特征: a).灵活的文档数据模型 可以非常容易的存储不同结构的的数据,并且还能动态的修改这些数据的源结构模式 b).可伸缩可扩展性 从单个服务器到数千个节点,MongoDB可以很轻松的进行水平扩展,部署多个数据中心 c).二级索引 包括在完全一致的任何字段上的索引.地理空间.

WebServer 之apache(httpd2.2和httpd2.4)基础安装部署

一.Httpd2.2基础安装部署 1.httpd-2.2软件的基础配置说明: 2.HTTPD配置练习 1)修改监听的地址端口: 2)持久连接配置 3)MPM机制配置 4)DSO:支持动态装载和卸载 5)'Main' Server'配置 6)站点资源访问控制 7) 定义站点主页面 8) 定义路径别名: 9)日志设定 10)httpd-manual 手册软件 11)基于用户的访问控制机制 12)虚拟主机 13)status页面:httpd程序自带的能够不断的反馈刷新的方式显示内部状态页面 14)cu

Nagios监控基础安装与监控项部署(上)

前言:NAGIOS介绍: Nagios是一款开源的电脑系统和网络监视工具,能有效监控Windows.Linux和Unix的主机状态,交换机路由器等网络设置,打印机等.在系统或服务状态异常时发出邮件或短信报警第一时间通知网站运维人员,在状态恢复后发出正常的邮件或短信通知. 主要功能 (1)网络服务监控(SMTP.POP3.HTTP.NNTP.ICMP.SNMP.FTP.SSH) (2)主机资源监控(CPU load.diskusage.system logs),也包括Windows主机(使用NSC

ISA2006安装和部署基础(虚拟机非域环境)

0x00. 为了测试基于HTTP隧道的绕过ISA,必须搭建模拟环境,为了不麻烦,我们这里不配合域环境认证.本次实验利用Vmware 10.0搭建环境,实现ISA2006安装和部署,同时设定基于HTTP代理访问的问题.  本人在ISA的应用上也算是新手,查找了不少资料,有不对的还望批评指正. 搭建环境说明: Vmware Workstation 10.0 Window 2003 ( ISA_SERVER) Window 2003 (客户机) 0x01.各台机器配置: [Win2003-ISA200

Nagios监控基础安装与监控项部署(下)

上文总结了nagios监控的基础安装配置,现在来总结一下Nagios监控项部署 一.Nagios服务端监控部署 1.Nagios服务端目录与相关配置文件说明 Nagios 安装完成后,/usr/local/nagios/目录下会生成 nagios 相关目录及配置文件,默认的的配置文件在/usr/local/nagios/etc 目录下.详细的描述如下: a)nagios安装后的目录结构 [[email protected] ~]# ll /usr/local/nagios/