Redis 单例、主从模式、sentinel 以及集群的配置方式及优缺点对比

这里需要说明的是,按照上述方式启动redis,其使用的ip为本机ip 127.0.0.1,端口为6379,并且其余的配置采用的都是默认配置,相关配置可在redis安装目录下的redis.conf文件中查看。如果需要按照指定的配置文件来启动,可在redis-server后接上配置文件名,如:

./src/redis-server redis.conf

另外,上述使用redis-cli连接redis客户端时如果不带任何参数,那么其连接的默认ip和端口为127.0.0.1:6379。如果需要连接指定ip和端口的客户端,可以使用如下方式:

./src/redis-cli -h 127.0.0.1 -p 6379

这里-h参数表示连接的ip,-p则表示连接的端口。

配置好redis之后,我们就可以在redis中执行相关命令来操作数据,关于redis的常用命令,可查看本人的另一篇博客《redis常用命令大全》,其中有比较详细的讲解。

学习资料:Java进阶视频资源

Redis 主从模式的配置

redis单例提供了一种数据缓存方式和丰富的数据操作api,但是将数据完全存储在单个redis中主要存在两个问题:数据备份和数据体量较大造成的性能降低。

这里redis的主从模式为这两个问题提供了一个较好的解决方案。主从模式指的是使用一个redis实例作为主机,其余的实例作为备份机。

主机和从机的数据完全一致,主机支持数据的写入和读取等各项操作,而从机则只支持与主机数据的同步和读取,也就是说,客户端可以将数据写入到主机,由主机自动将数据的写入操作同步到从机。

主从模式很好的解决了数据备份问题,并且由于主从服务数据几乎是一致的,因而可以将写入数据的命令发送给主机执行,而读取数据的命令发送给不同的从机执行,从而达到读写分离的目的。

如下所示主机redis-A分别有redis-Bredis-Credis-Dredis-E四个从机:

60fea119e9e5d1bf329b8a11ea67d42f.png

前面第1点中我们已经介绍了redis单例的配置方式,而上面我们也介绍了主从模式其实也是多个redis实例组成的,因而redis主从模式的配置可以理解为多个不同的redis实例通过一定的配置告知其相互之间的主从关系。

而前面已经介绍,每个redis实例都会占用一个本机的端口号,主从模式的配置主要的配置点有两个:当前实例端口号和当前实例是主机还是从机,是从机的话其主机的ip和端口是什么。

一般的redis目录下的redis.conf保存的是默认配置,尽量不要对其进行修改,这里我们复制三份redis.conf文件,分别命名为6379.conf6380.conf6381.conf,如下是端口为6379的主机的主要配置:

bind 127.0.0.1

port 6379

logfile “6379.log”

dbfilename “dump-6379.rdb”

如下是端口为6380和6381的从机的配置:

bind 127.0.0.1

port 6380

logfile “6380.log”

dbfilename “dump-6380.rdb”

slaveof 127.0.0.1 6379

bind 127.0.0.1

port 6381

logfile “6381.log”

dbfilename “dump-6381.rdb”

slaveof 127.0.0.1 6379

可以看到,端口为6380和6381的实例被配置为端口为6379的实例的从机。配置完成后使用redis-server分别执行如下命令启动三个实例:

./src/redis-server 6379.conf

./src/redis-server 6380.conf

./src/redis-server 6381.conf

启动之后分别开启开启三个命令行工具分别执行以下命令连接redis实例:

./src/redis-cli -p 6379

./src/redis-cli -p 6380

./src/redis-cli -p 6381

分别在三个命令行工具中执行一个get命令,获取键名为msg的数据,如下所示:

127.0.0.1:6379> get msg

(nil)

12

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redis主从复制是指通过将数据从一个Redis实例(主节点)复制到另一个实例(从节点)来实现数据的备份和负载均衡的过程。主节点接收写入请求并将其同步到从节点,而从节点只能接收读取请求。主从复制模式可以提高Redis的可用性和性能,因为它可以实现读写分离和故障转移。 要搭建主从复制的集群,需要进行以下步骤: 1. 在主节点和从节点上安装Redis,并确保它们都可以正常运行。 2. 在主节点的redis.conf配置文件中添加“slaveof”指令,指定从节点的IP地址和端口号。例如,如果从节点的IP地址为192.168.0.2,端口号为6379,则指令为“slaveof 192.168.0.2 6379”。 3. 在从节点的redis.conf配置文件中添加“masterauth”指令,指定主节点的密码(如果有)。例如,如果主节点的密码为“password”,则指令为“masterauth password”。 4. 重启主节点和从节点,以使配置生效。可以使用redis-cli命令行工具验证主从复制是否正常工作,例如,在主节点上键入“set foo bar”,然后在从节点上键入“get foo”,应该会返回“bar”。 5. 可以通过添加更多的从节点来扩展主从复制集群。只需要将每个从节点的“slaveof”指令指向主节点的IP地址和端口号即可。 需要注意的是,主从复制模式并不提供高可用性,因为当主节点发生故障时,必须手动将一个从节点升级为新的主节点。因此,为了实现高可用性,可以考虑使用Redis SentinelRedis Cluster等其他技术。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值