【精品】Redis在项目中的应用场景,怒斩获了30家互联网公司offer

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Web前端全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024c (备注前端)
img

正文

热点数据缓存、对象缓存、全页缓存、可以提升热点数据的访问数据

位统计

在线用户统计,留存用户统计

分布式锁

// 当setnx返回1时,表示获取锁,做完操作以后del key,表示释放锁,如果setnx返回0表示获取锁失败

public static boolean getLock(String key) {

Long flag = jedis.setnx(key, “1”); //只有不存在时才能添加成功

if (flag == 1) {

jedis.expire(key, 10);

}

return flag == 1;

}

public static void releaseLock(String key) {

jedis.del(key);

}

setnx key value说明:

  • 当key不存在时,将 key 的值设为 value ,返回1

  • 若给定的 key 已经存在,则setnx不做任何动作,返回0。

计数器

int类型:incr方法

文章的阅读量、微博点赞数、允许一定的延迟,先写入Redis再定时持久化同步到数据库

示例:

set key 0

incr key // incr readcount::{帖子id} 每阅读一次

get key // get readcount::{帖子id} 获取阅读量

限流

int类型:incr方法

以访问者的ip和其他信息作为key,访问一次增加一次计数,超过次数则返回false

示例:封锁某IP地址

Set 127.0.0.1 0

Incr 127.0.0.1 //每访问一次+1,当值超过阀值时,禁止访问

分布式全局唯一id

分布式全局唯一id的实现方式有很多,这里只介绍用redis实现

在这里插入图片描述

每次获取userId的时候,对userId加1再获取,可以改进为如下形式

在这里插入图片描述

直接获取一段userId的最大值,缓存到本地慢慢累加,快到了userId的最大值时,再去获取一段,一个用户服务宕机了,也顶多一小段userId没有用到

set userId 0

incr usrId //返回1

incrby userId 1000 //返回10001

Hash


redis的散列可以让用户将多个键值对存储到一个Redis的键里面,散列非常适用于将一些相关的数据存储在一起。类似map的一种结构,将结构化的数据,比如一个对象(前提是这个对象没嵌套其他的对象)缓存到redis中,以后每次读写内存时,就可以操作hash里的某个字段

示例

// 存储用户信息,比如保存name,age:

hset(user:1001,name,“zhangsan”)

hset(user:1001,age,18)

hget(user:1001,name) //获取

hset(user:1001,name,“张三”) //修改

示例: 购物车,采用String 或hash实现:

  • key:用户id;field:商品id;value:商品数量。

  • +1:hincr。-1:hdecr。删除:hdel。全选:hgetall。商品数:hlen。

List


模拟消息队列:

实现最新消息的排序

使用push将任务存在List中

使用pop将任务从List中取出

应用:模拟电商中的秒杀功能

示例

在这里插入图片描述

在list里面一边进,一边出即可

实现方式一

lpush key value //一直往list左边放

brpop key value 10

//key这个list有元素时,直接弹出,没有元素被阻塞,直到等待超时或发现可弹出元素为止,上面例子超时时间为10s

实现方式二

rpush key value

blpop key value 10

示例:新浪/Twitter用户消息列表

// 假如用户li关注了2个微博a和b

// a发了一条微博(编号为100)就执行如下命令:

lpush msg::li 100

// b发了一条微博(编号为200)就执行如下命令:

lpush msg::li 200

// 假如想拿最近的10条消息就可以执行如下命令(最新的消息一定在list的最左边):

lrange msg::li 0 9 //下标从0开始,[start,stop]是闭区间,都包含

Set


无序集合,自动去重,将数据放到set中就可去重,可以基于JVM的HashSet去重,如果系统部署在多台机器上,就可以用redis进行全局去重。

可以基于set做交集,并集,差集的操作。

应用举例:

  • 将每个人的好友存在Set中,可避免重复

  • 求两个人的共同好友,使用sinter求交集

示例:点赞、签到、打卡

假如微博ID是t1001,用户ID是u3001。用 like:t1001 来维护 t1001 这条微博的所有点赞用户,则:

最后

四轮技术面+一轮hr面结束,学习到了不少,面试也是一个学习检测自己的过程,面试前大概复习了 一周的时间,把以前的代码看了一下,字节跳动比较注重算法,面试前刷了下leetcode和剑指offer, 也刷了些在牛客网上的面经。大概就说这些了,写代码去了~

祝大家都能收获大厂offer~

篇幅有限,仅展示部分内容

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
65.png)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-ebO2An1k-1713438303051)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 12
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值