redis主从与集群搭建
redis搭建主从
条件:yum安装(3.2.1)与编译安装(5.0.0)都可以
环境:我这里在同一台主机上搭建,当然也可以两台。
1) 复制redis.conf的主配置文件并命令为slave.conf
2)配置slave.conf
bind 192.168.253.153(主节点ip一致)
slaveof 192.168.253.153 6379 (主节点的ip与端口)
port 6389 (自定义)
3)重启服务
redis-server 文件名(如果不在目录下,就需要带上目录)
4)测试
进入主从节点的redis数据库中,在主节点上添加等操作,如果从节点能够读出来,说明配置成功。
redis-cli -p 6379 -h 192.168.253.10
redis-cli -p 6389 -h 192.168.253.10 #配置的端口和ip
redis集群
环境:两台主机(一台3个主节点,一台三个从节点) 或者一台主机(3台主节点,3台从节点)
条件:编译安装,yum安装的如果时3.2版本或者更早之前很可能会行不通,报错:
Unrecognized option or bad number of args for: '--cluster' #此错误原因为参数错误或者缺少redis cluster
我这里选择一台主机配置集群:
1)创建一个conf目录
mkdir conf
2)创建6个.conf结尾的文件
touch {7000,7001,7002,7003,7004,7005}.conf
3)添加配置内容
port #绑定端口
bind 192.168.253.135 #绑定对外连接提供的ip
daemonize yes #开启守护进程
pidfile .pid #进程文件名
cluster-enabled yes #是否是集群
cluster-config-file 7000_node.conf #集群配置文件
cluster-node-timeout #集群连接超时时间
appendonly yes #数据持久化类型
不同配置文件之间只需更改:port ;pidfile ;cluster-config-file(如果是不同主机上配置,bind也需更改)
4)写一个执行脚本:
#!/bin/bash
for i in `seq `
do
redis-server $i.conf
done
bash a.sh来开启服务
ps -ef | grep redis 来查看是否开启服务
5)早版本需要安装ivm和ruby来做集群操作,现在我们只需要执行以下命令:
redis-cli --cluster create 192.168.253.153: 192.168.253.153: 192.168.253.153: 192.168.253.153: 192.168.253.153: 192.168.253.153: --cluster-replicas
出现以下内容后yes确认接受。
6)测试
进入数据库:redis-cli -p7000 -c -h 192.168.253.153
每一次更改等操作会跳转节点,主节点如果宕机,会由其他两个节点从从节点中选一个来顶替。
拓展:2)、3)、4)步可以通过以下脚本来实现:
#!/bin/bash
for i in `seq `
do
touch "$i".conf
echo -e " port "$i"\nbind 192.168.253.153\ndaemonize yes \npidfile "$i".pid\ncluster-enabled yes\ncluster-config-file "$i"_node.conf\ncluster-node-timeout 15000\nappendonly yes" > "$i".conf
redis-server "$i".conf
done
redis主从与集群搭建的更多相关文章
- redis主从和集群搭建
主从搭建 redis的主从搭建非常简单,打开配置文件6379.conf,只需要将主节点的protected-mode设置为no,然后在从节点配置中加入:slaveof <masterip> ...
- Redis主从&哨兵集群搭建
主从集群 在搭建主从集群前,我们先把Redis安装起来: #解压Redis压缩包 [root@master lf]# tar -zxvf redis-6.2.1.tar.gz -- #安装gcc [r ...
- Redis 3.0 集群搭建
Redis 3.0 集群搭建 开启两个虚拟机 分别在两个虚拟机上开启3个Redis实例 3主3从两个虚拟机里的实例互为主备 下面分别在两个虚拟机上安装,网络设置参照codis集群的前两个主机 分别关闭 ...
- redis主从、集群、哨兵
redis的主从.集群.哨兵 参考: https://blog.csdn.net/robertohuang/article/details/70741575 https://blog.csdn.net ...
- Redis 5.0 集群搭建
Redis 5.0 集群搭建 单机版的 Redis 搭建 https://www.jianshu.com/p/b68e68bbd725 /usr/local/目录 mkdir redis-cluste ...
- 【Redis学习专题】- Redis主从+哨兵集群部署
集群版本: redis-4.0.14 集群节点: 节点角色 IP redis-master 10.100.8.21 redis-slave1 10.100.8.22 redis-slave2 10.1 ...
- Redis进阶实践之十一 Redis的Cluster集群搭建
一.引言 本文档只对Redis的Cluster集群做简单的介绍,并没有对分布式系统的详细概念做深入的探讨.本文只是提供了有关如何设置集群.测试和操作集群的说明,而不涉及Redis集群规范中涵 ...
- linux Redis 5.0集群搭建
文档结构如下: Redis cluster 是redis的分布式解决方案,在3.0版本正式推出后,有效的解决了redis分布式方面的需求:当遇到单机内存,并发,流量等瓶颈是,可以采用cluster架构 ...
- Redis操作及集群搭建以及高可用配置
NoSQL - Redis 缓存技术 Redis功能介绍 数据类型丰富 支持持久化 多种内存分配及回收策略 支持弱事务 支持高可用 支持分布式分片集群 企业缓存产品介绍 Memcached: 优点:高 ...
随机推荐
- hibernate的get方法和load方法区别
读者需注意:Hibernate版本不同,运行机制不太一样,以下是hibernate3.x作为讲解 get方法: Hibernate会确认一下该id对应的数据是否存在,首先在session缓存中查找,然 ...
- Java学习day7面向对象编程1-对象和类
一.Java编程中对象和类的概念 1,什么是类? 答:类是客观存在的,抽象的,概念的东西. 2,什么是对象? 答:对象是具体的,实际的,代表一个事物.例如:车是一个类,汽车,自行车就是他的对象. 关于 ...
- Codeforces 515C 题解(贪心+数论)(思维题)
题面 传送门:http://codeforces.com/problemset/problem/515/C Drazil is playing a math game with Varda. Let’ ...
- Appium+Python之元素定位和操作
一.常用识别元素的工具 uiautomatorviewer:Android SDK自带的一个工具,在tools目录下 二.元素定位 1.格式:find_element_by_定位方式(va ...
- 利用js使图片外层盒子的高等于适应图片的高
JS代码如下:<script> $(window).load(function(){ var width=$(window).width(); var img_1=$(".hot ...
- Hibernate初始化创建SessionFactory,Session,关闭SessonFactory,session
1.hibernate.cfg.xml <?xml version='1.0' encoding='UTF-8'?> <!DOCTYPE hibernate-configuratio ...
- 线程屏障CyclicBarrier实现原理
生产环境中,存在需要等待多个线程都达到某种状态后,才继续运行的情景.并发工具CyclicBarrier就能够完成这种功能.本篇从源码方面,简要分析CyclicBarrier的实现原理. 使用示例 pu ...
- 采集容器内存并写到excel
# coding=utf-8 import os import commands import re from pyExcelerator import * def execute(cmd): sta ...
- 基于firebird的数据转存
功能:使用于相同的表从一个数据库转存到另一数据库: 方式:直连fdb并加载django,引用django的model完成: 原因:1.select * from *** 返回的数有很多None,直接i ...
- Java8 的一些新特性的学习理解
近期在学习队列相关的一些知识,在学习过程中发现Iterable<T>接口中新增了两个新的方法,出于好奇,就想知道这是什么东东,干什么用的.俗话说:实践出真知,所以就有了以下反复的测试. 先 ...