Redis入门
1. 简介
Redis是一个高性能的并且开源的使用key-value保存数据的NoSql数据库,它的特点包括:
Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
Redis支持数据的备份,即master-slave模式的数据备份。
性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
Redis的所有操作都是原子性的,意思就是要么成功执行要么失败完全不执行。单个操作是原子性的。多个操作也支持事务,即原子性,通过MULTI和EXEC指令包起来。
丰富的特性,Redis还支持 publish/subscribe, 通知, key 过期等等特性。
Redis作为持久层,它存储的数据结构是半结构化的,这就意味着计算机在读入内存时有更少的规则,读入速度更快。作为缓存,它支持大数据存入内存中,只要命中率高,它就能快速响应。
举个例子,对于常用数据,第一次从数据库取出存放在nosql中,这样以后无需访问数据库,只要从nosql中读出即可,性能比数据库快得多,对于高并发的操作,可以先在nosql上完成写入,等待某一时刻再批量写入数据库,这样就满足系统的性能要求了。
2. 应用场景
缓存
任务队列
应用排行榜
网站访问统计
数据过期处理
分布式集群架构中的session分离
3. Linux下安装
4. 启动
5. 停止
6. 进入redis客户端
apt-get 安装
7. 增删查改数据
8. Redis基础特性
多数据库:
一个Redis实例最多提供16个数据库(类似mysql的多个数据库),下标0-15,默认连接0数据库。
通过select n 选择数据库。
事务:
一次提交多条记录,multi:开始事务;exec:提交事务;discard:回滚事务。
密码设置
redis没有实现访问控制这个功能,但是他提供了一个轻量级的认证方式,可以编辑redis.conf配置来启用认证。比如:
需要重启redis才能生效。也可以在cli中进行配置密码:
这样配置后,只要不重启redis就一直是生效的。
登录有密码的redis:
也可以先登录后验证。
实现访问控制还可以通过绑定ip的办法。同样在redis.conf中:
9. 在java中使用redis
9.1 引入jedis依赖
在pom.xml中添加redis的依赖
9.2 在java文件中使用redis
这是我在win下运行的结果:
这里每秒只操作了2万多次,而事实上Redis的执行速度比这个操作要快的多,这是因为我们只是一条一条的将命令发送给redis去执行,如果使用流水线技术会快的多。将可以达到10万次每秒的速度,十分有利于系统性能的提升。
10. 在SpringMVC中使用redis
10.1 引入pom依赖
10.2 配置连接池,连接工厂,序列化方式
10.3 在java文件中使用redis
1)序列化类Role
2)自动注入RedisTemplate
3)redis写入和读取
运行程序后查看日志:
可以看到使用RedisTemplate可以很好的实现java对象的序列化存储和读取。
4)使用同一个连接池操作
以上的使用都是基于redisTemplate、基于连接池的操作,换句话说,并不能保证每次使用RedisTemplate都是操作同一个Redis的连接,比如上面的set和get方法。使用同一个连接可以节省资源,对于有很多操作的时候我们往往希望通过使用同一个连接操作。
为了保证所有的操作都来自同一个连接,可以使用SessionCallback或者RedisCallback这两个接口,RedisCallback是比较底层的封装,其使用不是很友好,所以更多的时候会使用SessionCallback这个接口,通过这个接口就可以把多个命令放入到同一个Redis连接中去执行。比如上面redis写入和读取的代码可以改成:
日志打印:
11. redis为什么采用单线程
使用单线程模型能带来更好的可维护性,方便开发和调试;
使用单线程模型也能并发的处理客户端的请求;
Redis 服务中运行的绝大多数操作的性能瓶颈都不是 CPU;
redis4.0之后引入多线程执行一些非阻塞的删除操作等;
redis6.0使用I/O多线程进行数据包的解析;
https://draveness.me/whys-the-design-redis-single-thread/ 这篇文章写得很好。
参考:
Last updated
Was this helpful?