python3连接redis sentinel集群

2024-08-21 04:32

本文主要是介绍python3连接redis sentinel集群,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

安装

pip install redis

示例代码

# import redis
from redis.sentinel import Sentinel"""
1、通过访问Sentinel服务的方式,获取redis的master、slave节点信息
2、向master redis写入数据
3、从slave redis读取数据
"""# 连接哨兵服务器(主机名也可以用域名)
sentinel = Sentinel([('192.168.196.129', 26379),('192.168.196.132', 26379)],socket_timeout=0.5)# 获取主服务器地址
master = sentinel.discover_master('mymaster')
print(master)
# 输出:('192.168.196.132', 6379)# 获取从服务器地址
slave = sentinel.discover_slaves('mymaster')
print(slave)
# 输出:[('192.168.196.129', 6379)]# 获取主服务器进行写入
master = sentinel.master_for('mymaster', socket_timeout=0.5, password='newpwd', db=0)
w_ret = master.set('foo', 'bar')
# 输出:True# 获取从服务器进行读取(默认是round-roubin,随机从多个slave服务中读取数据)
slave = sentinel.slave_for('mymaster', socket_timeout=0.5, password='newpwd', db=0)
r_ret = slave.get('foo')
print(r_ret)
# 输出:bar

封装工具类方法

from redis.sentinel import Sentinelclass redisSentinelHelper():def __init__(self,sentinel_list,service_name,password,db):self.sentinel = Sentinel(sentinel_list,socket_timeout=0.5)self.service_name = service_nameself.password = passwordself.db = dbdef get_master_redis(self):return self.sentinel.discover_master(self.service_name)def get_slave_redis(self):return self.sentinel.discover_slaves(self.service_name)def set_key(self,key,value):master = self.sentinel.master_for(service_name=self.service_name,socket_timeout=0.5,password=self.password,db=self.db)return master.set(key,value)def get_key(self,key):slave = self.sentinel.slave_for(service_name=self.service_name,socket_timeout=0.5,password=self.password,db=self.db)return slave.get(key)def _test():# redis infosentinel_list = [('192.168.196.129', 26379),('192.168.196.132', 26379)]password = 'newpwd'db = 0service_name = 'mymaster'# create redis linkrsh = redisSentinelHelper(sentinel_list=sentinel_list,password=password,service_name=service_name,db=db)# test set key : key1 test-insert-key1rsh.set_key('key1','test-insert-key1')# get key1print(rsh.get_key('key1'))if __name__ == '__main__':_test()

运行如下:

D:\Python37\python3.exe D:/pythonProject/redis-test/test7.py
b'test-insert-key1'

其中,我没有把设置master节点写在初始化,而是在set key操作的时候才创建连接,主要是后续想要测试master节点变化的情况下,写入能够继续。

当然这样的话性能肯定不会很好,有很多可以根据实际情况修改的地方。

测试:当master节点切换,能否自动连续写入

当然,在sentinel执行master切点切换的过程,肯定会有些丢失,但是主要是要看切换之后,是否可以自动继续写入数据。

首先编写一个循环写入的示例

from redis.sentinel import Sentinelclass redisSentinelHelper():def __init__(self,sentinel_list,service_name,password,db):self.sentinel = Sentinel(sentinel_list,socket_timeout=0.5)self.service_name = service_nameself.password = passwordself.db = dbdef get_master_redis(self):return self.sentinel.discover_master(self.service_name)def get_slave_redis(self):return self.sentinel.discover_slaves(self.service_name)def set_key(self,key,value):master = self.sentinel.master_for(service_name=self.service_name,socket_timeout=0.5,password=self.password,db=self.db)return master.set(key,value)def get_key(self,key):slave = self.sentinel.slave_for(service_name=self.service_name,socket_timeout=0.5,password=self.password,db=self.db)return slave.get(key)def _test():# redis infosentinel_list = [('192.168.196.129', 26379),('192.168.196.132', 26379)]password = 'newpwd'db = 0service_name = 'mymaster'# create redis linkrsh = redisSentinelHelper(sentinel_list=sentinel_list,password=password,service_name=service_name,db=db)# test set key : key1 test-insert-key1# rsh.set_key('key1','test-insert-key1')# get key1# print(rsh.get_key('key1'))# loop set keyfor i in range(0,1000000):rsh.set_key('key' + str(i), i)print(rsh.get_key('key' + str(i)))if __name__ == '__main__':_test()

运行如下:

13423234-be354f9fc300530f.png

在写入的过程停止master服务

13423234-f6083e868c5bd704.png

脚本由于socket连接异常,直接报终止了。

13423234-0364afd6ef7f5232.png

查看sentinel的日志如下:

