本篇来介绍MongoDB的安装。安装版本是3.4.18

如果安装老版本的mongodb,你会发现安装比较顺利,但是新版本的mongo安装稍微麻烦一点 ,主要是多了安全机制认证等步骤。

1、下载mongo

wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.4.18.tgz

2、开始解压,我的习惯就是解压到/usr/local的目录下并重命名

[root@:vg_adn_tidbCkhsTest /usr/local/src]#tar -zxf ./mongodb-linux-x86_64-3.4.18.tgz -C /usr/local
[root@:vg_adn_tidbCkhsTest /usr/local/src]#cd ..
[root@:vg_adn_tidbCkhsTest /usr/local]#ls
bin etc games include lib lib64 libexec mongodb-linux-x86_64-3.4.18 redis-4.0.2 sbin share src
[root@:vg_adn_tidbCkhsTest /usr/local]#mv ./mongodb-linux-x86_64-3.4.18/ ./mongodb

3、开始建立data目录和log目录。

[root@:vg_adn_tidbCkhsTest /usr/local/mongodb]#mkdir ./data ./log
[root@:vg_adn_tidbCkhsTest /usr/local/mongodb]#ls
bin data GNU-AGPL-3.0 log MPL-2 README THIRD-PARTY-NOTICES

注意:bin目录下的mongod是服务器指令,而mongo是客户端指令

4、新建配置文件,作用是在启动mongo服务器的时候直接指定一个配置文件即可,否则启动的时候指定参数比较麻烦

[root@:vg_adn_tidbCkhsTest /usr/local/mongodb]#vim mongod.conf
[root@:vg_adn_tidbCkhsTest /usr/local/mongodb]#ls
bin data GNU-AGPL-3.0 log mongod.conf MPL-2 README THIRD-PARTY-NOTICES

mongod.conf文件的内容如下:

[root@:vg_adn_tidbCkhsTest /usr/local/mongodb]#cat mongod.conf
dbpath=/usr/local/mongodb/data/
logpath=/usr/local/mongodb/log/log.txt

注意:这里的文件名字“log.txt”这里我们必须在配置文件中写好,但是log目录下的“log.txt”这个文件系统会自动创建,我们不必在log目录下新建“log.txt”

5、启动服务端,最好在后台启动。 -f参数表示指定配置文件。&表示后台启动

[root@:vg_adn_tidbCkhsTest /usr/local/mongodb]#./bin/mongod -f /usr/local/mongodb/mongod.conf &
[] 7851[root@:vg_adn_tidbCkhsTest /usr/local/mongodb]#ps aux | grep mongo
root 7851 0.4 0.1 942704 46340 pts/0 Sl 02:20 0:00 ./bin/mongod -f /usr/local/mongodb/mongod.conf
root 7875 0.0 0.0 112704 960 pts/0 S+ 02:21 0:00 grep --color=auto mongo

6、启动客户端,客户端连接服务端

[root@:vg_adn_tidbCkhsTest:23.22.172.65:172.31.22.29 /usr/local/mongodb]#bin/mongo
MongoDB shell version v3.4.18
connecting to: mongodb://127.0.0.1:27017
MongoDB server version: 3.4.18
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:
2018-11-13T02:20:54.413+0000 I CONTROL [initandlisten]
2018-11-13T02:20:54.413+0000 I CONTROL [initandlisten] ** WARNING: Access control is not enabled for the database.
2018-11-13T02:20:54.413+0000 I CONTROL [initandlisten] ** Read and write access to data and configuration is unrestricted.
2018-11-13T02:20:54.413+0000 I CONTROL [initandlisten] ** WARNING: You are running this process as the root user, which is not recommended.
2018-11-13T02:20:54.413+0000 I CONTROL [initandlisten]
2018-11-13T02:20:54.413+0000 I CONTROL [initandlisten]
2018-11-13T02:20:54.413+0000 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.
2018-11-13T02:20:54.413+0000 I CONTROL [initandlisten] ** We suggest setting it to 'never'
2018-11-13T02:20:54.413+0000 I CONTROL [initandlisten]
2018-11-13T02:20:54.413+0000 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
2018-11-13T02:20:54.413+0000 I CONTROL [initandlisten] ** We suggest setting it to 'never'
2018-11-13T02:20:54.413+0000 I CONTROL [initandlisten]
> show dbs;
admin 0.000GB
local 0.000GB

看上去是没有问题,测试一下mongo也是可以用的,只是报错了不少警告,虽然不影响使用,但是我们最好解决一下。我们一个个的来看。

7、警告:WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'  和 WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.

关于这一条警告的解决方法我们可以参考官方的解决方法: https://docs.mongodb.com/manual/tutorial/transparent-huge-pages/

如果官方的解决方法比较麻烦的话,我们还可以参考这位网友的方法:https://blog.csdn.net/u013075468/article/details/51471033

8、出现警告:WARNING: Access control is not enabled for the database

原因分析:新版本的MongDB增加了安全性设计,推荐用户创建使用数据库时进行验证。如果用户想建立简单连接,则会提示警示信息

解决方法:

创建管理员账号并设置密码:

> use admin
switched to db admin
> db.createUser(
... {
... user:"admin",
... pwd:"123456",
... roles:[{role:"userAdminAnyDatabase",db:"admin"}]
... }
... )
Successfully added user: {
"user" : "admin",
"roles" : [
{
"role" : "userAdminAnyDatabase",
"db" : "admin"
}
]
}

