准备一台机器,系统版本为CentOS7。

部署redis

1、下载软件包

# wget http://download.redis.io/releases/redis-3.2.8.tar.gz

2、解压

# tar xvf redis-3.2.8.tar.gz -C /usr/local/
# cd /usr/local/
# ln -sv redis-3.2.8/ redis

3、编译

# yum groupinstall -y "Development Tools"
# cd redis
# make

4、为多实例redis配置启动环境

# mkdir -pv /home/redis-cluster/{9000,9001,9002}

# cp src/{redis-server,redis-sentinel} /home/redis-cluster/9000/
# cp src/{redis-server,redis-sentinel} /home/redis-cluster/9001/
# cp src/{redis-server,redis-sentinel} /home/redis-cluster/9002/ # cp redis.conf sentinel.conf /home/redis-cluster/9000/
# cp redis.conf sentinel.conf /home/redis-cluster/9001/
# cp redis.conf sentinel.conf /home/redis-cluster/9002/

5、修改配置文件

# vim /home/redis-cluster/9000/redis.conf
bind 172.60.0.170
protected-mode no
port 9000
daemonize yes
appendonly yes # \cp /home/redis-cluster/9000/redis.conf /home/redis-cluster/9001/redis.conf
# \cp /home/redis-cluster/9000/redis.conf /home/redis-cluster/9002/redis.conf # vim /home/redis-cluster/9001/redis.conf
port 9001
slaveof 172.60.0.170 9000 # vim /home/redis-cluster/9002/redis.conf
port 9002
slaveof 172.60.0.170 9000

6、启动三个redis实例

# cd /home/redis-cluster/9000/
# ./redis-server redis.conf # cd ../9001/
# ./redis-server redis.conf # cd ../9002/
# ./redis-server redis.conf # ps -ef | grep redis
root 23565 1 0 03:29 ? 00:00:03 ./redis-server 172.60.0.170:9000
root 23569 1 0 03:29 ? 00:00:02 ./redis-server 172.60.0.170:9001
root 23575 1 0 03:29 ? 00:00:02 ./redis-server 172.60.0.170:9002

7、验证,查看主从状态

# /usr/local/redis/src/redis-cli -h 172.60.0.170 -p 9000
172.60.0.170:9000> set name keith
OK
172.60.0.170:9000> get name
"keith"
172.60.0.170:9000> info replication
# Replication
role:master
connected_slaves:2
slave0:ip=172.60.0.170,port=9001,state=online,offset=99,lag=1
slave1:ip=172.60.0.170,port=9002,state=online,offset=99,lag=0
master_repl_offset:99
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:2
repl_backlog_histlen:98

部署sentinel

1、部署实例一

# cd /home/redis-cluster/9000
# vim sentinel.conf
protected-mode no
port 29000
daemonize yes
dir /home/redis-cluster/9000/logs
sentinel monitor mymaster 172.60.0.170 9000 2
# mkdir logs
# ./redis-sentinel sentinel.conf
# \cp sentinel.conf ../9001/
# \cp sentinel.conf ../9002/

2、部署实例二

# cd ../9001/
port 29001
dir "/home/redis-cluster/9001/logs"
# mkdir logs
# ./redis-sentinel sentinel.conf

3、部署实例三

# cd ../9002/
# vim sentinel.conf
port 29002
dir "/home/redis-cluster/9002/logs"
# mkdir logs
# ./redis-sentinel sentinel.conf
# ps -ef | grep redis
root 23565 1 0 03:29 ? 00:00:03 ./redis-server 172.60.0.170:9000
root 23569 1 0 03:29 ? 00:00:03 ./redis-server 172.60.0.170:9001
root 23575 1 0 03:29 ? 00:00:03 ./redis-server 172.60.0.170:9002
root 23923 1 0 03:43 ? 00:00:04 ./redis-sentinel *:29000 [sentinel]
root 23927 1 0 03:44 ? 00:00:04 ./redis-sentinel *:29001 [sentinel]
root 23965 1 0 03:44 ? 00:00:04 ./redis-sentinel *:29002 [sentinel]

4、验证

