侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

redis用在哪里

Redis  /  管理员 发布于 7年前   161

1. 高并发缓存/共享session:

UserInfo getUserInfo (long id) {}

取:

userRedisKey = "user:info:" + id;

value = redis.get(userRedisKey );

if (value != null) {

userInfo = deserialize(value);

return userInfo;

}

存:

userInfo = ***getUserInfo(id);

redis.setex(userRedisKey, 3600, serialize(userInfo));

用string存储序列化后的数据,不够立体直观,可以转为hmset存储为哈希结构,存取更直观

2. 简单分布式锁

setnx只有不存在时能设置成功,其余只能等待。单线程

3. 计数器 incr,因为是单线程,比cas等少了cpu消耗,性能更高

long incrVideoCounter (long id) {

key = "video:playCount:" + id;

return redis.incr(key);

}

4. 实现栈/队列

栈: lpush + lpop

队列: lpush + rpop

5. 流量控制/限速

phoneNum = "12345678999";

key = "shortMsg:limit:" + phoneNum;

isExists = redis.set(key, 1, "EX 60", "NX");

if (isExists != null || redis.incr(key) <= 5) {

//通过

} else {

//不通过

}

6. 消息队列

使用lpush + brpop可实现阻塞队列,生产者从列表左端lpush插入元素,多个消费者从右端brpop阻塞获取队列尾部元素

7. 每个用户有自己的文章,现在要分页展示文章列表

hmset article:1 title xx context XXXX

lpush user:1:articles srticle:1 articles:3

articles = lrange user:1:articles 0 9

for article in {articles}

hgetall {article}

8. 关注点赞等

点赞: zincrby user:ranking:2016_03_15 mike 1

取消: zrem user:ranking:2016_03_15 mike

取得赞最多的10个用户: zrevrangebyrank user:ranking:2016_03_15 0 9

展示用户信息及分数: hgetall user:info:tom / zscore user:ranking:2016_03_15 mike / zrank user:ranking:2016_03_15 mike

9. bitmaps 计算大数据集合见的关系等

10. 排行榜

mike上传了一个视频并获得了3个赞 zadd user:ranking:2016_03_15 mike 3

又有人给点了个赞 zincrby user:ranking:2016_03_15 mike 1

11. 共同关注

给用户添加关注标签 sadd user:1:tags tag1 tag2

给标签添加用户 sadd tag1:uses user:1

共同关注 sinter user:1:tags user:2:tags

sinter/sunion/sdiff

12. 发布订阅

subscribe video:changes:

publish video:changeds "video1,video2"

for video in video1,video2

update (video)

每种数据type对应了多种底层数据结构实现(object encoding),可以通过数据大小长度场景等切换,达到更高的效率

持久化RDB(子进程创建,二进制文件,恢复快,不够实时)/AOF(appendonly。文本文件,实时写操作先aop_buffer,然后通过配置写入磁盘间隔,写入磁盘,达到一定大小合并)

批量hmget等操作要转为hscan等渐进式遍历方法,否则容易阻塞

缓冲:客户端缓冲(输入/输出),复制积压缓冲,aof缓冲

复制: 全量/增量 复制偏移量/复制积压缓冲(写命令发送给从服务器同时还维护一个先进先出的队列,等于主服务还保存着最近传播的命令)/ID

sentinal: 实现高可用,本身是特殊的redis节点,可以自己配置集群,通过心跳等机制监控redis数据集群,当某一节点出现故障不可用,可以及时发现并自动迁移

cluster: 分布式集群,容错选主等。将物理结点映射到16383个槽位实现动态性

更多Redis相关技术文章,请访问Redis教程栏目进行学习!

以上就是redis用在哪里的详细内容,更多请关注其它相关文章!


  • 上一条:
    redis使用哪种持久化策略好
    下一条:
    redis有哪些api
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在Redis中能实现的功能、常见应用介绍(0个评论)
    • 2024年Redis面试题之一(0个评论)
    • 在redis缓存常见出错及解决方案(0个评论)
    • 在redis中三种特殊数据类型:地理位置、基数(cardinality)估计、位图(Bitmap)使用场景介绍浅析(2个评论)
    • Redis 删除 key用 del 和 unlink 有啥区别?(1个评论)
    • 近期文章
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2017-12
    • 2020-03
    • 2020-05
    • 2021-04
    • 2022-03
    • 2022-05
    • 2022-08
    • 2023-02
    • 2023-04
    • 2023-07
    • 2024-01
    • 2024-02
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客