MongoDB基础之 安装

本篇来介绍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 &
[1] 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 &
[1] 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命令就可以连接服务器,要用不同的用户不同的权限来连接才可以。

 

posted @ 2018-11-13 11:32  峰哥ge  阅读(263)  评论(0编辑  收藏  举报