redis_实战笔记

redis简介

redis是一个速度非常快的非关系型数据库,它可以存储键与5种不同类型的值之间的映射,可以将存储在内存的键值对数据持久化到硬盘,可以使用复制特性来扩展读性能,还可以使用客户端分片来快展写性能。

redis与memcached对比

两者都可以用于存储键值映射,彼此的性能也相差无几,但是redis能够自动以两种不同的方式将数据写入硬盘,并且redis除了能存储普通的字符串键之外,还可以存储其他4种数据结构,而memcached只能存储普通的字符串键。

数据库和缓存服务器的特性与功能

名称 类型 数据存储选项 查询类型 附加功能
Redis 使用内存存储的非关系型数据库 字符串、列表、集合、散列值、有序集合 每种数据类型都有自己的专属操作,还有批量操作和不完全的事务支持 发布订阅,主从复制,持久化,脚本
memcached 使用内存存储的键值缓存 键值之间的映射 创建命令、读取命令、更新命令、删除命令以及其他命令 为了提升性能而设的多线程服务器
MySql 关系数据库 每个数据库可以包含多个表,每个表可以包含多个行;可以处理多个表的视图;支持空间和第三方扩展;支持可定制类型 SELECT、INSERT、UPDATE、DELETE、内置函数、自定义存储过程 支持ACID(原子性、一致性、隔离性、持久性)性质,主从复制,由第三方支持的多主复制

redis持久化方法

  1. 时间点转储,转储操作既可以在"指定时间段内有指定数量的写操作执行"这一条件满足时执行,又可以通过调用两条转储到硬盘命令中的任何一个来执行。
  2. 将所有修改了数据库的命令写入一个只追加文件里面,用户可以根据数据的重要程度,将只追加写入设置为从不同步、每秒同步一次或者每写入一个命令就同步一次

redis主从复制

Redis实现了主从复制特性: 执行复制的从服务器会连接上主服务器,接受服务器发送的整个数据库的初始副本;之后主服务器执行命令,都会被发送给所有连接着的从服务器去执行,从而实时地更新从服务器的数据集。因为从服务器包含的数据会不断地进行更新,所以客户端可以向任意一个从服务器发送读请求,以此来避免对主服务器进行集中式的访问。

redis的5种数据结构

结构类型 结构存储的值 结构的读写能力
STRING 可以是字符串、整数或者浮点数 对整个字符串或者字符串的其中一个部分执行操作;对整数和浮点数执行自增或者自减操作
LIST 一个链表,链表上的每个节点都包含了一个字符串 从链表的两端推入或者弹出元素;根据偏移量对链表进行修剪;读取单个或者多个元素;根据值查找或者移除元素
SET 包含字符串的无序收集器,并且包含的每个字符串都是独一无二、各不相同的 添加、获取、移除单个元素;检查一个元素是否存在于集合中;计算交集、并集、差集;从集合里面随机获取元素
HASH 包含键值对的无序散列表 添加、获取、移除单个键值对;获取所有键值对
ZSET 字符串成员与浮点数分值之间的有序映射,元素的排序顺序由分值的小大决定 添加、获取、删除单个元素;根据分值范围或者成员来获取元素

redis中的字符串

命令 行为
GET 获取存储在给定键中的值
SET 设置存储在给定键中的值
DEL 删除存储在给定键中的值(这个命令可以用于所有类型)

redis中的列表

命令 行为
LPUSH 将给定值推入列表的右端
LRANGE 获取列表在给定范围上的所有值
LINDEX 获取列表在给定位置上的单个元素
LPOP 从列表的左端弹出一个值,并返回弹出的值

redis的集合

Redis的集合和列表都可以存储多个字符串,不同点在于,列表可以存储多个相同的字符串,而集合则通过使用散列表来保证自己存储的每个字符串都各不相同(这些散列表只有键,但没有与键相关联的值)。因为Redis的集合使用无序方式存储元素,所有用户不能像使用列表那样,将元素推入集合的某一端,或者从集合的某一端弹出元素。

命令 行为
SADD 将给定的元素添加到集合
SMEMBERS 返回集合包含的所有元素
SISMEMBER 检查给定元素是否在集合中
SREM 如果给定的元素存在于集合中,那么移除这个元素

Redis散列

Redis的散列可以存储多个键值对之间的映射。和字符串一样,散列存储的值既可以是字符串又可以是数字值,并且用户同样可以对散列存储的数字执行自增操作或者自减操作。散列在很多方面是一个微缩版的Redis,不少字符串都有相应的散列版本。

命令 行为
HSET 在散列里关联起给定的键值对
HGET 获取指定散列键的值
HGETALL 获取散列包含的所有键值对
HDEL 如果给定键存在于散列里面,那么移除这个键

Redis有序集合

有序集合和散列一样,用于存储键值对,有序集合的键成为成员,每个成员都各不相同的,而有序集合的值则被称为分值,分值必须为浮点数。有序集合是Redis里面唯一一个既可以根据成员访问元素,又可以根据分值以及分值的排列顺序来访问元素的结构。

命令 行为
ZADD 将一个带有给定分值的成员添加到有序集合里面
ZRANGE 根据元素在有序排列中所处的位置,从有序集合里面获取多个元素
ZRANGEBYSCORE 获取有序集合在给定分值范围内的所有元素
ZREM 如果给定成员存在于有序集合,那么移除这个成员
posted @ 2017-07-05 12:59  zane_zong  阅读(93)  评论(0编辑  收藏  举报