# /usr/local/redis/src/redis-cli -h 172.60.0.170 -p 29000
172.60.0.170:29000> sentinel masters
1) 1) "name"
2) "mymaster"
3) "ip"
4) "172.60.0.170"
5) "port"
6) "9000"
7) "runid"
8) "3236841c634359db724f73d4833b003683efa446"
9) "flags"
10) "master"
11) "link-pending-commands"
12) "0"
13) "link-refcount"
14) "1"
15) "last-ping-sent"
16) "0"
17) "last-ok-ping-reply"
18) "65"
19) "last-ping-reply"
20) "65"
21) "down-after-milliseconds"
22) "30000"
23) "info-refresh"
24) "4288"
25) "role-reported"
26) "master"
27) "role-reported-time"
28) "2885298"
29) "config-epoch"
30) "0"
31) "num-slaves"
32) "2"
33) "num-other-sentinels"
34) "2"
35) "quorum"
36) "2"
37) "failover-timeout"
38) "180000"
39) "parallel-syncs"
40) "1"
172.60.0.170:29000> sentinel slaves mymaster
1) 1) "name"
2) "172.60.0.170:9002"
3) "ip"
4) "172.60.0.170"
5) "port"
6) "9002"
7) "runid"
8) "0e741da8193158b565113ec84c6384284d11b0bd"
9) "flags"
10) "slave"
11) "link-pending-commands"
12) "0"
13) "link-refcount"
14) "1"
15) "last-ping-sent"
16) "0"
17) "last-ok-ping-reply"
18) "133"
19) "last-ping-reply"
20) "133"
21) "down-after-milliseconds"
22) "30000"
23) "info-refresh"
24) "4338"
25) "role-reported"
26) "slave"
27) "role-reported-time"
28) "2915465"
29) "master-link-down-time"
30) "0"
31) "master-link-status"
32) "ok"
33) "master-host"
34) "172.60.0.170"
35) "master-port"
36) "9000"
37) "slave-priority"
38) "100"
39) "slave-repl-offset"
40) "632552"
2) 1) "name"
2) "172.60.0.170:9001"
3) "ip"
4) "172.60.0.170"
5) "port"
6) "9001"
7) "runid"
8) "4a500eedd644d89c565773d5e42faf4c2872295e"
9) "flags"
10) "slave"
11) "link-pending-commands"
12) "0"
13) "link-refcount"
14) "1"
15) "last-ping-sent"
16) "0"
17) "last-ok-ping-reply"
18) "133"
19) "last-ping-reply"
20) "133"
21) "down-after-milliseconds"
22) "30000"
23) "info-refresh"
24) "4338"
25) "role-reported"
26) "slave"
27) "role-reported-time"
28) "2915465"
29) "master-link-down-time"
30) "0"
31) "master-link-status"
32) "ok"
33) "master-host"
34) "172.60.0.170"
35) "master-port"
36) "9000"
37) "slave-priority"
38) "100"
39) "slave-repl-offset"
40) "632552"

