关于Redis的Python客户端的连接池问题
Python  /  管理员 发布于 3年前   305
在一次分享中提到了Redis的长短链接的问题,引发了对redis-py的连接池机制的讨论。
通过源码发现,每创建一个Redis实例都会构造出一个ConnectionPool,每一次访问redis都会从这个连接池得到一个连接,访问完成之后,会把该连接放回连接池,下面是发送命令访问redis的execute_command方法实现:
352 #### COMMAND EXECUTION AND PROTOCOL PARSING #### 353 def execute_command(self, *args, **options): 354 "Execute a command and return a parsed response" 355 pool = self.connection_pool 356 command_name = args[0] 357 connection = pool.get_connection(command_name, **options) 358 try: 359 connection.send_command(*args) 360 return self.parse_response(connection, command_name, **options) 361 except ConnectionError: 362 connection.disconnect() 363 connection.send_command(*args) 364 return self.parse_response(connection, command_name, **options) 365 finally: 366 pool.release(connection)
当然,也可以构造一个ConnectionPool,在创建Redis实例时,可以将该ConnectionPool传入,那么后续的操作会从给定的ConnectionPool获得连接。
redis-py的作者在文档中也有详细说明:
博主 在
2023年国务院办公厅春节放假通知:1月21日起休7天中评论 @ xiaoB 你只管努力,剩下的叫给天意;天若有情天亦老,..xiaoB 在
2023年国务院办公厅春节放假通知:1月21日起休7天中评论 会不会春节放假后又阳一次?..BUG4 在
你翻墙过吗?国内使用vpn翻墙可能会被网警抓,你需了解的事中评论 不是吧?..博主 在
go语言+beego框架中获取get,post请求的所有参数中评论 @ t1 直接在router.go文件中配就ok..Jade 在
如何在MySQL查询中获得当月记录中评论 Dear zongscan.com team, We can skyroc..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号