MongoDB集群搭建

MongoDB是一个非常优秀的非关系型数据库,其优秀的性能和类SQL兼容一直是非强事务性存储的好选择。



当数据量到一定量级且需要高可用的时候,我们需要MongoDB的集群,本文用3个实例做集群搭建演示

1. 基础环境准备

RH/Centos Linux服务器3台,在此假设3台服务器IP/hostname分别为:

  • 192.168.10.27 / master
  • 192.168.10.28 / cluster1
  • 192.168.10.29 / cluster2

MongoDB集群节点之间默认使用27017通信,也可自定义设置修改该端口
请确保集群节点之间和对外开放通信端口

2. 下载安装

分别在3台服务器上进行如下安装操作

  • 官网下载安装包或使用下面的命令下载(请选择对应的系统版本,此处使用Community版本演示,Enterprise搭建过程相同):

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

  • 解压安装包至/usr/local/mongodb-3.4.10目录,该目录及软件的安装目录(后面会讲到数据的存放目录请注意区分)

  • 完成后配置MongoDB的环境变量:

    export MONGO_HOME=/usr/local/mongodb-3.4.10
    export PATH=$MONGO_HOME/bin:PATH
    
  • 使用source命令使环境变量生效

3. 集群初始化及配置

MongoDB使用本地文件作为数据库存储,存储数据和Mongo自身使用的配置等全部存储在文件系统,我们需要指定这些文件所用的目录并使用配置声明

  • 配置实例

    分别在3台服务器执行如下操作:

    mkdir -p /usr/local/test_data/db/data
    mkdir -p /usr/local/test_data/db/log
    cd /usr/local/test_data
    vi replica.yml
    systemLog:
      destination: file
      path: "/usr/local/test_data/db/log/replica-set.log"
    processManagement:
      fork: true
    net:
      port: 27017
    storage:
      dbPath: "/usr/local/test_data/db/data/"
    replication:
      replSetName: "drive"
    sharding:
      clusterRole: shardsvr
    
  • 启动所有节点

    分别在3台服务器使用:

    mongod -f /usr/local/test_data/replica.yml启动Mongo实例

    此时使用ps应该可以在3台服务器上分别看到一个Mongo进程

  • 连接子节点

    注意下面的操作仅在主节点进行

    选3台服务器其中一台(此处使用 192.168.10.27/master)作为初始主节点进行操作

    在此节点上使用Mongo Shell,键入命令mongo

    在出现的Shell当中使用如下命令连接各节点

    rs.initiate()  //初始化集群主节点,使用默认初始配置,子节点随后添加
    rs.status()      //查看状态。此命令的输出中members元素应该只有此服务器的信息
    rs.add('192.168.10.28:27017')   //添加节点1,未报错且输出为1则说明添加成功
    rs.add('192.168.10.29:27017')   //添加节点2,未报错且输出为1则说明添加成功
    rs.status()    //查看状态。此时输出的members元素中应该有3个节点的信息
    
  • 设置子节点为可读状态分担主节点读取压力

    分别在子节点使用mongo命令打开Shell

    db.getMongo().setSlaveOk()    //开启子节点读取
    show dbs      //如果未出现错误提示则说明成功
    

4. 建立索引

我们定义演示使用的库名为trips,假定是用户跑步过程中的行程及坐标记录数据,使用的集合名称为coordinates

行程坐标数据中可以添加索引以提高查询速度,此处使用列为tripIDtimestamp。索引选列的依据和传统数据库类似,选定常作为过滤条件的列或列组合和提高效率

在主节点使用mongo呼出Shell

use trips    //切换到行程坐标库,初始化时没有该库并不影响
db.coordinates.getIndexes()      //此时应该能看到一个默认的"_id"索引列
db.coordinates.createIndex({"tripID":1})
db.coordinates.createIndex({"timestamp":1})
db.coordinates.getIndexes()      //此时应该能"_id","tripID","timestamp"3条索引记录

5. 验证&测试

任意节点使用下面命令应该都能看到未报错的输出结果且返回信息包含的节点信息正确

rs.status()
rs.conf()
show dbs
use trips
show collections
db.coordinates.getIndexes()

6. 配置MongoDB用户名密码

首先建立系统管理员账户,在主节点进行如下操作:

mongo
use admin
db.createUser({user:"root",pwd:"changeme",roles:[{role:"root",db:"admin"}]}) #数据库管理员

use trips
db.createUser({user:"trip_owner",pwd:"changeme",roles:[{role:"dbAdmin",db:"trips"},{role:"readWrite",db:"trips"}]}) #行程坐标库的使用者

show users   #检查是否添加成功

完成之后关闭所有节点的Mongo实例并重新启动,在启动命令后添加--auth声明开启用户身份认证

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,193评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,306评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,130评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,110评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,118评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,085评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,007评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,844评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,283评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,508评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,395评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,985评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,630评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,797评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,653评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,553评论 2 352

推荐阅读更多精彩内容