Python 操作 redis(python 操作界面)
mhr18 2024-10-24 11:13 23 浏览 0 评论
连接 Redis
import redis
连接方式:redis提供了2个方法
1:StrictRedis:实现大部分官方的命令
2:Redis:是StrictRedis的子类,用于向后兼容旧版的redis。
官方推荐使用StrictRedis方法。
举例(普通连接):
import redis
#decode_responses=True 自动解码
r = redis.Redis(host='127.0.0.1',port=6379,password='123456',db=0,decode_responses=True) #默认数据库为0
r = redis.StrictRedis(host='10.10.2.14',port=6379,password='123456',decode_responses=True)
连接池:connection pool
管理对一个redis server的所有连接,避免每次建立,释放连接的开销。默认,每个redis实例都会维护一个自己的连接池,可以直接建立一个连接池,作为参数传给redis,这样可以实现多个redis实例共享一个连接池。
举例(连接池):
pool = redis.ConnectionPool(host='127.0.0.1',port=6379,password='123456',decode_responses=True)
r = redis.Redis(connection_pool=pool)
一 、STRING 字符串的操作
1. r.set 设置值
2. r.get 获取值
3. mset 批量设置值
4. mget(keys, *args) 批量获取
5. getset 设置新值,打印原值
6. getrange 根据字节获取子序列
7. setrange 修改字符串内容,从指定字符串索引开始向后替换,如果新值太长时,则向后添加
8. strlen(name) 返回name对应值的字节长度
9. incr 值的累加 amount为累加的值
10. append 在name对应的值后面追加内容
11.type 查看类型
案例
页面点击数
假定我们对一系列页面需要记录点击次数。例如论坛的每个帖子都要记录点击次数,而点击次数比回帖的次数的多得多。如果使用关系数据库来存储点击,可能存在大量的行级锁争用。所以,点击数的增加使用redis的INCR命令最好不过了。
? 当redis服务器启动时,可以从关系数据库读入点击数的初始值(1237这个页面被访问了34634次)
每当有一个页面点击,则使用INCR增加点击数即可。
二、Hash 操作
redis中的Hash 在内存中类似于一个name对应一个dic来存储
1. hset name对应的hash中设置一个键值对(不存在,则创建,否则,修改)
2. hget 在name对应的hash中根据key获取value
3. hgetall 获取name对应hash的所有键值
4. hmset 在name对应的hash中批量设置键值对,mapping:字典
5. hmget 在name对应的hash中获取多个key的值
6.hlen 获取hash中键值对的个数
hkeys 获取hash中所有的key的值
hvals 获取hash中所有的value的值
7. hexists 检查name对应的hash是否存在当前传入的key
8. hdel 删除指定name对应的key所在的键值对
9. hincrby 自增hash中key对应的值,不存在则创建key=amount(amount为整数)
10.hincrbyfloat 自增hash中key对应的值,不存在则创建key=amount(amount为浮点数)
自增hash中key对应的值,不存在则创建key=amount(amount为浮点数)
hincrbyfloat(name, key, amount=1.0)
案例
使用hash类型保存多样化对象,类似二维表结构
当有大量类型文档的对象,文档的内容都不一样时,(即“表”没有固定的列),可以使用hash来表达。
三、List 操作
redis中的List在内存中按照一个name对应一个List来存储
1. lpush 在name对应的list中添加元素,每个新的元素都添加到列表的最左边
2.rpush 同lpush,但每个新的元素都添加到列表的最右边
3. lpushx 在name对应的list中添加元素,只有name已经存在时,值添加到列表的最左边
4. rpushx 在name对应的list中添加元素,只有name已经存在时,值添加到列表的最右边
5. llen name对应的list元素的个数
6. linsert 在name对应的列表的某一个值前或后插入一个新值
7. r.lset 对list中的某一个索引位置重新赋值
8. r.lrem 删除name对应的list中的指定值
9. lpop 移除列表的左侧第一个元素,返回值则是第一个元素
10. lindex 根据索引获取列表内元素
11. lrange 分片获取元素
12. ltrim 移除列表内没有在该索引之内的值(裁剪)
13. rpoplpush(src, dst) 从一个列表取出最右边的元素,同时将其添加至另一个列表的最左边
四、Set 操作
Set集合就是不允许重复的列表
1. sadd(name,values) 给name对应的集合中添加元素
2. smembers(name) 获取name对应的集合的所有成员
3. scard(name) 获取name对应的集合中的元素个数
4. sdiff(keys, *args) 在第一个name对应的集合中且不在其他name对应的集合的元素集合
5. sinter(keys, *args) 获取多个name对应集合的并集
6.sismember 检查value是否是name对应的集合内的元素
7. smove(src, dst, value) 将某个元素从一个集合中移动到另外一个集合
8. spop(name) 从集合的右侧移除一个元素,并将其返回
9. srandmember(name, numbers) 从name对应的集合中随机获取numbers个元素
10. srem(name, values) 删除name对应的集合中的某些值
11. sunion(keys, *args) 获取多个name对应的集合的并集
12. sunionstore(dest,keys, *args) 获取多个name对应的集合的并集,并将结果保存到dest对应的集合中
案例
社交圈子数据
在社交网站中,每一个圈子(circle)都有自己的用户群。通过圈子可以找到有共同特征(比如某一体育活动、游戏、电影等爱好者)的人。当一个用户加入一个或几个圈子后,系统可以向这个用户推荐圈子中的人。
? 我们定义这样两个圈子,并加入一些圈子成员。
获取一个圈子的成员
可以使用集合运算来得到几个圈子的共同成员:
五、有序集合 zset
有序集合:
在集合的基础上,为每元素排序,元素的排序需要根据另外一个值来进行比较,所以,对于有序集合,每一个元素有两个值,即:值和分数,分数专门用来做排序。
1. zadd(name, args, *kwargs)
2. zcard(name) 获取有序集合内元素的数量
3. zcount(name, min, max) 获取有序集合中分数在[min,max]之间的个数
4. zincrby(name, value, amount) 自增有序集合内value对应的分数
5. zrange( name, start, end, desc=False, withscores=False, score_cast_func=float)
6. zrevrange(name, start, end, withscores=False, score_cast_func=float)
7. zrank(name, value)、zrevrank(name, value)
8. zscore(name, value) 获取name对应有序集合中 value 对应的分数
9. zrem(name, values) 删除name对应的有序集合中值是values的成员
10. zremrangebyrank(name, min, max) 根据排行范围删除
11. zremrangebyscore(name, min, max) 根据分数范围删除
12. zinterstore(dest, keys, aggregate=None)
13. zunionstore(dest, keys, aggregate=None)
其他常用操作
1. delete(*names) 根据name删除redis中的任意数据类型
2. exists(name) 检测redis的name是否存在
3. keys(pattern='*') 根据* ?等通配符匹配获取redis的name
4. expire(name ,time) 为某个name设置超时时间
5. rename(src, dst) 重命名
6. move(name, db)) 将redis的某个值移动到指定的db下
7. randomkey() 随机获取一个redis的name(不删除)
8. type(name) 获取name对应值的类型
作者:rottengeek
来源:https://segmentfault.com/a/1190000015191422
相关推荐
- 使用 Docker 部署 Java 项目(通俗易懂)
-
前言:搜索镜像的网站(推荐):DockerDocs1、下载与配置Docker1.1docker下载(这里使用的是Ubuntu,Centos命令可能有不同)以下命令,默认不是root用户操作,...
- Spring Boot 3.3.5 + CRaC:从冷启动到秒级响应的架构实践与踩坑实录
-
去年,我们团队负责的电商订单系统因扩容需求需在10分钟内启动200个Pod实例。当运维组按下扩容按钮时,传统SpringBoot应用的冷启动耗时(平均8.7秒)直接导致流量洪峰期出现30%的请求超时...
- 《github精选系列》——SpringBoot 全家桶
-
1简单总结1SpringBoot全家桶简介2项目简介3子项目列表4环境5运行6后续计划7问题反馈gitee地址:https://gitee.com/yidao620/springbo...
- Nacos简介—1.Nacos使用简介
-
大纲1.Nacos的在服务注册中心+配置中心中的应用2.Nacos2.x最新版本下载与目录结构3.Nacos2.x的数据库存储与日志存储4.Nacos2.x服务端的startup.sh启动脚...
- spring-ai ollama小试牛刀
-
序本文主要展示下spring-aiollama的使用示例pom.xml<dependency><groupId>org.springframework.ai<...
- SpringCloud系列——10Spring Cloud Gateway网关
-
学习目标Gateway是什么?它有什么作用?Gateway中的断言使用Gateway中的过滤器使用Gateway中的路由使用第1章网关1.1网关的概念简单来说,网关就是一个网络连接到另外一个网络的...
- Spring Boot 自动装配原理剖析
-
前言在这瞬息万变的技术领域,比了解技术的使用方法更重要的是了解其原理及应用背景。以往我们使用SpringMVC来构建一个项目需要很多基础操作:添加很多jar,配置web.xml,配置Spr...
- 疯了!Spring 再官宣惊天大漏洞
-
Spring官宣高危漏洞大家好,我是栈长。前几天爆出来的Spring漏洞,刚修复完又来?今天愚人节来了,这是和大家开玩笑吗?不是的,我也是猝不及防!这个玩笑也开的太大了!!你之前看到的这个漏洞已...
- 「架构师必备」基于SpringCloud的SaaS型微服务脚手架
-
简介基于SpringCloud(Hoxton.SR1)+SpringBoot(2.2.4.RELEASE)的SaaS型微服务脚手架,具备用户管理、资源权限管理、网关统一鉴权、Xss防跨站攻击、...
- SpringCloud分布式框架&分布式事务&分布式锁
-
总结本文承接上一篇SpringCloud分布式框架实践之后,进一步实践分布式事务与分布式锁,其中分布式事务主要是基于Seata的AT模式进行强一致性,基于RocketMQ事务消息进行最终一致性,分布式...
- SpringBoot全家桶:23篇博客加23个可运行项目让你对它了如指掌
-
SpringBoot现在已经成为Java开发领域的一颗璀璨明珠,它本身是包容万象的,可以跟各种技术集成。本项目对目前Web开发中常用的各个技术,通过和SpringBoot的集成,并且对各种技术通...
- 开发好物推荐12之分布式锁redisson-sb
-
前言springboot开发现在基本都是分布式环境,分布式环境下分布式锁的使用必不可少,主流分布式锁主要包括数据库锁,redis锁,还有zookepper实现的分布式锁,其中最实用的还是Redis分...
- 拥抱Kubernetes,再见了Spring Cloud
-
相信很多开发者在熟悉微服务工作后,才发现:以为用SpringCloud已经成功打造了微服务架构帝国,殊不知引入了k8s后,却和CloudNative的生态发展脱轨。从2013年的...
- Zabbix/J监控框架和Spring框架的整合方法
-
Zabbix/J是一个Java版本的系统监控框架,它可以完美地兼容于Zabbix监控系统,使得开发、运维等技术人员能够对整个业务系统的基础设施、应用软件/中间件和业务逻辑进行全方位的分层监控。Spri...
- SpringBoot+JWT+Shiro+Mybatis实现Restful快速开发后端脚手架
-
作者:lywJee来源:cnblogs.com/lywJ/p/11252064.html一、背景前后端分离已经成为互联网项目开发标准,它会为以后的大型分布式架构打下基础。SpringBoot使编码配置...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle位图索引 (63)
- oracle批量插入数据 (62)
- oracle事务隔离级别 (53)
- oracle 空为0 (50)
- oracle主从同步 (55)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)