CentOS7单节点部署redis主从复制和sentinel的更多相关文章

  1. CentOS7单节点部署redis-cluster

    准备一台机器,系统版本为CentOS7.(注意本文描述的是redis-cluster,不是主从复制) 1.下载软件包 # wget http://download.redis.io/releases/ ...

  2. Ubuntu下用devstack单节点部署Openstack

    一.实验环境 本实验是在Vmware Workstation下创建的单台Ubuntu服务器版系统中,利用devstack部署的Openstack Pike版. 宿主机:win10 1803  8G内存 ...

  3. HyperLedger Fabric 1.4 单机单节点部署(10.2)

    单机单节点指在一台电脑上部署一个排序(Orderer)服务.一个组织(Org1),一个节点(Peer,属于Org1),然后运行官方案例中的example02智能合约例子,实现转财交易和查询功能.单机单 ...

  4. Centos7 单节点安装 FastDFS + FastDHT服务

    Centos7 单节点安装 FastDFS + FastDHT服务 1.安装gcc(编译时需要) FastDFS是C语言开发,安装FastDFS需要先将官网下载的源码进行编译,编译依赖gcc环境,如果 ...

  5. .netcore consul实现服务注册与发现-单节点部署

    原文:.netcore consul实现服务注册与发现-单节点部署 一.Consul的基础介绍     Consul是HashiCorp公司推出的开源工具,用于实现分布式系统的服务发现与配置.与其他分 ...

  6. Kubernetes 二进制部署(一)单节点部署(Master 与 Node 同一机器)

    0. 前言 最近受“新冠肺炎”疫情影响,在家等着,入职暂时延后,在家里办公和学习 尝试通过源码编译二进制的方式在单一节点(Master 与 Node 部署在同一个机器上)上部署一个 k8s 环境,整理 ...

  7. MongoDB 3.2复制集单节点部署(四)

    MongoDB在单节点中也可以做复制集,但是仅限于测试实验,最大的好处就是部署方便快速,可以随便添加新节点,节省资源.在这里我使用的是MongoDB 3.2版本进行复制集实验(但MongoDB配置文件 ...

  8. MongoDB 2.6复制集单节点部署(三)

    MongoDB在单节点中也可以做复制集,但是仅限于测试实验,最大的好处就是部署方便快速,可以随便添加新节点,节省资源.在这里我使用的是MongoDB 2.6版本进行复制集实验(但MongoDB配置文件 ...

  9. Ubuntu 16.04下使用docker部署Redis主从复制

    (以下docker相关的命令,需要在root用户环境下或通过sudo提升权限来进行操作.) 1.拉取Redis镜像到本地 docker pull redis 2. 准备Redis主从配置文件 Redi ...

随机推荐

  1. Harbor 学习分享系列2 - Harbor项目介绍

    云盘链接 链接:https://pan.baidu.com/s/19yZCZMijf1c3rTwYOqiZzw 密码:netv 通过本文无法把本文中的实验进行成功,请联系作者本人,作者会录制视频发送给 ...

  2. 关于Maven的一点理解

    maven是一个项目管理工具,主要作用是: 1.依赖管理(jar包,工程之间); 2.统一开发规范和工具.完成项目的一步构建 3.工程聚合.继承.依赖 其核心配置文件就是pom.xml:pom即Pro ...

  3. noip2018 D1T3 赛道修建

    题目描述 C 城将要举办一系列的赛车比赛.在比赛前,需要在城内修建 mm 条赛道. C 城一共有 nn 个路口,这些路口编号为 1,2,…,n1,2,…,n,有 n-1n−1 条适合于修建赛道的双向通 ...

  4. lscpi命令详解

    基础命令学习目录 lspci是一个用来查看系统中所有PCI总线以及连接到该总线上的设备的工具. 命令格式为 lspci -参数 (不加参数显示所有硬件设备) 至于有哪些参数及其详细用法可以看下这篇博客 ...

  5. scrapy有用的(代理,user-agent,随机延迟等)

    代理 方法一(待测试) 见scrapy.downloadermiddlewares.httpproxy.HttpProxyMiddleware import os # 设置相应的代理用户名密码,主机和 ...

  6. 【探路者】final贡献分配

     [探路者]组成员及各位博客地址. 1蔺依铭:http://www.cnblogs.com/linym762/ 2张恩聚:http://www.cnblogs.com/zej87/ 3米赫:http: ...

  7. 在js中保存数据

    localStorage: localStorage.setItem("key", "value"); localStorage.getItem("k ...

  8. bing词典vs有道词典对比测试报告——功能篇之细节与用户体验

    之所以将细节与用户体验放在一起讨论,是因为两者是那么的密不可分.所谓“细节决定成败”,在细节上让用户感受方便.舒适.不费心而且温馨,多一些人文理念,多一些情怀,做出来的产品自然比其他呆板的产品更受欢迎 ...

  9. 小组冲刺第十一天站立会议(发布Alpha版+网站链接)

    注: “助成”招聘网站链接:http://58.87.74.131:8080/zhucheng 欢迎大家进行评测. 一.任务看板: 二.燃尽图: 三.团队成员合照: 四.任务总结: 今天我们发布网站B ...

  10. Beta 冲刺 (4/7)

    队名:日不落战队 安琪(队长) 过去两天完成了那些任务 完善已完成的界面. 接下来的任务 建立和上传收藏夹. 还剩下的任务 完善手写涂鸦. 遇到的困难 明天考试,准备通宵中. 有哪些收获和疑问 无. ...