Mongo分片集群脚本
bash大法好啊,一键玩mongo。
我的mongo版本是:MongoDB shell version v4.0.2
这里准备为大家献上Mongo创建分片和可复制集的脚本,以及在部署的时候踩的坑。
分完片插入的文档没有包含分片的键:
兄弟们,权限自动化的脚本来了~
安装好了mongo之后,执行脚本就可以玩了,呵呵
mon-config-cluster-start.sh
#!/bin/bash # 杀死与mongo有关的所有进程, 先把进程都清一遍
pid=$(ps -ef | grep 'mongo' | grep -v grep | awk '{print $2}')
for temp in $pid
do
echo "this is $temp"
if ps -p $temp > /dev/null
then
echo "$temp is running"
kill - $temp
fi
done # 创建分片实验的数据文件, 如果已经存在data的话就先删除
if [ ! -d "/root/data" ]; then
mkdir /root/data
else
echo "文件夹已经存在, 先清空/root/data"
rm -rf /root/data/*
fi # 创建shard-a的数据目录
echo "创建shard-a的数据目录"
mkdir /root/data/rs-a-1
mkdir /root/data/rs-a-2
mkdir /root/data/rs-a-3 # 启动第一个可复制集
mongod --shardsvr --replSet shard-a --dbpath /root/data/rs-a-1 --port 30000 --logpath /root/data/rs-a-1.log --fork
mongod --shardsvr --replSet shard-a --dbpath /root/data/rs-a-2 --port 30001 --logpath /root/data/rs-a-2.log --fork
mongod --shardsvr --replSet shard-a --dbpath /root/data/rs-a-3 --port 30002 --logpath /root/data/rs-a-3.log --fork mongo localhost:30000/test initial-shard-a.js # 创建shard-b的数据目录
echo "创建shard-b的数据目录"
mkdir /root/data/rs-b-1
mkdir /root/data/rs-b-2
mkdir /root/data/rs-b-3 # 启动第二个可复制集
mongod --shardsvr --replSet shard-b --dbpath /root/data/rs-b-1 --port 30100 --logpath /root/data/rs-b-1.log --fork
mongod --shardsvr --replSet shard-b --dbpath /root/data/rs-b-2 --port 30101 --logpath /root/data/rs-b-2.log --fork
mongod --shardsvr --replSet shard-b --dbpath /root/data/rs-b-3 --port 30102 --logpath /root/data/rs-b-3.log --fork mongo localhost:30100/test initial-shard-b.js # 创建配置文件的目录
mkdir /root/data/config-1
mkdir /root/data/config-2
mkdir /root/data/config-3 echo "准备启动配置服务进程"
# 启动配置服务器进程
# Failed global initialization: BadValue: nojournal is not allowed when configsvr is specified
# 这里没有指定配置项 --nojournal
mongod --configsvr --replSet conf --dbpath /root/data/config-1 --port 27019 --logpath /root/data/config-1.log --fork
mongod --configsvr --replSet conf --dbpath /root/data/config-2 --port 27020 --logpath /root/data/config-2.log --fork
mongod --configsvr --replSet conf --dbpath /root/data/config-3 --port 27021 --logpath /root/data/config-3.log --fork mongo localhost:27019/test initial-conf.js # 启动mongos进程
# 注意前面要有conf这个配置集群可复制集的名字
echo "准备启动路由进程......"
mongos --configdb conf/localhost:27019,localhost:27020,localhost:27021 --logpath /root/data/mongos.log --port 40000 --fork # 添加分片, 以及对哪个库和集合进行分片
mongo localhost:40000/test add-shard.js # 执行插入数据, 然后你就可以去shard-a和shard-b上去看数据了, 确实被分片了
mongo localhost:40000/test add-doc.js
initial-shard-a.js
// 使用这种单条的方式不行, 似乎只有第一条语句有效果, 后面的rs.add就没用了
// rs.initiate();
// print("执行了initiate()");
// rs.add("127.0.0.1:30001");
// print("added secondary...");
// rs.addArb("127.0.0.1:30002"); config={
_id:"shard-a",
members:[
{_id:0,host:"localhost:30000"},
{_id:1,host:"localhost:30001"},
{_id:2,host:"localhost:30002",arbiterOnly:true}
]
};
rs.initiate(config);
initial-shard-b.js
// rs.initiate();
// rs.add("localhost:30101");
// rs.addArb("localhost:30102"); config={
_id:"shard-b",
members:[
{_id:0,host:"localhost:30100"},
{_id:1,host:"localhost:30101"},
{_id:2,host:"localhost:30102",arbiterOnly:true}
]
};
rs.initiate(config);
initial-conf.js
// 日了狗了, 配置服务器不能使用arbiter
config={
_id:"conf",
members:[
{_id:0,host:"localhost:27019"},
{_id:1,host:"localhost:27020"},
{_id:2,host:"localhost:27021"}
]
};
rs.initiate(config); print("初始化配置可复制集...");
add-shard.js
print("准备添加分片......");
printjson(sh.addShard('shard-a/localhost:30000,localhost:30001'));
printjson(sh.addShard('shard-b/localhost:30100,localhost:30101'));
print("开启test可分片")
printjson(sh.enableSharding("test"));
printjson(sh.shardCollection('test.user',{name: 1}));
printjson(sh.status());
print("添加分片完毕");
add-doc.js
print("start...."); t = "I love China, I love palying DOTA, 妈蛋国庆节怎么说...."
for(i=0; i<10; i++) {
t = t + t;
} print("heheda");
for(a=0; a<1000; a++) {
print("a = " + a);
db.user.insert({name:Math.random().toString(36).substr(2), filename: "sheet-1", updated_at: new Date(),data: t});
}
Mongo分片集群脚本的更多相关文章
- Mongo--04 Mongo分片集群
目录 一.分片的概念 二. 分片工作原理 三.IP端口目录规划 1.IP端口规划 2.目录规划 四.分片集群搭建副本集步骤 1.安装软件 2.创建目录 3.创建配置文件 4.优化警告 5.启动服务 6 ...
- 从零搭建mongo分片集群的简洁方法
一.目录 1.mongo路径,config数据路径,shard数据路径
- mongo分片集群部署
测试环境192.168.56.101-213 前期准备: openssl rand -base64 756 > /home/software/mongodb/mongodbkey chmod ...
- mongo 分片集群的搭建
MongoDB版本当前使用的MongoDB版本为4.2.0,下载地址.https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2. ...
- Mongo 整体架构介绍(1)-------分片集群
摘要 在mongo初识文中介绍了mongo与cassandra的主要区别,以及mongo物理部署架构图.本文接着上一篇的mongo 架构图,来继续讲分片集群. 分片介绍 shard key mongo ...
- mongo 3.4分片集群系列之八:分片管理
这个系列大致想跟大家分享以下篇章: 1.mongo 3.4分片集群系列之一:浅谈分片集群 2.mongo 3.4分片集群系列之二:搭建分片集群--哈希分片 3.mongo 3.4分片集群系列之三:搭建 ...
- mongo 3.4分片集群系列之七:配置数据库管理
这个系列大致想跟大家分享以下篇章: 1.mongo 3.4分片集群系列之一:浅谈分片集群 2.mongo 3.4分片集群系列之二:搭建分片集群--哈希分片 3.mongo 3.4分片集群系列之三:搭建 ...
- mongo 3.4分片集群系列之六:详解配置数据库
这个系列大致想跟大家分享以下篇章: 1.mongo 3.4分片集群系列之一:浅谈分片集群 2.mongo 3.4分片集群系列之二:搭建分片集群--哈希分片 3.mongo 3.4分片集群系列之三:搭建 ...
- mongo 3.4分片集群系列之五:详解平衡器
这个系列大致想跟大家分享以下篇章: 1.mongo 3.4分片集群系列之一:浅谈分片集群 2.mongo 3.4分片集群系列之二:搭建分片集群--哈希分片 3.mongo 3.4分片集群系列之三:搭建 ...
随机推荐
- Alan Cox:单向链表中prev指针的妙用
之前发过一篇二级指针操作单向链表的例子,显示了C语言指针的灵活性,这次再探讨一个指针操作链表的例子,而且是一种完全不同的用法. 这个例子是linux-1.2.13网络协议栈里的,关于链表遍历& ...
- 【转】TeXmacs:一个真正“所见即所得”的排版系统
TeXmacs:一个真正“所见即所得”的排版系统 好久没有推荐过自己喜欢的软件了,现在推荐一款我在美国做数学作业的私家法宝:TeXmacs.我恐怕不可能跟以前那么有闲心写个长篇的 TeXmacs 说明 ...
- 乙醇的webdriver实用指南java版本
启动浏览器 关闭浏览器 浏览器最大化 设置浏览器大小 访问链接 打印当前页面的title及url 前进和后退 简单的对象定位 定位一组对象 层级定位 操作测试对象 send keys模拟按键输入 处理 ...
- java字符串拼接的几种方式
1. plus方式 当左右两个量其中有一个为String类型时,用plus方式可将两个量转成字符串并拼接. String a="";int b=0xb;String c=a+b;2 ...
- maven pom文件简单模板和配置详解
https://blog.csdn.net/earbao/article/details/49924943 maven pom文件简单模板和配置详解
- activiti Task
UserTask ScriptTask ServiceTask MailTask ManualTask ReceiveTask BusinessRuleTask callActivity
- Lua中and、or的一些特殊使用方法
Lua中的逻辑运算符:与(and).或(or)和非(not),与其它语言的逻辑运算符功能一致,这里不做赘述.仅仅说一点,全部的逻辑运算符将false和nil视为假,其它不论什么东西视为真.0也视为真. ...
- IOS 学习 Key-value coding
1 前言 本节我们主要介绍键值编码,以及如何使一个类符合KVC编码. 2 详述 键-值编码是一个对于间接访问一个对象属性和关系使用字符标识的机制.它支持或者关系几个特别的Cocoa编程机制和技术,在C ...
- TCP/IP 三次握手,温故知新
今天看网络编程.又又一次看了一遍三次握手.曾经只知道连接有三次握手.今天发现原来断开也有三次握手. 三次握手:指通信两方彼此交换三次信息. 三次握手是在存在数据报丢失.反复和延迟的情况下,确保通信两方 ...
- Nginx配置优化参考
Nginx配置优化参考 ...