一.什么是mongodb

MongoDB是一个高性能,开源,无模式的文档型数据库,是当前NoSql数据库中比较热门的一种。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能

最丰富,最像关系数据库的。它在许多场景下可用于替代传统的关系型数据库或键/值存储方式。它是由C++语言编写的一个基于分布式文件存储的开源数据库系统,它的目的在于为WEB应

用提供可扩展的高性能数据存储解决方案。MongoDB是一个介于关系型数据库和非关系型数据库之间的产品,是非关系型数据库当中功能最丰富,最像关系型数据库的。它支持的数据结构

非常松散,会将数据存储为一个文档,数据结构由键值对(key=>value)组成,是类似于json的bson格式,字段值可以包含其它文档、数组和文档数组,因此可以存储比较复杂的数据类型。

适用场景:

网站实时数据处理。它非常适合实时的插入、更新与查询,并具备网站实时数据存储所需的复制及高度伸缩性;缓存,由于性能很高,它适合作为信息基础设施的缓存层。在系统重启之后,

由它搭建的持久化缓存层可以避免下层的数据源过载。高伸缩性的场景。非常适合由数十或数百台服务器组成的数据库,它的路线图中已经包含对MapReduce引擎的内置支持。

 不适用场景:

要求高度事务性的系统。传统的商业智能应用。复杂的跨文档(表)级联查询。

二.  mongodb安装

1. Ubuntu 二进制安装

2. Centos 二进制安装

3 . yum 安装

4.  mongodb 创建用户并开启登陆验证

5 . mongodb 常用命令

mongodb官网下载地址:https://www.mongodb.com/download-center/community

1. Ubuntu 二进制安装

我们可以创建mongodb的运行用户来运行,也可以使用root直接来运行

如果我们需要使用指定的用户来运行,那么需要更改/opt/momgodb的目录所有者为指定用户。

下载安装包:

cd  /tmp/  && wget  https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-ubuntu1404-4.0.3.tgz

解压并移动到/opt/下

tar -xvzf  mongodb-linux-x86_64-ubuntu1404-4.0..tgz && mv  mongodb-linux-x86_64-ubuntu1404-4.0.  /opt/mongodb

创建目录 data(用来存放数据的),log(存放日志的)

mkdir  /opt/mongodb/data
mkdir /opt/mongodb/log

创建mongodb配置文件 mongodb.conf

cd/opt/mongodb/ && vim mongodb.conf

配置文件内容

bind_ip=0.0.0.0
port=
dbpath=/opt/mongodb/data/
logpath=/opt/mongodb/log/mongodb.log
pidfilepath =/opt/mongodb/mongodb.pid
logappend=true
fork=true
maxConns=500
noauth = true

配置文件参数解释

 bind_ip=0.0.0.0  # 绑定的ip,0.0.0.0 表示本地所有ip
port= # 绑定的端口 默认端口是27017
dbpath=/opt/mongodb/data/ #数据存放目录
logpath=/opt/mongodb/log/mongodb.log #日志存放目录
pidfilepath =/opt/mongodb/mongodb.pid #pid文件存放位置
logappend=true #日志写入为追加模式
fork=true #是否以守护进程运行
maxConns= #最大连接数
9 noauth = true/auth=true #是否开启认证,初次不开启,设置完密码后开启。默认是不开启的

启动mongodb.

/opt/mongodb/bin/mongod -f /opt/mongodb/mongodb.conf

检查端口是否在监听

root@iZ23rx1wgk89:/opt/mongodb# lsof -i:
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
mongod root 10u IPv4 0t0 TCP *: (LISTEN)

防火墙开启27037端口

iptables -A INPUT  -p tcp  -dport 27037 -j  ACCEPT
service iptables save

2. Centos7 二进制安装

centos 7的安装基本和Ubuntu一致,只有少许的命令不同

下载安装包:

cd  /tmp/  && wget  https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.0.3.tgz

解压并移动到/opt/下

tar -xvzf  mongodb-linux-x86_64-rhel70*  && mv  mongodb-linux-x86_64-rhel70-4.0.3  /opt/mongodb

创建目录 data(用来存放数据的),log(存放日志的)

mkdir  /opt/mongodb/data
mkdir /opt/mongodb/log

创建mongodb配置文件 mongodb.conf

cd /opt/mongodb/ && vim mongodb.conf

配置文件内容

bind_ip=0.0.0.0
port=27037
dbpath=/opt/mongodb/data/
logpath=/opt/mongodb/log/mongodb.log
pidfilepath =/opt/mongodb/mongodb.pid
logappend=true
fork=true
maxConns=500
noauth = true

配置文件参数解释

 1 bind_ip=0.0.0.0  # 绑定的ip,0.0.0.0 表示本地所有ip
