文章目录
1.下载Mongodb
下载地址:https://www.mongodb.com/download-center/community
图中的 IBM Z Series 是大型机
2 开始安装
2.1 解压文件夹
我将压缩包上传到home目录下。解压压缩包到/usr/local目录
tar -zxvf mongodb-linux-x86_64-rhel70-4.2.3.tgz -C /usr/local
查看该文件夹下的执行结果
[root@CentOS7-01 local]# pwd
/usr/local
[root@CentOS7-01 local]# ll
总用量 0
drwxr-xr-x. 2 root root 6 4月 11 2018 bin
drwxr-xr-x. 2 root root 6 4月 11 2018 etc
drwxr-xr-x. 2 root root 6 4月 11 2018 games
drwxr-xr-x. 2 root root 6 4月 11 2018 include
drwxr-xr-x. 2 root root 6 4月 11 2018 lib
drwxr-xr-x. 2 root root 6 4月 11 2018 lib64
drwxr-xr-x. 2 root root 6 4月 11 2018 libexec
drwxr-xr-x. 3 root root 135 2月 18 00:35 mongodb-linux-x86_64-rhel70-4.2.3
drwxr-xr-x. 2 root root 6 4月 11 2018 sbin
drwxr-xr-x. 5 root root 49 2月 16 07:44 share
drwxr-xr-x. 2 root root 6 4月 11 2018 src
重新命名
mv mongodb-linux-x86_64-rhel70-4.2.3 mongodb-4.2.3
执行结果
[root@CentOS7-01 local]# mv mongodb-linux-x86_64-rhel70-4.2.3 mongodb-4.2.3
[root@CentOS7-01 local]# ll
总用量 0
drwxr-xr-x. 2 root root 6 4月 11 2018 bin
drwxr-xr-x. 2 root root 6 4月 11 2018 etc
drwxr-xr-x. 2 root root 6 4月 11 2018 games
drwxr-xr-x. 2 root root 6 4月 11 2018 include
drwxr-xr-x. 2 root root 6 4月 11 2018 lib
drwxr-xr-x. 2 root root 6 4月 11 2018 lib64
drwxr-xr-x. 2 root root 6 4月 11 2018 libexec
drwxr-xr-x. 3 root root 135 2月 18 00:35 mongodb-4.2.3
drwxr-xr-x. 2 root root 6 4月 11 2018 sbin
drwxr-xr-x. 5 root root 49 2月 16 07:44 share
drwxr-xr-x. 2 root root 6 4月 11 2018 src
2.2 配置环境变量和初始化操作
2.2.1配置环境变量
vi /etc/profile
按下字母 I 键,开始编辑,
在 export PATH USER LOGNAME MAIL HOSTNAME HISTSIZE HISTCONTROL 一行的上面添加如下内容:
export PATH=/usr/local/mongodb-4.2.3/bin:$PATH
按ESC退出编辑,并输入 :wq 保存退出
2.2.2 使环境变量生效命令
source /etc/profile
2.2.3 回到mongodb-4.2.3目录下创建数据库目录
回到下面目录
cd /usr/local/mongodb-4.2.3
在该目录下新建配置文件
touch mongodb.conf
执行结果如下
[root@CentOS7-01 mongodb-4.2.3]# touch mongodb.conf
[root@CentOS7-01 mongodb-4.2.3]# ll
总用量 312
drwxr-xr-x. 2 root root 231 2月 18 00:35 bin
-rw-r--r--. 1 root root 30608 1月 24 13:19 LICENSE-Community.txt
-rw-r--r--. 1 root root 0 2月 18 00:40 mongodb.conf
-rw-r--r--. 1 root root 16726 1月 24 13:19 MPL-2
-rw-r--r--. 1 root root 2617 1月 24 13:19 README
-rw-r--r--. 1 root root 75405 1月 24 13:19 THIRD-PARTY-NOTICES
-rw-r--r--. 1 root root 183512 1月 24 13:21 THIRD-PARTY-NOTICES.gotools
创建数据文件目录和日志目录
mkdir db
mkdir log
设置文件夹权限,赋可写权限,方便操作
chmod 777 db
chmod 777 log
创建日志文件
cd log
touch mongodb.log
2.3 修改配置文件内容
2.3.1 在mongodb.conf 中添加以下内容,
vi mongodb.conf
写入如下配置内容(不能有中文)
#端口
port=27017
#数据库存文件存放目录
dbpath= /usr/local/mongodb/mongodb-4.2.3/db
#日志文件存放路径
logpath= /usr/local/mongodb/mongodb-4.2.3/log/mongodb.log
#使用追加的方式写日志
logappend=true
#以守护进程的方式运行,创建服务器进程
fork=true
#最大同时连接数
maxConns=100
#不启用验证
noauth=true
#每次写入会记录一条操作日志(通过journal可以重新构造出写入的数据)
journal=true
#即使宕机,启动时wiredtiger会先将数据恢复到最近一次的checkpoint点,然后重放后续的journal日志来恢复。
#存储引擎,有mmapv1、wiretiger、mongorocks
storageEngine=wiredTiger
#设置成全部ip可以访问,这样就可以在windows中去连虚拟机的MongoDB,也可以设置成某个网段或者某个ip
bind_ip = 0.0.0.0
查看编辑后的文件如下(不能有中文)
2.3.2 启动mongodb
mongod --config /usr/local/mongodb-4.2.3/mongodb.conf
执行结果如下,表明启动成功
我们也可以通过访问url来确认是否启动正常
curl localhost:27017
2.4 关闭防火墙
CentOS 7.0默认使用的是firewall作为防火墙,如果不关闭的话,访问不到mongodb,如果不想关闭也可以开放某个端口。
第一种:
直接关闭firewall:
systemctl stop firewalld.service #停止firewall
systemctl disable firewalld.service #禁止firewall开机启动
第二种:
直接编辑/etc/sysconfig/iptables文件
在原有的22的端口上一行加入内容并保存
-A INPUT -p tcp -m state --state NEW -m tcp --dport 27017-j ACCEPT
重启服务:
service iptables restart
查看端口是否开放:
more /etc/sysconfig/iptables
到这里我们的安装结束,现在我们打开工具去测试连接是否成功~~
2.5 设置账号密码
mongodb默认是没有账号密码的,这样是很不安全的,我们现在通过mongodb自带的客户端来使用命令行进行账号密码的添加
2.5.1 启动mongodb客户端
#切换目录
cd /usr/local/mongodb-4.2.3/bin
#启动客户端
./mongo
先去掉下面的监控提示
> db.disableFreeMonitoring()
> exit;
如下图
再次进入客户端
#切换目录
cd /usr/local/mongodb-4.2.3/bin
#启动客户端
./mongo
如下图所示
2.5.2 使用admin库设置账号和密码
输入如下mongodb命令设置用户名和密码
# 使用admin库
use admin
#设置账号密码(userAdminAnyDatabase为管理用户的用户)
db.createUser( {user: "beyondli",pwd: "123456",roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]});
结果如下
2.5.3 关闭mongodb服务端修改配置文件
mongodb服务端,注意这里不要使用kill来杀掉mongodb服务端
# 关闭mongodb服务端
db.shutdownServer()
接下来。我们修改一下mongodb的配置文件,新增一行配置来使用权限方式启动MongoDB,添加内容为auth=true
2.5.4 启动mongodb服务,进入客户端验证账号和密码
好了,现在就大功告成了,我们只要在启动mongodb即可,记得启动的时候指定配置文件,命令如下
[root@zzy mongodb-4.2.3]# mongod --config /usr/local/mongodb-4.2.3/mongodb.conf
再次进入客户端
此时我们如果直接查看admin的用户是会报错的,如下图所示
现在我们通过命令来进行登录,返回1即表示登陆成功,如下图所示
db.auth("yourusername","你的密码")
3 客户端可视化工具
推荐使用工具: Studio3T
测试连接图片