1.统计访问次数
对于一些网站来说他们需要统计流量,如果用户访问一次数据库,就要去操作一次数据库表语句,总体来说是非常消耗性能的,访问业务场景是,就可以使用Redis,定义一个key,在里面有一个方法(incr),他可以直接对value进行+1
根据图中的代码可以很明显的看出Redis是后这个功能的,可以减小对数据库的内存io消耗。
2. 做分布式锁
分布式锁常用的有很多种,Zookeeper,Redis,数据库。
2.1 简单使用setnx,这种使用的方式他是有问题的,加锁的操作和后面设置的超时时间他是分开的,,如果超时时间设置失败,这个锁就会一直存在容易产生死锁。
2.2他还有一个方法,可以直接在加锁是就进行设置超时时间。,但是这个情况是必须到了时间才会释放锁,我们可以在执行完业务时进行一个手动释放锁。这种还有一个情况就是
2.3. Redis+脚本
将一些数据封装在脚本里面,在设置加锁时,使用uuid,Lua脚本专门整合了原子操作。
2.4. 看门狗机制
Redisson内置看门狗机制,他会通过定时任务不断地获取锁,获取事件,判断事件是否完成,从而刷新锁的时间
3.做排行榜
使用Zset进行添加数据,可以是key不重复,value设置值,它里面提供了一个方法
score方法可以进行自动排序
4.用户的登录信息
我们经常将用户的登录信息(token)存放到redis当中,这样后面该用户访问其他接口的时候,会直接从Redis中查询用户登录状态,如果可以查到数据,说明用户已登录,则允许做后续的操作。如果从Redis中没有查到用户登录状态,说明该用户没有登录,或者登录状态失效了,则直接跳转到用户登录页面。使用Redis保存用户登录状态,有个好处是它可以设置一个过期时间,比如:该时间可以设置成30分钟。