2 port=27037 # 绑定的端口 默认端口是27017
3 dbpath=/opt/mongodb/data/ #数据存放目录
4 logpath=/opt/mongodb/log/mongodb.log #日志存放目录
5 pidfilepath =/opt/mongodb/mongodb.pid #pid文件存放位置
6 logappend=true #日志写入为追加模式
7 fork=true #是否以守护进程运行
8 maxConns=500 #最大连接数
9 noauth = true/auth=true #是否开启认证,初次不开启,设置完密码后开启。默认是不开启的

启动mongodb.

/opt/mongodb/bin/mongod -f /opt/mongodb/mongodb.conf

检查端口是否在监听

root@iZ23rx1wgk89:/opt/mongodb# lsof -i:27037
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
mongod 14285 root 10u IPv4 30394148 0t0 TCP *:27037 (LISTEN)

防火墙开启27037端口

firewall-cmd --add-port=27037/tcp  --permanent
firewall-cmd --reload

3 . yum 安装

首先得配置yum 源,我这里配置的yum源是阿里云的源的mongodb 3.2的,可以根据自己的安装版本配置不同的yum源

4.0 源 :http://mirrors.aliyun.com/mongodb/yum/redhat/7Server/mongodb-org/4.0/x86_64/

vim /etc/yum.repos.d/mongodb.repo
[mongodb]
name=MongoDB Repository
baseurl=http://mirrors.aliyun.com/mongodb/yum/redhat/7Server/mongodb-org/3.2/x86_64/
gpgcheck=
enabled=

安装

yum -y install mongodb-org mongodb-org-server

启动并添加到开机自启

systemctl enable mongod
systemctl start mongod

防火墙开放27017端口

firewall-cmd --add-port=/tcp  --permanent
firewall-cmd --reload

默认绑定的ip是:127.0.0.1

默认绑定的端口是:27017

我们可以编辑配置文件/etc/mongod.conf,进行修改。

4 .mongodb 创建用户并开启登陆验证

在实际使用过程中,我需要为mongodb添加认证机制。这样才能保障我们数据的安全性。

如果我们是自己使用tar包安装的,那么我们可以将mongo命令添加到解释器路径里。yum安装默认会添加

ln -s /opt/mongodb/bin/mongo  /usr/bin/mongo 

如果我们更改了默认端口的话,那么我们需要使用 --port 参数指定端口

./mongo  --port  
 [root@djx2 bin]# ./mongo  --port 27037
MongoDB shell version v4.0.3
connecting to: mongodb://127.0.0.1:27037/
Implicit session: session { "id" : UUID("fc5045fe-8d56-4272-a362-f86e4a0d2a96") }
MongoDB server version: 4.0.
Welcome to the MongoDB shell.
For interactive help, type "help".
For more comprehensive documentation, see
http://docs.mongodb.org/
Questions? Try the support group
http://groups.google.com/group/mongodb-user
Server has startup warnings:
--06T18::18.381+ I CONTROL [initandlisten] ** WARNING: You are running this process as the root user, which is not recommended.
--06T18::18.381+ I CONTROL [initandlisten]
--06T18::18.381+ I CONTROL [initandlisten]
--06T18::18.381+ I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.
--06T18::18.381+ I CONTROL [initandlisten] ** We suggest setting it to 'never'
--06T18::18.381+ I CONTROL [initandlisten]
--06T18::18.381+ I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
--06T18::18.381+ I CONTROL [initandlisten] ** We suggest setting it to 'never'
--06T18::18.381+ I CONTROL [initandlisten]
---
Enable MongoDB's free cloud-based monitoring service, which will then receive and display
metrics about your deployment (disk utilization, CPU, operation statistics, etc). The monitoring data will be available on a MongoDB website with a unique URL accessible to you
and anyone you share the URL with. MongoDB may use this information to make product
improvements and to suggest MongoDB products and deployment options to you. To enable free monitoring, run the following command: db.enableFreeMonitoring()
To permanently disable this reminder, run the following command: db.disableFreeMonitoring()
--- > use admin;
switched to db admin
> db.createUser({ user: "admin", pwd: "9toc7ttpji8", roles: [{ role: "root", db: "admin" }] })
Successfully added user: {
"user" : "admin",
"roles" : [
{
"role" : "root",
"db" : "admin"
}
]
}
>

这样我们就添加好了管理员用户。

然后我们需要将我们 mongodb.conf中的noauth 参数注释,添加  auth = true

auth = true

并将mongodb重启,我们在进行查询的时候就需要验证用户了。

创建普通用户

切换到kevin库添加普通用户(readWrite有读写权限;read有读权限)
> use kevin;
switched to db kevin
> db.createUser({user: "kevin",pwd: "kevin@123456",roles:[{"role":"readWrite","db":"kevin"}]});
Successfully added user: {
"user" : "kevin",
"roles" : [
{
"role" : "readWrite",
"db" : "kevin"
}
]
}

5.  mongodb的常用命令

见文章  mongodb常用命令

