mongodb的安装、单主机配置、主从配置、replicaSet副本集配置
2016-07-26 15:24
375 查看
一.Mongodb的安装
环境:centos6.7
版本:mongodb-linux-i686-2.6.7.gz
位置:/usr/local/mongodb
安装步骤:
mkdir /usr/local/mongo
tar -zxvf mongodb-linux-i686-2.6.7.gz -C /usr/local/mongo
安装是很简单的,关键是下面的启动的配置。启动配置有三种情况,分别是正常的单主机启动,主从启动,副本集启动三种方式。
1. 单主机启动方式
启动
cd /usr/local/mongodb/bin
./mongod –f mongodb.conf
#mongodb.conf是自定义的启动配置文件,其中参数auth表明需要认证才能登录,内容如下:
#start as daemon and need authentication
port=27017
fork=true
dbpath=/usr/local/mongodb/data/
logpath=/usr/local/mongodb/logs
auth=true
设置开机自动启动(可选)
echo "/usr/local/mongodb/bin/mongod -f /usr/local/mongodb/bin/mongodb.conf" >> /etc/rc.local
设置密码
#连接mongodb
cd /usr/local/mongodb/bin
./mongo
#默认进入到mongodb默认的test库
#为数据库设置用户名密码
#首先切换到admin库,先建立一个管理员账号
> use admin
> db.addUser("root","root");
#切换到test库
use test
#为test库添加用户名和密码
> db.addUser("testuser","123456");
说明设置密码已生效,此时要先转到admin库,输入认证再转回到test库设置用户名密码,如下:
use admin
db.auth(“root”,”root”);
use test
#下次再连接mongodb时需要使用如下方式:
./mongo –u testUser –p 123456
#删除用户
db.system.users.remove({“user”:”testUser”});
#注:mongodb的用户名和密码都是针对每一个库的,所以不同的库可以设置不同的用户名和密码。
2. 主从方式启动
实际上现在这种方式已经不推荐使用了,推荐使用的是replicaset副本集,下面会讲到
假设已经将mongodb安装在了两台主机上ip分别为192.168.0.1和192.168.0.2上,下面是启动配置
启动master(192.168.0.1)
cd /usr/local/mongodb/bin/
./mongod --dbpath=/usr/local/mongodb/data --logpath=/usr/local/mongodb/logs
--master --logappend --port=27017 -fork
启动slave(192.168.0.2)
cd /usr/local/mongodb/bin/
./mongod --dbpath=/usr/local/mongodb/data --logpath=/usr/local/mongodb/logs
--slave --source 192.168.0.1 --slave
--logappend --port=27017 -fork
这样配置就完成了,当然也可以将这些启动参数像前面一样写在配置文件中,启动时使用配置文件启动。
3. replcaSet的配置
我们假设有三台服务器,分别已经安装好了mongodb,有如下三段配置
#192.168.0.1上的配置
logpath=/usr/local/mongodb/logs
dbpath=/usr/local/mongodb/data/
port=27017
fork=true
logappend=true
replSet=rs1/192.168.0.2:27017
#192.168.0.2上的配置
logpath=/usr/local/mongodb/logs
dbpath=/usr/local/mongodb/data/
port=27017
fork=true
logappend=true
replSet=rs1/192.168.0.1:27017
#192.168.0.3上的配置
logpath=/usr/local/mongodb/logs
dbpath=/usr/local/mongodb/data/
port=27017
fork=true
logappend=true
replSet=rs1/192.168.0.1:27017,192.168.0.2:27017
分别将上面三段配置复制后放到每台mongodb的某个位置(推荐bin目录),三台服务器分别使用上面的配置启动后,要进行初始化
首先连接上192.168.0.1这台mongo
./mongo -port 27017
这样就连接上了mongodb的默认库test,然后输入如下指令:
> config_rs1={_id:'rs1',members:[
...{_id:0,host:'192.168.0.1:27017',priority:3},
...{_id:1,host:'192.168.0.2:27017',priority:2},
...{_id:2,host:'192.168.0.3:27017',priority:1}]
...}
> rs.initiate(config_rs1);
回车后出现下面的提示:
{
“info”:"Config now saved locallly. should come online in about a minute.",
" ok":1
}
说明初始化成功,注意只需要在其中任何一台上初始化就可以
运行如下指令查看是否成功
rs.status()
然后退出再重新连接,发现光标变成下面这种就对了:
rs1:PRIMARY
配置完成后可以进行秘密和用户名的设置,设置方式前面已经提到,需要注意的是,
每台mongodb都需要用同样的方式设置用户名和密码。
环境:centos6.7
版本:mongodb-linux-i686-2.6.7.gz
位置:/usr/local/mongodb
安装步骤:
mkdir /usr/local/mongo
tar -zxvf mongodb-linux-i686-2.6.7.gz -C /usr/local/mongo
安装是很简单的,关键是下面的启动的配置。启动配置有三种情况,分别是正常的单主机启动,主从启动,副本集启动三种方式。
1. 单主机启动方式
启动
cd /usr/local/mongodb/bin
./mongod –f mongodb.conf
#mongodb.conf是自定义的启动配置文件,其中参数auth表明需要认证才能登录,内容如下:
#start as daemon and need authentication
port=27017
fork=true
dbpath=/usr/local/mongodb/data/
logpath=/usr/local/mongodb/logs
auth=true
设置开机自动启动(可选)
echo "/usr/local/mongodb/bin/mongod -f /usr/local/mongodb/bin/mongodb.conf" >> /etc/rc.local
设置密码
#连接mongodb
cd /usr/local/mongodb/bin
./mongo
#默认进入到mongodb默认的test库
#为数据库设置用户名密码
#首先切换到admin库,先建立一个管理员账号
> use admin
> db.addUser("root","root");
#切换到test库
use test
#为test库添加用户名和密码
> db.addUser("testuser","123456");
说明设置密码已生效,此时要先转到admin库,输入认证再转回到test库设置用户名密码,如下:
use admin
db.auth(“root”,”root”);
use test
#下次再连接mongodb时需要使用如下方式:
./mongo –u testUser –p 123456
#删除用户
db.system.users.remove({“user”:”testUser”});
#注:mongodb的用户名和密码都是针对每一个库的,所以不同的库可以设置不同的用户名和密码。
2. 主从方式启动
实际上现在这种方式已经不推荐使用了,推荐使用的是replicaset副本集,下面会讲到
假设已经将mongodb安装在了两台主机上ip分别为192.168.0.1和192.168.0.2上,下面是启动配置
启动master(192.168.0.1)
cd /usr/local/mongodb/bin/
./mongod --dbpath=/usr/local/mongodb/data --logpath=/usr/local/mongodb/logs
--master --logappend --port=27017 -fork
启动slave(192.168.0.2)
cd /usr/local/mongodb/bin/
./mongod --dbpath=/usr/local/mongodb/data --logpath=/usr/local/mongodb/logs
--slave --source 192.168.0.1 --slave
--logappend --port=27017 -fork
这样配置就完成了,当然也可以将这些启动参数像前面一样写在配置文件中,启动时使用配置文件启动。
3. replcaSet的配置
我们假设有三台服务器,分别已经安装好了mongodb,有如下三段配置
#192.168.0.1上的配置
logpath=/usr/local/mongodb/logs
dbpath=/usr/local/mongodb/data/
port=27017
fork=true
logappend=true
replSet=rs1/192.168.0.2:27017
#192.168.0.2上的配置
logpath=/usr/local/mongodb/logs
dbpath=/usr/local/mongodb/data/
port=27017
fork=true
logappend=true
replSet=rs1/192.168.0.1:27017
#192.168.0.3上的配置
logpath=/usr/local/mongodb/logs
dbpath=/usr/local/mongodb/data/
port=27017
fork=true
logappend=true
replSet=rs1/192.168.0.1:27017,192.168.0.2:27017
分别将上面三段配置复制后放到每台mongodb的某个位置(推荐bin目录),三台服务器分别使用上面的配置启动后,要进行初始化
首先连接上192.168.0.1这台mongo
./mongo -port 27017
这样就连接上了mongodb的默认库test,然后输入如下指令:
> config_rs1={_id:'rs1',members:[
...{_id:0,host:'192.168.0.1:27017',priority:3},
...{_id:1,host:'192.168.0.2:27017',priority:2},
...{_id:2,host:'192.168.0.3:27017',priority:1}]
...}
> rs.initiate(config_rs1);
回车后出现下面的提示:
{
“info”:"Config now saved locallly. should come online in about a minute.",
" ok":1
}
说明初始化成功,注意只需要在其中任何一台上初始化就可以
运行如下指令查看是否成功
rs.status()
然后退出再重新连接,发现光标变成下面这种就对了:
rs1:PRIMARY
配置完成后可以进行秘密和用户名的设置,设置方式前面已经提到,需要注意的是,
每台mongodb都需要用同样的方式设置用户名和密码。
相关文章推荐
- java mongodb aggregate用法
- mongoDB 各类索引相关命令总结
- mongodb--linux下的安装
- mongodb之副本集的实现及故障自动转移
- python与mongodb的连接
- MongoDB备份与恢复
- mongodb副本集
- MongoDB学习笔记(3)主从复制和副本集
- MongoDB 游标和索引
- win10 编译mongodb 笔记
- 利用Mongodb做地理空间查询
- mongodb的介绍以及安装
- MongoDB备份与恢复
- MongoDB Replica set + sharding
- 使用python语言操作MongoDB
- 1、mongodb的安装及简单应用
- MongoDB学习笔记(0)windows的安装与配置
- Windows安装Mongodb
- MongoDB安装图文教程
- MongoDB 增删改查