1825:X 17 Apr 17:44:51.101 # +sdown master mymaster 192.168.196.132 6379
1825:X 17 Apr 17:44:51.194 # +new-epoch 3
1825:X 17 Apr 17:44:51.195 # +vote-for-leader 3607cde178c7ac4255d5f862e8f3892f5599100f 3
1825:X 17 Apr 17:44:52.230 # +odown master mymaster 192.168.196.132 6379 #quorum 2/2
1825:X 17 Apr 17:44:52.230 # Next failover delay: I will not start a failover before Wed Apr 17 17:50:52 2019
1825:X 17 Apr 17:44:52.274 # +config-update-from sentinel 3607cde178c7ac4255d5f862e8f3892f5599100f 192.168.196.129 26379 @ mymaster 192.168.196.132 6379
1825:X 17 Apr 17:44:52.274 # +switch-master mymaster 192.168.196.132 6379 192.168.196.129 6379
1825:X 17 Apr 17:44:52.274 * +slave slave 192.168.196.131:6379 192.168.196.131 6379 @ mymaster 192.168.196.129 6379
1825:X 17 Apr 17:44:52.274 * +slave slave 192.168.196.132:6379 192.168.196.132 6379 @ mymaster 192.168.196.129 6379
1825:X 17 Apr 17:45:22.298 # +sdown slave 192.168.196.132:6379 192.168.196.132 6379 @ mymaster 192.168.196.129 6379
1825:X 17 Apr 17:45:22.298 # +sdown slave 192.168.196.131:6379 192.168.196.131 6379 @ mymaster 192.168.196.129 6379
[root@centos7-server02 redis]# 

可以看到已经切换了master节点,这时候抛开刚才的异常问题,再执行一下脚本看看。

在master节点切换之后,再次运行脚本

13423234-f0b4500cd04702bc.png

直接就可以访问处理了。
这里就体现了通过sentinel集群来获取master节点的优势。

13423234-0e3934319aa622f6.png

这篇关于python3连接redis sentinel集群的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1092124

相关文章

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma

电脑win32spl.dll文件丢失咋办? win32spl.dll丢失无法连接打印机修复技巧

《电脑win32spl.dll文件丢失咋办?win32spl.dll丢失无法连接打印机修复技巧》电脑突然提示win32spl.dll文件丢失,打印机死活连不上,今天就来给大家详细讲解一下这个问题的解... 不知道大家在使用电脑的时候是否遇到过关于win32spl.dll文件丢失的问题,win32spl.dl

redis+lua实现分布式限流的示例

《redis+lua实现分布式限流的示例》本文主要介绍了redis+lua实现分布式限流的示例,可以实现复杂的限流逻辑,如滑动窗口限流,并且避免了多步操作导致的并发问题,具有一定的参考价值,感兴趣的可... 目录为什么使用Redis+Lua实现分布式限流使用ZSET也可以实现限流,为什么选择lua的方式实现

Redis中管道操作pipeline的实现

《Redis中管道操作pipeline的实现》RedisPipeline是一种优化客户端与服务器通信的技术,通过批量发送和接收命令减少网络往返次数,提高命令执行效率,本文就来介绍一下Redis中管道操... 目录什么是pipeline场景一:我要向Redis新增大批量的数据分批处理事务( MULTI/EXE

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、

Windows Server服务器上配置FileZilla后,FTP连接不上?

《WindowsServer服务器上配置FileZilla后,FTP连接不上?》WindowsServer服务器上配置FileZilla后,FTP连接错误和操作超时的问题,应该如何解决?首先,通过... 目录在Windohttp://www.chinasem.cnws防火墙开启的情况下,遇到的错误如下:无法与

Redis中的常用的五种数据类型详解

《Redis中的常用的五种数据类型详解》:本文主要介绍Redis中的常用的五种数据类型详解,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Redis常用的五种数据类型一、字符串(String)简介常用命令应用场景二、哈希(Hash)简介常用命令应用场景三、列表(L

Redis解决缓存击穿问题的两种方法

《Redis解决缓存击穿问题的两种方法》缓存击穿问题也叫热点Key问题,就是⼀个被高并发访问并且缓存重建业务较复杂的key突然失效了,无数的请求访问会在瞬间给数据库带来巨大的冲击,本文给大家介绍了Re... 目录引言解决办法互斥锁(强一致,性能差)逻辑过期(高可用,性能优)设计逻辑过期时间引言缓存击穿:给

Redis中如何实现商品秒杀

《Redis中如何实现商品秒杀》:本文主要介绍Redis中如何实现商品秒杀问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录技术栈功能实现步骤步骤一:准备商品库存数据步骤二:实现商品秒杀步骤三:优化Redis性能技术讲解Redis的List类型Redis的Set