概述
Redis是一个开源的使用C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。
特性
- 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s。
- 持久化 – 可以将内存中的数据保存在硬盘中,重启时可以再次加载。
- 多种数据类型 – 支持字符串(String), 列表(List), 集合(Set), 有序集合(Sorted Set) 和 哈希类型(Hash) 等数据类型。
- 原子性 – 所有操作都是原子性,要么成功要么失败。
- 支持多种编程语言 – 支持Python, Ruby, Erlang, Tcl等服务器端语言。
应用场景
- 缓存系统 – 因为Redis能读的速度是110000次/s,写的速度是81000次/s,所以非常适合作为缓存系统。
- 分布式集群的会话存储 – 比如Java中的Tomcat、Memcached就是使用Redis做会话存储。
- 计数器/限速器 – 可以使用Redis的INCR, DECR命令实现。
- 消息队列 – 使用List作为队列,使用Pub/Sub作为发布/订阅。
- 排行榜/计分板 – 使用Sorted Set。
安装
Linux下安装:
# 下载 wget http://download.redis.io/releases/redis-5.0.5.tar.gz # 解压 tar xzf redis-5.0.5.tar.gz # 编译 cd redis-5.0.5 make # 测试 make test # 安装 sudo make install
Windows下安装:
可以通过下载官方提供的Windows版本或使用WSL(Windows Subsystem for Linux)。
客户端
命令行客户端:
redis-cli
多种编程语言的客户端:
- Python:
redis-py
- Java:
Jedis
- Node.js:
ioredis
- Ruby:
redis-rb
- C#:
StackExchange.Redis
- Python:
以上是Redis的基本概念、特性和应用场景,以及如何在Linux和Windows上安装Redis及其常用客户端。