Redis
1. Redis是什么?
Redis是一个开放源代码(BSD许可)的内存中数据结构存储,用作数据库,缓存和消息代理。它支持数据结构,例如字符串,哈希,列表,集合,带范围查询的排序集合,位图,超日志,带有半径查询和流的地理空间索引。Redis具有内置的复制,Lua脚本,LRU驱逐,事务和不同级别的磁盘持久性,并通过Redis Sentinel和Redis Cluster自动分区提供了高可用性。
Redis是用C语言开发的一一个开源的高性能键值对( key-value )内存数据库。
它提供五种数据类型来存储值:字符串类型、散列类型、列表类型、集合类型、有序集合类型
它是一个NoSQL数据库
Redis支持哪几种数据类型:String、List、Set、Sorted Set、hashes
2 Redis有那些优势?
(1) 速度快,因为数据存在内存中,类似于HashMap,HashMap的优势就是查找和操作的时间复杂度都是O(1)
(2) 支持丰富数据类型,支持string,list,set,sorted set,hash
(3) 支持事务,操作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行
(4) 丰富的特性:可用于缓存,消息,按key设置过期时间,过期后将会自动删除
3 Redis的特点?
Redis可以从磁盘重新将数据加载到内存中,这些可以通过配置文件对其进行配置,正因为这样,Redis才能实现持久化。
Redis支持主从模式,可以配置集群,这样更利于支撑起大型的项目,这也是Redis的一大亮点。
Redis的性能非常出色,每秒可以处理超过 10万次 读写操作,是已知性能最快的Key-Value DB
Redis的出色之处不仅仅是性能,Redis最大的魅力是支持保存多种数据结构,此外单 个 value 的最大限制是
1GB,不像 memcached只能保存1MB的数据,另外Redis 也可以对存入的Key-Value设置expire时间。
4 什么是NoSQL数据库?
NoSQL ,即Not-0nly SQL (不仅仅是SQL ),泛指非关系型的数据库。
什么是关系型数据库?数据结构是一种有行有列的数据库
NoSQL数据库是为了解决高并发、融用、扩展、大数据存储问题而产生的数据库解决方案。
5 为什么redis需要把所有数据放到内存中?
Redis为了达到最快的读写速度将数据都读到内存中,并通过异步的方式将数据写入磁盘。所以redis具有快速和
数据持久化的特征。如果不将数据放在内存中,磁盘 I/O 速度为严重影响 redis 的性能。在内存越来越便宜的今天,
redis将会越来越受欢迎。如果设置了最大使用的内存,则数据已有记录数达到内存限值后不能继续插入新值。
6 NoSQL数据库分类
■ 键值(Key-Value)存储数据库
典型应用:内容缓存,主要用于处理大量数据的高访问负载。数据模型: 一系列键值对。
优势:快速查询劣势:存储的数据缺少结构化
■列存储数据库
■文档型数据库
■图形(Graph)数据库
7 Redis安装配置
* 官网地址:http://redis.io/
* 中文官网地址:http://www.redis.cn/
* 下载地址:http://download.redis.io/releases/
1.解压
tar xzvf redis-4.0.8.tar.gz
2.安装
yum install gcc-c++
cd redis-4.0.8
make
cd src
make install PREFIX=/usr/local/redis
3.开启redis
/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf
4.常用命令
redis-server /usr/local/redis/etc/redis.conf //启动redis
pkill redis //停止redis
卸载redis:
rm -rf /usr/local/redis //删除安装目录
rm -rf /usr/bin/redis-* //删除所有redis相关命令脚本
rm -rf /root/download/redis-4.0.4 //删除redis解压文件夹
8.Redis的数据类型
一、String(字符串)
string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。
string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。
string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。
127.0.0.1:6379> SET name "yzl" OK 127.0.0.1:6379> GET name "yzl"
二、Hash(哈希)
Redis hash 是一个键值(key=>value)对集合。
Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。
每个 hash 可以存储 232 -1 键值对(40多亿)
127.0.0.1:6379> HMSET myhash name "yzl" age "20" OK 127.0.0.1:6379> HGET myhash name "yzl" 127.0.0.1:6379> HGET myhash age "20"
三、List(列表)
- Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。
- 列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)。
- 他的底层是一个链表
127.0.0.1:6379> LPUSH fruitlist apple (integer) 1 127.0.0.1:6379> LPUSH fruitlist banana (integer) 2 127.0.0.1:6379> LPUSH fruitlist orange (integer) 3 127.0.0.1:6379> LRANGE fruitlist 1 2 1) "banana" 2) "apple"
四、Set(集合)
Redis的Set是string类型的无序集合。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)。
sadd key member
添加一个 string 元素到 key 对应的 set 集合中,成功返回1,如果元素已经在集合中返回 0,如果 key 对应的 set 不存在则返回错误。
127.0.0.1:6379> sadd city beijing (integer) 1 127.0.0.1:6379> sadd city hangzhou (integer) 1 127.0.0.1:6379> sadd city shandong (integer) 1 127.0.0.1:6379> sadd city guangzhou (integer) 1 127.0.0.1:6379> sadd city beijing (integer) 0 127.0.0.1:6379> smembers city 1) "shandong" 2) "guangzhou" 3) "hangzhou" 4) "beijing"
注意:以上实例中 beijing添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。
五、zset(sorted set:有序集合)
zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。zset的成员是唯一的,但分数(score)却可以重复。
zadd key score member
添加元素到集合,元素在集合中存在则更新对应score
127.0.0.1:6379> zadd price 3 pen (integer) 1 127.0.0.1:6379> zadd price 5 apple (integer) 1 127.0.0.1:6379> zadd price 50 dinner (integer) 1 127.0.0.1:6379> zadd price 100 basketball (integer) 1 127.0.0.1:6379> zrangebyscore price 10 200 1) "dinner" 2) "basketball"