Redis

Redis:

Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。
Redis 的特性:

  1. redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载使用;
  2. redis不仅仅支持简单的key:value类型的数据,同时还提供了,string.list, zset. set, hash,等数据结构的存储。
  3. redis支持数据的备份,即master–slave模式的数据备份。
使用redis的优势:
  1. 性能极高;redis能读的速度是11万次每秒,写的速度是八万一千次每秒81000
  2. 丰富的数据类型;redsi支持二进制案列的strings,lists,hashes,stes,以及ordered,sets数据类型的操作。
  3. 原子,redis的所有操作都死原子性的,同时redis还支持对几个操作合并后的原子性执行。
  4. 丰富的特性,redis 还支持publish/subscribe,通知,key过期等特性。
redis的应用场景;
  1. 用来做缓存,redis的所有数据是放在内存中的;内存数据库。
  2. 可以在某些特定应用场景下替代传统的数据库------比如社交类的应用。
  3. 在一些大型系统中巧妙的实现一些特定的功能,session共享,购物车;
    设置键值
主从概念

⼀个master可以拥有多个slave,⼀个slave⼜可以拥有多个slave,如此下去,形成了强⼤的多级服务器集群架构
master用来写数据,slave用来读数据,经统计:网站的读写比率是10:1
通过主从配置可以实现读写分离

redis集群搭建:

由于访问量1000W过大的时候就有可能造成服务器挂掉或者自然灾害导致数据的丢失;所以采用集群

集群是一组相互独立的、通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理。一个客户与集群相互作用时,集群像是一个独立的服务器。集群配置是用于提高可用性和可缩放性。

当请求到来首先由负载均衡服务器处理,把请求转发到另外的一台服务器上。

集群组成:软件层面;硬件层面。
软件层面 一台电脑,一台电脑上启动了多个redis服务
硬件层面;存在多台实体电脑,每一台实体电脑上都启动了一个redis服务

string

set
setex
mset
append
get
mget
key
keys
exists
type
delete
expire
getrange
ttl

hash

hset
hmset
hkeys
hget
hmget
hvals
hdel

list

lpush
rpush
linsert
lrange
lset
lrem

set

sadd
smembers
srem

zset

zadd
zrange
zrangebyscore
zscore
zrem
zremrangebyscore

set key value

例1:设置键为name值为itcast的数据

set name itcast

设置键值及过期时间,以秒为单位

setex key seconds value

例2:设置键为aa值为aa过期时间为3秒的数据

setex aa 3 aa

设置多个键值

mset key1 value1 key2 value2 …

例3:设置键为’a1’值为’python’、键为’a2’值为’java’、键为’a3’值为’c’

mset a1 python a2 java a3 c

追加值

append key value

例4:向键为a1中追加值’ haha’

append ‘a1’ ‘haha’

获取:根据键获取值,如果不存在此键则返回nil

get key

例5:获取键’name’的值

get ‘name’

根据多个键获取多个值

mget key1 key2 …

例6:获取键a1、a2、a3’的值

mget a1 a2 a3

查找键,参数⽀持正则表达式

keys pattern

例1:查看所有键

keys *

例2:查看名称中包含a的键

keys ‘a*’

判断键是否存在,如果存在返回1,不存在返回0

exists key1

例3:判断键a1是否存在

exists a1

查看键对应的value的类型

type key

例4:查看键a1的值类型,为redis⽀持的五种类型中的⼀种

type a1

删除键及对应的值

del key1 key2 …

例5:删除键a2、a3

del a2 a3

设置过期时间,以秒为单位

如果没有指定过期时间则⼀直存在,直到使⽤DEL移除

expire key seconds

例6:设置键’a1’的过期时间为3秒

expire ‘a1’ 3

查看有效时间,以秒为单位

ttl key

例7:查看键’bb’的有效时间

ttl bb

哈希类型:

设置单个属性

hset key field value

例1:设置键 user的属性name为itheima

hset user name itheima

例2:设置键u2的属性name为itcast、属性age为11

hmset u2 name itcast age 11

