
目录
- Redis 特性
- 使用场景
- 初次使用
安装(Linux)
配置
启动 redis 的 3 种方法
使用 redis 客户端
关闭 redis 服务
- Redis 版本说明
- 引用
1 Redis 特性
- 速度快(基于内存,C 语言,单线程)
- 基于 key value 键值对的数据结构服务器。全称 Remote Dictionary Server。包含 String,Hash, List, Set, SotrSet. 同时在字符串的基础上演变出位图(BitMaps) 和 HyperLogLog 两种数据数据结构。3.2 版本中加入 GEO(地理信息位置)。
- 丰富的功能。例如:键过时(缓存),发布订阅(消息队列), Lua 脚本(本身实现 Redis 命令),事务,流水线(Pipeline 减小网络开销)。
- 简单稳定。
- 客户端语言多。
- 持久化(RDB,AOF)。
- 主从复制(分布式的基础)。
- 高可用(Sentinel)和分布式(Cluster)。
2 使用场景
缓存redis
合理的使用缓存可以明显加快访问的速度,同时下降数据源的压力。这也是 Redis 最经常使用的功能。Redis 提供了键值过时时间(EXPIRE key seconds
)设置,而且也提供了灵活控制最大内存和内存溢出后的淘汰策略。shell
排行榜数据库
每一个网站都有本身的排行榜,例如按照热度排名的排行榜,发布时间的排行榜,答题排行榜等等。Redis 提供了列表(List)和有序集合(sorted set)数据结构,合理的使用这些数据结构能够很方便的构建各类排行榜系统。缓存
计数器服务器
计数器在网站应用中很是重要,例如,点赞数加一,浏览数加一,还有经常使用的限流操做,限制每一个用户每秒访问系统的次数等等,Redis 支持计数功能(INCR key)并且计数的性能也很是好,计数的同时也能够设置超时时间,这样就能够实现限流。网络
社交网络数据结构
赞/踩,粉丝,共同好友/喜爱,推送,下拉刷新等是社交网站必备的功能,因为社交网站访问量一般比较大,并且传统的数据库不太适合保存这类数据,Redis 提供的数据结构能够相对比较容易实现这些功能。连接:Redis实战:如何构建类微博的亿级社交平台运维
消息队列分布式
Redis 提供的发布订阅(PUB/SUB) 和阻塞队列(blpop key1...keyN timeout )的功能,虽然和专业的消息队列比,还不够强大,但对于通常的消息队列功能基本知足。工具
3 初次使用
- 安装(Linux)
Centos yum install redis
- 配置
安装完成以后,会在 /usr/local/bin 目录目录下,多出几个可执行文件,称之为 redis shell。以下:
redis-server |
启动 redis 服务 |
redis-cli |
redis 命令行客户端 |
redis-benchmark |
redis 基准测试工具 |
redis-check-aof |
redis AOF 持久化文件检测和修复工具 |
redis-check-dump |
redis RDB 持久化文件检测和修复工具 |
redis-sentinel |
启动 redis sentinel |
- 启动 redis 的 3 种方法
3.1 配置文件启动
将配置写到配置文件中,例如写到 /opt/redis/redis.conf 中,执行 redis-server /opt/redis/redis.conf 便可启动 redis。redis 有 60 多个配置,经常使用的是:port(端口),logfile(日志文件),dir(redis 工做目录,存放持久化文件和日志文件),daemonize(是否以守护进程的方式启动 redis)。
3.2 运行启动
在 redis-server 后面加入参数,格式为:redis-server --configkey1 configvaue1 --configkey2 configvalue2. 例如:redis-server --port 6380 ,即,将端口自定义为 6380.
3.3 默认启动
直接 redis-server,默认端口 6379.
若是是生产环境的话,一般建议使用配置文件的方式启动。
- 使用 redis 客户端
redis 客户端能够经过设置 ip 端口,链接 redis 服务器并执行命令。而使用redis-cli 的方式有 2 种。
4.1 交互式方式
经过 redis cli -h [host] -p [port] 的方式链接到 reids 服务。
4.2 命令式方式
经过 redis-cli -h [host] -p [port] [command] 就能够,是一次性的。
注意:若是不指定 host,port ,默认链接 127.0.0.1:6379.
- 关闭 redis 服务
redis 提供了 shutDown 命令来中止 redis 服务,例如停掉127.0.0.1:6379 服务,使用:redis-cli shutdown 便可。
注意点:
- redis 关闭的过程:断开和客户端的链接,持久化文件生成。相对而言比较优雅。
- 不用使用 kill -9,过于粗暴,不但不会作持久化操做,还会形成缓冲区等资源不会优雅关闭。极端状况下形成 AOF 和复制丢失数据的状况。
- shutdown 还有一个参数,表明是否在关闭 redis 前,生成持久化文件:
redis-cli shutdown nosave|save
4 Redis 版本说明
redis 借鉴了 Linux 对于版本号的命名规则,版本号第二位若是是奇数,则为非稳定版本,若是是偶数,则为稳定版本。当前奇数版本就是下一个稳定版本的开发版本。
重大版本:2.8 提高了 sentinel 的可用性,使其可在生产环境使用;3.0 版本最大的功能:添加了分布式 Redis Cluster,填补了官方没有分布式实现的空白(以前都是用户本身实现的 sharding)。
5 引用
《Redis 开发与运维》