然后kill掉进程并重启服务器

[root@:vg_adn_tidbCkhsTest /usr/local/mongodb]#bin/mongod --auth --port=27017 -f mongod.conf &
[] 8205

我们加上“--auth”参数表示访问数据库需要认证

然后使用客户端连接:

[root@:vg_adn_tidbCkhsTest /usr/local/mongodb]#bin/mongo -u "admin" -p "123456" --authenticationDatabase "admin"
MongoDB shell version v3.4.18
connecting to: mongodb://127.0.0.1:27017
MongoDB server version: 3.4.18
> exit
bye

现在看来都没有警告了。

如果大家对这条警告“WARNING: You are running this process as the root user, which is not recommended.”还有疑问的话,可以参考这个文章:https://www.cnblogs.com/ljai/p/4923229.html

但是我对上面的第8条做好之后就没有这条警告了。其实意思就是需要auth认证,对于生产环境中的mongo来说安全机制是比较严格的,并不像我们联系的那样子直接一个mongo命令就可以连接服务器,要用不同的用户不同的权限来连接才可以。

MongoDB基础之 安装的更多相关文章

  1. MongoDB基础介绍安装与使用

    MongoDB已经日益成为流程和主流的数据库了,原因有两个:第一个就是技术优势,第二就是便利性,个人使用部署都很方便. MongoDB的优缺点,以及使用场景 优点: 面向文档存储(自由读高,不需要定义 ...

  2. windows下mongodb基础玩法系列一介绍与安装

    windows下mongodb基础玩法系列 windows下mongodb基础玩法系列一介绍与安装 windows下mongodb基础玩法系列二CURD操作(创建.更新.读取和删除) windows下 ...

  3. MongoDB基础教程(安装、操作、配置)

    MongoDB 下载安装 简易安装 # redhat, centOS sudo yum install -y mongodb # debian, ubuntu sudo apt install -y ...

  4. MongoDB基础篇1:安装和服务配置

    一.下载 请前往官网下载community版本MongoDB,我当前可见最新版本是3.6.4 https://www.mongodb.com/download-center#community 如需下 ...

  5. mongodb基础用法

    安装部分 mongodb配置方法 mongodb的安装目录 C:\MongoDB\Server\3.2\bin 创建以下目录 c:\mongo\log c:\mongo\db 创建mongodb的配置 ...

  6. MongoDB基础学习

    *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...

  7. windows下mongodb基础玩法系列二CURD附加一

    windows下mongodb基础玩法系列 windows下mongodb基础玩法系列一介绍与安装 windows下mongodb基础玩法系列二CURD操作(创建.更新.读取和删除) windows下 ...

  8. windows下mongodb基础玩法系列二CURD操作(创建、更新、读取和删除)

    windows下mongodb基础玩法系列 windows下mongodb基础玩法系列一介绍与安装 windows下mongodb基础玩法系列二CURD操作(创建.更新.读取和删除) windows下 ...

  9. 【MongoDB】MongoDB的下载 安装 配置及使用

    windows系统  教程 1.下载地址   (官方提供根据系统位数选择对应的bit.exe下载) 由于自己win32系统不支持该官方版本,在网上又找了个 mongodb-win32-i386版本 p ...

随机推荐

  1. GOROOT、GOPATH和project目录说明

    go env环境查看 用go env 可查看当前go环境变量. $ go env GOARCH="amd64" GOBIN="" GOEXE="&qu ...

  2. netty源码解解析(4.0)-4 线程模型-概览

    netty线程体系概览 netty的高并发能力很大程度上由它的线程模型决定的,netty定义了两种类型的线程: I/O线程: EventLoop, EventLoopGroup.一个EventLoop ...

  3. Lightning Chart 8.4版新功能

    LightningChat V8.4版在如下功能上做了改进 边距 缩放功能 Legend box 的自动定位 正投影 相机orientation与rotation系统 全新3D 坐标空间转换器 Poi ...

  4. RabbitMQ远程不能访问问题的解决

    刚刚安装的RabbitMQ-Server-3.3.5,并且也已经开启了Web管理功能,但是现在存在一个问题: 出于安全的考虑,guest这个默认的用户只能通过http://localhost:1567 ...

  5. 转 C#反编译后的一些错误改正

    Xenocode反编译及代码整理记录1.Xenocode中设置输出数字为十进制 2.输出后中文文本为\uXXXX,可采用编码工具转成中文 3.new ()改成null; 4.反编译后代码中嵌套数组ne ...

  6. TCP Socket Http关系

    理解Tomcat内部处理网络数据的机制同时需要了解相关的一些术语,这样我们在阅读源码的时候能更加清楚的理解Connector下使用到的Socket通信原理. TCP/IP: 数据在网络传输是基于TCP ...

  7. Java开发中常用的设计模式(一)---工厂模式

    一. 准备工作 1. 本文参考自  自己理解的工厂模式,希望对大家有所帮助 二. 开始 以汽车工厂为例,首先有个汽车类的接口 Car,里面有个开车的方法 drive(),然后有个宝马车的类 BMW 和 ...

  8. apache伪静态原理图

  9. HDU4289(KB11-I 最小割)

    Control Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  10. Django Rest framework 之 分页

    RESTful 规范 django rest framework 之 认证(一) django rest framework 之 权限(二) django rest framework 之 节流(三) ...