Redis
概念:Redis是 REmote DIctionary Server 远程字典服务的缩写,非关系型数据库,key-value形式缓存。
1、Redis数据库的应用场景
(1)Token令牌的生成,随机生成一个token,将token存入Redis中,设置Redis的key的有效时间,也就是token的有效时间,最后返回这个token就可以拿到了,RedisUtils这个工具类是需要自己写的。
public String getToken(){
String token = "token" + UUID.randomUUID().toString();
RedisUtils redisUtils = new RedisUtils();
redisUtils.setString(token,token,5l);
return token;
}
(2)短信验证码,将短信验证码存入Redis的key,设置这个key的有效期,一般是一分钟,一分钟之后,key过期,验证码也失效。
(3)实现缓存数据,对于经常查询的数据,可以将数据存入Redis缓存,这样可以减轻对数据库的查询压力,同时也能提升效率,因为Redis是非常高效的。
(4)实现计数器,比如网站的点击量,因为Redis的单线程的,可以保证数据的原子性。
(5)分布式锁
(6)秒杀场景中,订单超时未支付的情况。
2、Redis的线程模型
Redis底层采用的IO多路复用原则,能够很好的支持并发;Redis是单线程的,底层采用一个线程去维护不同客户端的IO操作,将多个客户端的连接存储到一个集合里面,使用一个线程维护。Redis在linux操作系统中采用epoll实现事件驱动回调,只对活跃的socket连接实现主动回调,时间复杂度是O(1),而不会去轮询存储客户端连接的集合,效率大大提升;和Redis一样使用IO多路复用原则的还有Nginx,都是采用了nio的epoll实现的。