获取指定键所有的属性

hkeys key

例3:获取键u2的所有属性

hkeys u2

获取⼀个属性的值

hget key field

例4:获取键u2属性’name’的值

hget u2 ‘name’

获取多个属性的值

hmget key field1 field2 …

例5:获取键u2属性’name’、'age的值

hmget u2 name age

获取所有属性的值

hvals key

例6:获取键’u2’所有属性的值

hvals u2

删除
删除整个hash键及值,使⽤del命令
删除属性,属性对应的值会被⼀起删除

hdel key field1 field2 …

例7:删除键’u2’的属性’age’

hdel u2 age

list类型的 插入数据:

分别是 左边 l 右边 r
在左侧插⼊数据

lpush key value1 value2 …

例1:从键为’a1’的列表左侧加⼊数据a 、 b 、c

lpush a1 a b c

在右侧插⼊数据

rpush key value1 value2 …

例2:从键为’a1’的列表右侧加⼊数据0 1

rpush a1 0 1

在指定元素的前或后插⼊新元素

linsert key before或after 现有元素 新元素

例3:在键为’a1’的列表中元素’b’前加⼊’3’

linsert a1 before b 3

返回列表⾥指定范围内的元素

start、stop为元素的下标索引
索引从左侧开始,第⼀个元素为0
索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素
lrange key start stop

例4:获取键为’a1’的列表所有元素

lrange a1 0 -1

索引从左侧开始,第⼀个元素为0
索引可以是负数,表示尾部开始计数,如-1表示最后⼀个元素

lset key index value

例5:修改键为’a1’的列表中下标为1的元素值为’z’

lset a 1 z

删除
删除指定元素

将列表中前count次出现的值为value的元素移除
count > 0: 从头往尾移除
count < 0: 从尾往头移除
count = 0: 移除所有
lrem key count value

例6.1:向列表’a2’中加⼊元素’a’、‘b’、‘a’、‘b’、‘a’、‘b’

lpush a2 a b a b a b

例6.2:从’a2’列表右侧开始删除2个’b’

lrem a2 -2 b

例6.3:查看列表’py12’的所有元素

lrange a2 0 -1

set类型

⽆序集合
元素为string类型
元素具有唯⼀性,不重复
说明:对于集合没有修改操作
增加
添加元素

sadd key member1 member2 …

例1:向键’a3’的集合中添加元素’zhangsan’、‘lisi’、‘wangwu’

sadd a3 zhangsan sili wangwu

获取
返回所有的元素

smembers key

例2:获取键’a3’的集合中所有元素

smembers a3

删除
删除指定元素

srem key

例3:删除键’a3’的集合中元素’wangwu’

srem a3 wangwu

zset类型

sorted set,有序集合
元素为string类型
元素具有唯⼀性,不重复
每个元素都会关联⼀个double类型的score,表示权重,通过权重将元素从⼩到⼤排序
说明:没有修改操作
增加
添加

zadd key score1 member1 score2 member2 …

例1:向键’a4’的集合中添加元素’lisi’、‘wangwu’、‘zhaoliu’、‘zhangsan’,权重分别为4、5、6、3

zadd a4 4 lisi 5 wangwu 6 zhaoliu 3 zhangsan

获取
返回指定范围内的元素
start、stop为元素的下标索引
索引从左侧开始,第⼀个元素为0
索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素

zrange key start stop

例2:获取键’a4’的集合中所有元素

zrange a4 0 -1
返回score值在min和max之间的成员

zrangebyscore key min max

例3:获取键’a4’的集合中权限值在5和6之间的成员

zrangebyscore a4 5 6

返回成员member的score值

zscore key member

例4:获取键’a4’的集合中元素’zhangsan’的权重

zscore a4 zhangsan

删除
删除指定元素

zrem key member1 member2 …

例5:删除集合’a4’中元素’zhangsan’

zrem a4 zhangsan

删除权重在指定范围的元素

zremrangebyscore key min max

例6:删除集合’a4’中权限在5、6之间的元素

zremrangebyscore a4 5 6

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章