mongodb二进制安装与yum安装的更多相关文章

  1. centos6/7安装 tinyproxy (yum安装)

    centos6/7安装tinyproxy(yum安装)2016年06月06日 运维 暂无评论 阅读 790 次centos7安装tinyproxy,centos6安装tinyproxy,centos6 ...

  2. Linux下yum安装MySQL yum安装MySQL指定版本

    yum安装MySQL 1. 查看有没有安装过     yum list installed MySQL* (有存在要卸载yum remove MySQL*)     rpm -qa | grep my ...

  3. MySQL安装之yum安装

    转载来源:https://www.cnblogs.com/brianzhu/p/8575243.html 1. 下载并安装MySQL官方的 Yum Repository 1 [root@BrianZh ...

  4. centos6 只安装mysql client(安装包安装和yum安装mysql)

    方法一下载安装: 1.在/home创建mysql目录,下载如下四个软件包 http://mirrors.sohu.com/mysql/MySQL-5.7/ wget http://mirrors.so ...

  5. yum 安装mysql, yum安装指定版本的mysql

    yum安装mysql: 1. 查看有没有安装过     yum list installed MySQL* (有存在要卸载yum remove MySQL*)     rpm -qa | grep m ...

  6. Linux系统下 Supervisor 安装搭建(yum安装)

    安装Supervisor # 安装supervisor yum install supervisor # 打开supervisor的配置文件 vi /etc/supervisord.conf 将sup ...

  7. [svc][op]pip安装ansible && yum安装python34

    相对yum安装,pip安装的好处是jinjia版本到了2.8 pip安装ansible Successfully installed MarkupSafe-1.0 PyYAML-3.12 ansibl ...

  8. ngxin安装之yum安装

    nginx部署至yum安装 1. 配置nginx所需的YUM源 [root@nginx]# cat /etc/yum.repos.d/yum.repo [nginx-stable] name=ngin ...

  9. rpm安装与yum安装的区别

      linux下的安装包多为rpm安装包.通常安装方法为 rpm -ivh 包的路径+包名.rpm 其中参数-i为安装 -v显示信息 -h显示进度条.这三个参数基本捆绑使用rpm的路径不单可以是本地磁 ...

随机推荐

  1. 用Execute操作数据库

    1.原型是:_ConnectionPtr Execute( _bstr_t CommandText, VARIANT * RecordsAffected, long Options ); 参数 1. ...

  2. queued frame 造成图形性能卡顿

    曾经遇到过卡顿是类似的原因:当时对显卡底层知识理解不懂,看到引擎底层有一个MaxFramexxx的接口,实现是使用注册表修改显卡底层的注册信息,当时还是一个掉接口习惯的客户端码农的思维,没理解底层含义 ...

  3. sklearn使用小记GridSearchCV

    def test_grid_search(): from sklearn import datasets,svm iris = datasets.load_iris() parameters = {' ...

  4. GitHub Android 开源项目汇总 (转)

    转自:http://blog.csdn.net/ithomer/article/details/8882236 GitHub 上的开源项目不胜枚举,越来越多的开源项目正在迁移到GitHub平台上.基于 ...

  5. C#DataGridView的简单使用

    首先创建一个DataGridView控件,然后创建列(包括列名的定义), 由于我不是和数据库进行连接,只是为了输出好看一点. 删除所有数据: while (this.dataGridView1.Row ...

  6. LayaAir从入门到放弃

    我是一个小白程序员,准备开发小程序找了很久小程序开发引擎,看到白鹭和LayaAir .经过一番资料查找后被LayaAir高性能.接口简洁及社区活跃所吸引,然后选择了LayaAir. 开发过程中一般小问 ...

  7. 构建NetCore应用框架之实战篇系列

    构建NetCore应用框架之实战篇 构建NetCore应用框架之实战篇(一):什么是框架,如何设计一个框架 构建NetCore应用框架之实战篇(二):BitAdminCore框架定位及架构 构建Net ...

  8. winform 批量控件取值赋值

    以前写winform 最多写几个文本框,最近需要入录一个人员信息,那好几十个字段,一下子干蒙了,这要是一个个取值赋值都写到明天了,于是就自己写了个方法,也不是什么高大上的,就是很简单很普通很low的方 ...

  9. [5.19 线下活动]Docker Meetup杭州站—拥抱Kubernetes,容器深度实践

    对本次线下活动感兴趣的朋友,欢迎点击此处报名,领取免费票. 今年3月,Docker刚刚过完5岁生日,五年期间,Docker也逐渐在技术和实践方面趋于成熟,更是在去年年底主动拥抱Kubernetes. ...

  10. Storm的Metric接口简介

    本文由作者林洋港授权网易云社区发布. 作为服务端程序,我们总是需要向外界报告一些统计数据,以助于了解系统的运行情况,比如某个接口的调用时间.系统处理的请求数等等.当我们的程序以Storm Topolo ...