什么是Redis?
Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。
Redis有哪些优点?
1、支持多种数据类型。常见的:string(字符串)、list(列表) 、hash(散列) 、sets (集合) 、sorted set(有序集合)。
2、数据存在内存中,读写性能高。理论上:读的速度是110000次/s,写的速度是81000次/s,实际上可能略小 。
3、原子性。Redis的所有操作都是原子性的,每一个操作都是不可再分的,要么执行,要么不执行。Redis也支持多个操作的事务,通过MULTI和EXEC等指令来实现,但是在事务运行期间,即使某个操作运行失败,其他的命令也将会继续执行。
4、单线程。redis队列将访问变为串行访问,消除了传统数据库串行控制的开销。线程是操作系统最小的执行单元,正因为在Redis中是单线程,意味着Redis的操作是一个一个地进行的,必须完成一个操作后,才进行下一个操作。而这也是Redis操作是原子性的原因。
5、具有持久化的特征。数据可以持久化到硬盘中。
6、可以进行分布式部署,实现读写分离,多个从机分摊读的压力,提高性能。
Redis的应用场景
1、数据缓存。与关系型数据库搭配使用,比如缓存数据库查询频率高但是修改次数很少的数据,能减少对数据库的io操作,实现高速查询,提高性能等。
2、有效解决高并发的问题。一提到高并发,自然会想到抢票、秒杀这样类似的问题,至于为什么说Redis能有效解决高并发的问题呢?上面Redis的有点说的已经很明显了。单线程相当于提供了锁,操作原子性,读写速度极快,还能进行分布式部署,最后还能把操作结果持久化到硬盘。
3、获取最新数据或者访问多的数据等。实现方式:在Redis中使用lpush命令存入数据构建list, 然后通过sort等命令来进行排序。
4、删除过期数据。将数据存入Redis,并设置一个有效时间,当超过这个有效时间时,Redis会删除这个数据。比如,短信验证码。
如果有写的不对的地方,请大家多多批评指正,非常感谢!