深入浅出Redis
1.Redis的发展史
Redis[Remote Directory Server]:远程服务器字典
2.下载安装Redis
1》Linux下安装Reids
http://redis.io/download
wget http://download.redis.io/releases/redis-3.0.1.tar.gz 下载
tar -xzvf redis-3.0.1.tar.gz 解压
cd redis-3.0.1 进入解压目录
make 编译 安装
make install
2》在bin下可执行的程序
redis-server:Redis服务器
redis-cli:命令行客户端
redis-benchmark:Redis的性能测试工具
redis-check-aof:AOF文件修复工具
redis-check-dump:RDB文件检测工具
redis.conf是Redis的配置文件
将配置文件中daemonize yes 以守护进程的方式来使用
3》启动和停止Redis
直接启动
redis-server
redis-server /ect/redis.conf
停止Redis
shutdown
结束Redis的进程也可以
3.命令返回值
1》状态回复
ping
SET test 'this is a test'
2》错误回复
错误回复以error开始
(error) ERR unknown command 'TESTERROR'
3》整数回复:
以interger 数值
(integer) 2
4》字符串回复
GET test
(nil)代表空的结果
5》多行字符串回复
KEYS *,得到当前数据库中的存在的键名
4.Redis配置选项相关内容
1》动态设置/获取配置选项的值
获取:
CONFIG GET name
1)"port"
2)"6379"
设置:
CONFIG SET name value
登录时设置的会覆盖默认的设置
2》Redis配置文件redis.conf选项相关
--连接选项--
port 6379 默认端口
bind 127.0.0.1,默认绑定的主机地址
timeout 0,当客户端闲置多久之后关闭连接,0代表没有启动这个选项
loglevel notice,日志的记录级别
# debug:很详细的信息,适合开发和测试
# verbose :包含很多不太有用的信息
# notice :比较适合生产环境
# warning :警告信息
logfile stdout,日志的记录方式,默认为标准输出(linux下)
databases 16,默认数据库的数量16个,默认的数据库编号从0开始
127.0.0.1:6379> SELECT 1
OK
127.0.0.1:6379[1]> KEYS *
(empty list or set)
127.0.0.1:6379[1]> SELECT 0
OK
127.0.0.1:6379> KEYS *
1) "lewen"
8
8
1
127.0.0.1:6379> SELECT 1
2
OK
3
127.0.0.1:6379[1]> KEYS *
4
(empty list or set)
5
127.0.0.1:6379[1]> SELECT 0
6
OK
7
127.0.0.1:6379> KEYS *
8
1) "lewen"
--快照--
save <seconds> <changes>:多少秒有多少次改变将其同步到磁盘中数据文件里
save 900 1--900秒内有一个更改
save 300 10--300秒内有10个更改
save 60 10000--60秒内有10000个更改
rdbcompression yes,存储本地数据库时是否启用压缩,默认yes
dbfilename dump.rdb,指定本地数据库文件名,默认为dump.rdb
dir ./,指定本地数据库的存放目录,默认是当前目录
5.Redis的数据类型
String字符串类型
一个键最多存储512MB
1》SET:设置key对应的值为value
语法:SET key value [EX seconds] [PX milliseconds] [NX|XX]
EX seconds:设置键的key的过期时间SET key value EX seconds -- SETEX
PX milliseconds:以毫秒的形式设置过期时间SET key value PX milliseconds--PSETEX
NX:只有键不存在的时候才可以设置成功SET key value NX--SETNX
XX:只有key已经存在的时候才可以设置
SET test16 'this is a test16' EX 100
SET test17 'this is a test17' PX 20000
SET test18 'this is a test18' NX
SET test18 'this is a test18888' XX
SET test19 'this is a test19' EX 100 NX
SET test20 'this is a test20' EX 100 PX 300000 NX
SET testStr1 'this is a test'
注意:如果key存在,同名会产生覆盖
2》GET:根据key找到对应的值
语法:GET key
GET testStr1
注意:如果key不存在,返回nil
如果key不是字符串,会报错
3》GETRANGE:返回字符串中一部分
语法:GETRANGE key start end
GETRANGE testStr2 0 4
GETRANGE testStr2 0 -3
GETRANGE testStr2 -4 -2
GETRANGE testStr2 0 1000
127.0.0.1:6379> get 43
"wew"
127.0.0.1:6379> GETRANGE lewen -4 -1
"irst"
4
4
1
127.0.0.1:6379> get 43
2
"wew"
3
127.0.0.1:6379> GETRANGE lewen -4 -1
4
"irst"
4》GETSET:设置指定key的值,并且返回旧的值
语法:GETSET key value
SET testStr3 'king'
GET testStr3
GETSET testStr3 'queen'
注意:当key不存在返回nil
如果key不是字符串,会报错
127.0.0.1:6379> SEt str3 'king'
OK
127.0.0.1:6379> get str3
"king"
127.0.0.1:6379> GETSET str3 'queen'
"king"
127.0.0.1:6379> get str3
"queen"
127.0.0.1:6379> SET count 1
OK
127.0.0.1:6379> INCR count
(integer) 2
127.0.0.1:6379> INCR count
(integer) 3
127.0.0.1:6379> GETSET count 0
"3"
127.0.0.1:6379> GET count
"0"
x
21
1
127.0.0.1:6379> SEt str3 'king'
2
OK
3
127.0.0.1:6379> get str3
4
"king"
5
127.0.0.1:6379> GETSET str3 'queen'
6
"king"
7
127.0.0.1:6379> get str3
8
"queen"
9
10
11
12
127.0.0.1:6379> SET count 1
13
OK
14
127.0.0.1:6379> INCR count
15
(integer) 2
16
127.0.0.1:6379> INCR count
17
(integer) 3
18
127.0.0.1:6379> GETSET count 0
19
"3"
20
127.0.0.1:6379> GET count
21
"0"
5》MSET:一次设置多个键值对
语法:MSET key value [key value...]
MSET testStr5 'king' testStr6 'maizi' testStr7 'queen'
6》MGET:一次得到多个键值
语法:MGET key key
MGET testStr5 testStr6 testStr7
MGET testStr5 testStr6 testStr7 testStr8
127.0.0.1:6379> KEYS *
1) "count"
2) "str2"
3) "lewen"
4) "43"
5) "str3"
127.0.0.1:6379> MSET str4 'a4' str5 'a5'
OK
127.0.0.1:6379> KEYS *
1) "count"
2) "str2"
3) "str5"
4) "lewen"
5) "str4"
6) "43"
7) "str3"
127.0.0.1:6379> MGET count str2 str4
1) "0"
2) "redis"
3) "a4"
127.0.0.1:6379>
21
21
1
127.0.0.1:6379> KEYS *
2
1) "count"
3
2) "str2"
4
3) "lewen"
5
4) "43"
6
5) "str3"
7
127.0.0.1:6379> MSET str4 'a4' str5 'a5'
8
OK
9
127.0.0.1:6379> KEYS *
10
1) "count"
11
2) "str2"
12
3) "str5"
13
4) "lewen"
14
5) "str4"
15
6) "43"
16
7) "str3"
17
127.0.0.1:6379> MGET count str2 str4
18
1) "0"
19
2) "redis"
20
3) "a4"
21
127.0.0.1:6379>
7》STRLEN:获取key的字符串长度
语法:STRLEN key
STRLEN testStr5
注意:对于不存在key获取其长度返回的0
127.0.0.1:6379> STRLEN str4
(integer) 2
127.0.0.1:6379> STRLEN str6
(integer) 0
4
4
1
127.0.0.1:6379> STRLEN str4
2
(integer) 2
3
127.0.0.1:6379> STRLEN str6
4
(integer) 0
8》SETRANGE:相当于字符串替换的效果
语法:SETRANGE key offset value
注意:如果设置的key原来的字符串长度要比偏移量小,就会以零字节(x00)来填充
SET testStr9 'hello king'
SETRANGE testStr9 6 'queen'
对不存在的key使用SETRANGE
EXISTS testStr10
SETRANGE testStr10 5 'king'
127.0.0.1:6379> SETRANGE str9 'hello lewen'
(error) ERR wrong number of arguments for 'setrange' command
127.0.0.1:6379> set str9 'hello lewen'
OK
127.0.0.1:6379> get str9
"hello lewen"
127.0.0.1:6379> SETRANGE str9 7 'kevin'
(integer) 12
127.0.0.1:6379> get str9
"hello lkevin"
127.0.0.1:6379> SETRANGE str9 6 'kevin'
(integer) 12
127.0.0.1:6379> get str9
"hello kevinn"
127.0.0.1:6379> SETRANGE str10 5 'lewen'
(integer) 10
127.0.0.1:6379> get str10
"x00x00x00x00x00lewen"
18
18
1
127.0.0.1:6379> SETRANGE str9 'hello lewen'
2
(error) ERR wrong number of arguments for 'setrange' command
3
127.0.0.1:6379> set str9 'hello lewen'
4
OK
5
127.0.0.1:6379> get str9
6
"hello lewen"
7
127.0.0.1:6379> SETRANGE str9 7 'kevin'
8
(integer) 12
9
127.0.0.1:6379> get str9
10
"hello lkevin"
11
127.0.0.1:6379> SETRANGE str9 6 'kevin'
12
(integer) 12
13
127.0.0.1:6379> get str9
14
"hello kevinn"
15
127.0.0.1:6379> SETRANGE str10 5 'lewen'
16
(integer) 10
17
127.0.0.1:6379> get str10
18
"x00x00x00x00x00lewen"
9》SETNX:只有key不存在才能设置成功
语法:SETNX key value
EXISTS testStr11
SETNX testStr11 'maizi'
GET testStr11
SETNX testStr11 'maiziedu'
GET testStr11
127.0.0.1:6379> SETNX str11 'lewen'
(integer) 1
127.0.0.1:6379> get str11
"lewen"
127.0.0.1:6379> SET str11 '32'
OK
127.0.0.1:6379> SETNX str11 '434'
(integer) 0
127.0.0.1:6379> get str11
"32"
10
10
1
127.0.0.1:6379> SETNX str11 'lewen'
2
(integer) 1
3
127.0.0.1:6379> get str11
4
"lewen"
5
127.0.0.1:6379> SET str11 '32'
6
OK
7
127.0.0.1:6379> SETNX str11 '434'
8
(integer) 0
9
127.0.0.1:6379> get str11
10
"32"
10》SETEX:设置key并且设置其过期时间
语法:SETEX key seconds value
SETEX expireStr 60 'testExpire'
注意:SETEX是原子性操作,相当于执行了SET key value,又对这个key设置了过期时间EXPIRE key seconds
SET expireStr1 'test1'
EXPIRE expireStr1 10
SETEX test12 1000 'a'
GET test12
127.0.0.1:6379> SETEX str12 60 'testExpire'
OK
127.0.0.1:6379> TTL str12
(integer) 39
127.0.0.1:6379> ttl str12
(integer) 2
127.0.0.1:6379> ttl str12
(integer) -2
127.0.0.1:6379> get str12
(nil)
10
10
1
127.0.0.1:6379> SETEX str12 60 'testExpire'
2
OK
3
127.0.0.1:6379> TTL str12
4
(integer) 39
5
127.0.0.1:6379> ttl str12
6
(integer) 2
7
127.0.0.1:6379> ttl str12
8
(integer) -2
9
127.0.0.1:6379> get str12
10
(nil)
11》MSETNX:一次设置多个key-value对,只有所有的key都不存在的时候才会成功
语法:MSETNX key value [key value]
MSETNX test13 'a' test14 'b' test15 'c'
MSETNX test15 'aa' test16 'bb' test17 'cc'
12》PSETEX:以毫秒为单位设置key的生存周期
语法:PSETEX key milliseconds value
PSETEX test16 2000 'hello world'
PTTL
13》INCR:对key中存储的数字+1
语法:INCR key
SET counter 1
INCR counter
注意:key如果不存在,则会先初始化为0,在进行INCR操作
如果key存储的不是数字,会报错
INCR counter1
INCR test20
14》INCRBY:将key中存储的数字加上指定增量
语法:INCRBY key INCREMENT
SET counter2 10
INCRBY counter2 5
INCRBY counter2 1.2
127.0.0.1:6379> INCRBY num 3
(integer) 6
127.0.0.1:6379> get num
"6"
4
4
1
127.0.0.1:6379> INCRBY num 3
2
(integer) 6
3
127.0.0.1:6379> get num
4
"6"
15》INCRBYFLOAT:给key中存储的数字加上指定的浮点数
语法:INCRBYFLOAT key increment
SET counter3 1
INCRBYFLOAT counter3 1.2
16》DECR:将key中存储的数字减1
语法:DECR key
DECR counter3
17》DECRBY:将key中存储的数值减去指定的值
语法:DECRBY key decrement
DECRBY counter2 3
127.0.0.1:6379> DECRBY num 4
(error) ERR value is not an integer or out of range
127.0.0.1:6379> get num
"9.300000000000001"
127.0.0.1:6379> set num2 44
OK
127.0.0.1:6379> DECRBY num2 3
(integer) 41
127.0.0.1:6379> DECRBY num2 2.2
(error) ERR value is not an integer or out of range
10
1
127.0.0.1:6379> DECRBY num 4
2
(error) ERR value is not an integer or out of range
3
127.0.0.1:6379> get num
4
"9.300000000000001"
5
127.0.0.1:6379> set num2 44
6
OK
7
127.0.0.1:6379> DECRBY num2 3
8
(integer) 41
9
127.0.0.1:6379> DECRBY num2 2.2
10
(error) ERR value is not an integer or out of range
18》APPEND:通过APPEND将值追加到字符串的末尾
语法:APPEND key value
注意:如果key不存在,则相当于执行的SET操作
APPEND testStr11 'edu'
APPEND noExistsStr 'this is a test'
Hash类型
在配置文件中可以通过配置
hash-max-ziplist-entries 512 512字节
hash-max-ziplist-value 64 字段数目
Hash相关命令
1》HSET:将哈希表key中域field设置成指定的value
语法:HSET key field value
HSET userInfo1 username 'king'
HSET userInfo1 password '123456'
HSET userInfo1 email '382771946@qq.com'
HGET userInfo1 username
HSET userInfo1 username 'queen'
如果哈希表key中field不存在,相当于新建field,设置成功返回1
如果哈希表key中field存在,相当于重新赋值,成功返回0
2》HGET:返回哈希表key中给定field的值
语法:HGET key field
HGET userInfo1 username
注意:如果key中field不存在,返回的是nil
3》HSETNX:将hash表中的field设置成指定的值,只要field不存在的时候才可以成功;如果field存在,操作无效
语法:HSETNX key field value
HSETNX testHash1 test 'a'
4》HMSET:通过将多个field-value设置到hash表key中
语法:HMSET key field value field value ...
HMSET userInfo2 username 'king' password '123' kickname 'smart king' email '382771946@qq.com'
HGET userInfo2 username
HMSET userInfo2 username 'queen' role 'admin'
5》HMGET:一次获得hash表key中多个field的值
语法:HMGET key field field
注意:如果hash表key中field不存在,会返回nil
6》HGETALL:返回hash表key中所有的field和value
语法:HGETALL key
HGETALL userInfo2
7》HKEYS:返回hash中key的所有的field
语法:HKEYS key
HKEYS userInfo2
8》HVALS:返回hash中key中field所有的对应的值
语法:HVALS key
HVALS userInfo2
9》HEXISTS:检测hash中key的field是否存在
语法:HEXISTS key field
HEXISTS userInfo2 username
HEXISTS userInfo2 notExists
10》HLEN:返回hash表key中field的数量
语法:HLEN key
HLEN userInfo2
11》HINCRBY:给hash中key的field做增量操作
语法:HINCRBY key field increment
HSET userInfo3 age 12
HINCRBY userInfo3 age 10
HSET userInfo3 username 'king'
HINCRBY userInfo3 username 10
12》HINCRBYFLOAT:给hash中key的field做增量浮点操作
语法:HINCRBYFLOAT key field increment
HSET userInfo3 salary '123.111'
HINCRBYFLOAT userInfo3 salary 12.888
13》HDEL:删除hash中key的指定域,可以删除一个也可以删除多个
语法:HDEL key field field
HGETALL userInfo2
HDEL userInfo2 username password email
List类型
Set集合类型
Zset有序集合类型
keys相关的命令:
1》KEYS:返回所有符合给定模式的key
语法:KEYS pattern
*:匹配任意个字符
?:匹配一个任意字符
[]:匹配[]之间的一个字符,[b-e],a[b-e] ab ac ad ae
x:匹配特殊字符? *
MSET one 1 two 2 three 3 four 4 five 5 six 6 seven 7
KEYS *
KEYS *o*
KEYS t??
KEYS ?o*
KEYS c[n-z]*
2》EXISTS:检测指定key是否存在
语法:EXISTS key
EXISTS one
3》TYPE:返回key所存储的类型
语法:TYPE key
不存在的key 返回none
string
hash
set
zset
list
TYPE testStr11
TYPE userInfo2
4》EXPIRE:设置key的过期时间
语法:EXPIRE key seconds
SET cache_page 'http://phpfamily.org'
EXPIRE cache_page 100
注意:如果key已经存在过期时间,在通过EXPIRE设置的时候会覆盖之前过期时间
5》EXPIREAT:需要指定在指定时间戳过期
语法:EXPIREAT key timestamp
SET cache_page1 'http://maiziedu.com'
EXPIREAT cache_page1 1431868810
6》PEXPIRE:以毫秒的形式指定过期时间
语法:PEXIRE key milliseconds
SET cache_page2 'http://maiziedu.com'
PEXPIRE cache_page2 50000
7》PEXPIREAT:指定时间戳,单位为毫秒
语法:PEXPIREAT key timestamp
SET cache_page3 'http://phpfamily.org'
PEXPIREAT cache_page3 1431968810000000
8》TTL:以秒为单位返回key剩余时间
语法:TTL key
注意:如果没有key没有设置过期时间,返回-1
如果key不存在返回 -2
返回过期时间
SET cache_page4 'http://www.baidu.com'
TTL cache_page4
TTL cache_page5
EXPIRE cache_page4 100
TTL cache_page4
9》PTTL:以毫秒为单位返回key的剩余时间
语法:PTTL key
10》PERSIST:将一个带有过期时间的key转变成永久的key
语法:PERSIST key
SET cache 'testCache'
EXPIRE cache 100
TTL cache
PERSIST cache
TTL cache
11》DEL:删除指定的KEY
语法:DEL key ...
DEL cache
12》RANDOMKEY:随机的从当前数据库中返回一个key
语法:RANDOMKEY
RANDOMKEY
13》RENAME:重名名一个键
语法:RENAME key newkey
SET testRename1 'rename1'
RENAME testRename1 testRename2
RENAME testRename2 testRename2
RENAME testRename2 test14
RENAME test14 six
注意:如果名称没有发生改变会报错
14》RENAMENX:必须重命名这个新名称不存在才会生效
语法:RENAMENX key newkey
SET testRename 'test'
RENAMENX testRename six
15》DUMP:序列化给定的Key,返回序列化之后的值
语法:DUMP key
SET testDump 'this is a test'
DUMP testDump
16》RESTORE:反序列化
语法:RESTORE key tt1 value
RESTORE testDump1 0 "x00x0ethis is a testx06x00fx97x10x8boxb5x91xf8"
RESTORE testDump3 50000 "x00x04testx06x00x17}xc7 x99xa4x8cxd6"
17》MOVE:将当前数据库中的key移动到另外的数据库中
语法:MOVE key dbId
SELECT 0
SET testMove 'aaaa'
MOVE testMove 1
注意:当移动一个不存在的key会失败
当目录数据库中存在同名key的时候移动失败
OBJECT、MIGRATE、SCAN、SORT
List列表类型
1》LPUSH:向列表左端添加元素
语法:LPUSH key value value...
LPUSH myList1 a b c
2》RPUSH:向列表右端添加元素
语法:RPUSH key value ...
RPUSH myList1 test1 test2 test3
RPUSH myList1 test3 test4
3》LPUSHX:向列表头部添加元素,只有key存在在来添加
语法:LPUSHX key value
LPUSHX myList2 a
LPUSH myList2 a
LPUSHX myList2 b
4》RPUSHX:向列表尾部添加元素,只有key存在在来添加
语法:RPUSHX key value
5》LPOP:将列表头部的元素弹出
语法:LPOP key
LPOP myList1
6》RPOP;弹出列表尾部的元素
语法:RPOP key
RPOP myList1
7》LLEN:得到列表的长度
语法:LLEN key
LLEN myList2
8》LRANGE:获取列表片段
语法:LRANGE key start stop
LRANGE myList1 0 -1
注意:
如果start下标比列表的最大下标end大,返回的空列表
如果stop比列表长度大,返回到列表的末尾
9》LREM:删除列表中指定的值
语法:LREM key count value
count值有以下几种:
count>0:从列表的头开始,向尾部搜索,移除与value相等的元素,移除count个
count<=:从列表尾部向头搜索,移除与value相等的元素,移除count个
count=0,移除列表中所有与count相等的值
LPUSH myList2 a b c d a e b c d b e f b g e b
LREM myList2 2 b
LREM myList2 -2 a
LREM myList2 0 e
10》LINDEX:获得指定索引元素的值
语法:LINDEX key index
LINDEX myList2 3
LINDEX myList2 -3
11》LSET:设置指定索引元素的值
语法:LSET key index value
LSET myList2 0 king
12》LTRIM:只保留列表的片段
语法:LTRIM key start stop
LPUSH myList3 log11 log22 log33 log44 log55
LTRIM myList3 0 1
LPUSH myList4 a b c d e f g
LTRIM myList4 1 -1
LTRIM myList4 1 1000
LTRIM myList4 1000 2000 列表被清空
LTRIM myList4 3000 2000 列表被清空
13》LINSERT:向列表插入元素
语法:LINSERT key BEFORE|AFTER pivot value
LPUSH myList5 a b c d
LINSERT myList5 BEFORE 'b' 'king'
LINSERT myList5 BEFORE bb queen
LINSERT myList5 AFTER d queen
LINSERT myList6 AFTER d queen
14》RPOPLPUSH:将元素从一个列表转到另一个列表
语法:RPOPLPUSH source destination
LPUSH myList6 a b c
LPUSH myList7 x y z
RPOPLPUSH myList6 myList7
LPUSH webLog log1 log2 log3 log4
RPOPLPUSH webLog webLog
RPOPLPUSH webLog1 webLog
15》BLPOP:BLPOP 是LPOP的阻塞版本
语法:BLPOP key [key...] timeout
LPUSH myList9 a b c
LPUSH myList10 d e f
BLPOP myList8 myList9 myList10 0
BLPOP myList 8 0
set集合类型:无序集合
1》SADD:向集合中添加元素
语法:SADD key member [,...]
SADD web maiziedu.com
SADD web phpfamily.org jd.com
SADD web phpfamily.org taobao.com
2》SMEMBERS:返回指定集合中的元素
语法:SMEMBERS key
SMEMBERS web
3》SISMEMBER:检测member是否是集合中的成员
语法:SISMEMBER key member
SISMEMBER web maiziedu.com
4》SREM:删除集合中的一个或者多个成员
语法:SREM key member [member...]
SREM web jd.com
SREM web taobao.com phpfamily.org
5》SPOP:删除并返回集合中的随机元素
语法:SPOP key
SADD course php java ios android c c++ oc
SPOP course
6》SRANDMEMBER:随机返回集合中的元素
语法:SRANDMEMBER key count
注意:
count为正数,而且小于集合中的元素,返回的一个包含随机元素的集合数组;count数大于集合中元素的个数,这时候会返回整个集合
count为负数,返回一个数组,数组中的成员可能出现重复,数组的长度是count取绝对值
SRANDMEMBER course
SRANDMEMBER course 2
SRANDMEMBER course 50
SRANDMEMBER course -2
7》SDIFF:返回集合间的差集
语法:SDIFF key key ...
SADD testSet1 a b c d e
SADD testSet2 b c d e f
SDIFF testSet1 testSet2
SDIFF testSet2 testSet1
SADD testSet3 x y z a
SDIFF testSet1 testSet2 testSet3
8》SINTER:返回集合间的交集
语法:SINTER key key...
SINTER testSet1 testSet2
SINTER testSet1 testSet2 testSet3
SADD testSet3 b
9》SUNION:返回集合中并集操作
语法:SUNION key key...
SUNION testSet1 testSet2
SUNION testSet1 testSet2 testSet3
10》SCARD:返回集合中元素个数
语法:SCARD key
SCARD testSet1
11》SDIFFSTORE:将差集结果保存到指定集合中
语法:SDIFFSTORE destination key key ...
SDIFFSTORE diffSet testSet1 testSet2
SADD diffSet f
SDIFFSTORE diffSet testSet2 testSet1
SDIFFSTORE diffSet testSet1 testSet2
SDIFFSTORE testSet1 testSet1 testSet2
12》SINTERSTORE:将交集的结果保存在指定集合中
语法:SINTERSTORE destination key key ...
13》SUNIONSTORE:将并集的结果保存到指定集合中
语法:SUNIONSTORE destination key key ...
14》SMOVE:将集合中元素移动另外一个集合中
语法:SMOVE source destination member
注意:原子操作
SMOVE testSet2 testSet1 f
SADD testSet2 f
SMOVE testSet2 testSet1 f
zset(sorted set)有序集合
1》ZADD:将元素及其分数添加到集合中
语法:ZADD key score member [score member]
ZADD PHPScore 100 king
ZADD PHPScore 98 queen 98 maizi 80 test 78 test1 85 test2
ZADD PHPScore 60 test2 67 test3 56 test4
ZADD PHPScore +inf maxInt -inf minInx
2》ZSCORE:获得指定元素的分数
语法:ZSCORE key member
ZSCORE PHPScore maizi
ZADD PHPScore 12.3 test5
3》ZRANGE:按照元素分数从小到大的顺序返回指定索引start到stop之间所有元素(包含两端)
语法:ZRANGE key start stop [WITHSCORES]
ZRANGE PHPScore 0 -1
ZRANGE PHPScore 0 -1 WITHSCORES
ZRANGE PHPScore 0 2 WITHSCORES
ZRANGE PHPScore 0 2000 WITHSCORES
ZRANGE PHPScore 1000 2000 WITHSCORES
ZADD PHPScore 60 test6 60 test7 60 test8 60 test9
注意:当两个元素的分数相同的时候,Redis在排序按照字典的顺序(0<9<A<Z<a<z),如果使用的是UTF-8
的编码方式的中文同样按照字典顺序排列
4》ZREVRANGE:和ZRANGE相反,按照分数从大到小的顺序
语法:ZREVRANGE key start stop [WITHSCORES]
ZREVRANGE PHPScore 0 -1 WITHSCORES
5》ZRANGEBYSCORE:获得指定分数范围内的元素,按照分数从小到大的顺序,返回的是分数在指定的min到max的元素
语法:ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]
#获得分数80~90之间的所有元素
ZRANGEBYSCORE PHPScore 80 90
ZADD PHPScore 81 test9 82 test10 83 test11 84 test12 84 test13 88 test14 89 test15
ZRANGEBYSCORE PHPScore 80 90 WITHSCORES
ZADD PHPScore 90 test16
ZRANGEBYSCORE PHPScore 80 (90 WITHSCORES
ZRANGEBYSCORE PHPScore (80 (90 WITHSCORES
注意:通过(代表不包端点
ZRANGEBYSCORE PHPScore 90 +inf WITHSCORES
ZRANGEBYSCORE PHPScore 80 +inf WITHSCORES LIMIT 0 3
6》ZREVRANGEBYSCORE:获得指定分数范围内的元素,按照元素的分数从大到小的顺序返回min和max之间的元素
语法:ZREVRANGEBYSCORE key max min [WITHSCORES] [LIMIT offset count]
ZREVRANGEBYSCORE PHPScore 90 80 WITHSCORES
7》ZINCRBY:操作某个元素的分数,返回操作之后的分数
语法:ZINCRBY key increment member
ZINCRBY PHPScore 5 test16
ZINCRBY PHPScore -15 test16
8》ZCARD:获得集合中元素的数量
语法:ZCARD key
ZCARD PHPScore
9》ZCONUT:获得指定分数内的元素的数量
语法:ZCOUNT key min max
ZCOUNT PHPScore 80 90
10》ZREM:删除一个或者多个元素,返回删除元素的个数
语法:ZREM key member ...
ZREM PHPScore test16
11》ZREMRANGEBYRANK:按照排名范围删除元素,按照分数从小到大的顺序删除所指定的排名范围内的所有元素
语法:ZREMRANGEBYRANK key start stop
ZADD testRem 1 a 2 b 3 c 4 d 5 e 6 f 7 g 8 h
ZREMRANGEBYRANK testRem 0 2
12》ZREMRANGEBYSCORE:按照分数范围删除元素
语法:ZREMRANGEBYSCORE key min max
ZADD testRem1 1 a 2 b 3 c 4 d 5 e 6 f 7 g 8 h
ZREMRANGEBYSCORE testRem1 3 7
13》ZRANK:获得指定元素的排名,根据分数从小到大的顺序
语法:ZRANK key member
ZRANK PHPScore king
14》ZREVRANK:获得指定元素的排名,根据分数从大到小的顺序
语法:ZREVRANK key member
ZREVRANK PHPScore king
15》ZINTERSTORE:计算有序集合的交集,并将结果保存起来
语法:ZINTERSTORE destination numkeys [WEIGHTS weight weight...] [AGGREGATE SUM | MIN | MAX]
ZADD testSortedSet1 1 a 2 b 3 c
ZADD testSortedSet2 10 a 20 b 30 c
ZINTERSTORE resTestSorted1 2 testSortedSet1 testSortedSet2
ZINTERSTORE resTestSorted2 2 testSortedSet2 testSortedSet2 AGGREGATE SUM
ZINTERSTORE resTestSorted3 2 testSortedSet1 testSortedSet2 AGGREGATE MIN
ZINTERSTORE resTestSorted4 2 testSortedSet1 testSortedSet2 AGGREGATE MAX
ZINTERSTORE resTestSorted5 2 testSortedSet1 testSortedSet2 WEIGHTS 2 0.2
16》ZUNIONSTORE:计算有序集合并集,将结果保存起来
语法:ZUNIONSTORE destination numkeys key key ... [WEIGHTS weight weight...] [AGGREGATE SUM | MIN | MAX]
ZADD TESTUNIONSET1 1 a 2 b 3 c
ZADD TESTUNIONSET2 4 d 5 e 6 f 7 a
ZUNIONSTORE uniRes1 2 TESTUNIONSET1 TESTUNIONSET2
ZUNIONSTORE uniRes2 2 TESTUNIONSET1 TESTUNIONSET2 AGGREGATE SUM
ZUNIONSTORE uniRes3 2 TESTUNIONSET1 TESTUNIONSET2 AGGREGATE MIN
ZUNIONSTORE uniRes4 2 TESTUNIONSET1 TESTUNIONSET2 AGGREGATE MAX
ZUNIONSTORE uniRes5 2 TESTUNIONSET1 TESTUNIONSET2 WEIGHTS 2 2
二、Redis中的事务
1.开启事务
MULTI:开启事务,事务块中的多条语句会按照顺序放入对列当中,最后由EXEC命令来执行
MULTI
INCR counter1
INCR counter2
INCR counter3
PING
GET counter1
EXEC
2.执行事务块中的命令
EXEC:执行事务块中的命令
3.监视一个或者多个key
WATCH:监视一个或者多个key,如果在执行事务之前这个key如果被其它命令改动,事务就被打断了。
UNWATCH:取消WATCH命令对所有key的监视
4.取消事务
DISCARD
MULTI
SET testMulti 'this is a test'
INCR counter4
INCR counter5
DISCARD
5.事务中的错误处理
1》语法错误:像命令不存在,或者参数错误,如果有语法错误,Redis接到exec后直接返回错误,里面正确的命令也不会被执行
MULTI
SET test hello
SET test1
ERRORCOMMAND
2》运行错误,错误指在运行命令的时候出现的问题
MULTI
SET test2 1
SADD test2 2
SET test2 3
EXEC
三、连接相关
PING:测试和服务器之间是否连接有效,如果服务器运行正常的话会得到PONG
ECHO:打印一个特定信息
QUIT:请求服务器关闭与当前客户端的连接,EXIT
SHUTDOWN:关闭服务器和客户端
AUTH:指定Redis的身份验证,Redis配置文件中requirepass选项的值
CONFIG SET requirepass password
登陆进来之后通过AUTH命令进行验证
连接的时候-a pwd
SELECT:选择数据库
四、生存时间
EXPIRE/EXPIREAT
PEXPIRE/PEXPIREAT
PERSIST
TTL
PTTL
SET session:test1 uid1
EXPIRE session:test1 900
TTL session:test1
SET session:test2 uid2
EXPIRE session:test2 30
注意:使用SET GETSET也会清楚过期时间
SET key hello
EXPIRE key 100
TTL key
SET key world
TTL key
四、排序相关
SORT
1》按照键值从小到大或者从大到小的顺序排序
SORT key
SORT key DESC
对数值进行排序
LPUSH testSort1 12 33 -13 45 90
SORT testSort1 #升序
SORT testSort1 DESC #降序
对字母进行排序
LPUSH testSort2 a b c test1 test2 king queen zendStudio
SORT testSort2 ALPHA
2》使用LIMIT限制返回结果
LPUSH testSort3 a b c d e f g h i j k l m n 1 2 3 4 6 8 900 23
SORT testSort3 ALPHA LIMIT 0 5
SORT testSort3 ALPHA LIMIT 0 5 DESC
3》根据外部key的权重进行排序
LPUSH uid 1
SET user_name_1 admin
SET user_level_1 9999
LPUSH uid 2
SET user_name_2 king
SET user_level_2 800
LPUSH uid 3
SET user_name_3 queen
SET user_level_3 600
LPUSH uid 4
SET user_name_4 jack
SET user_level_4 300
LPUSH uid 5
SET user_name_5 rose
SET user_level_5 860
SORT uid
SORT uid BY user_level_*
4》根据排序结果取出相应键值
SORT uid GET user_name_*
SORT uid BY user_level_* GET user_name_*
SORT uid GET user_name_* GET user_level_*
SORT uid GET # GET user_level_* GET user_name_*
SORT uid BY user_level_* GET # GET user_level_* GET user_name_*
SORT uid BY noExists
SORT uid BY noExists GET # GET user_level_* GET user_name_*
HMSET user_info_1 username admin level 1000
HMSET user_info_2 username king level 999
HMSET user_info_3 username king1 level 77
HMSET user_info_4 username king2 level 90
SORT uid BY user_info_*->level
SORT uid GET user_info_*->username
SORT uid BY user_info_*->level GET # GET user_info_*->username
5》将排序结果保存起来
RPUSH testSort4 1 2 5 8 9 20
RPUSH testSort4 43 56 90 120
SORT testSort4 DESC STORE sortRes4
SORT key [BY pattern] [LIMIT offset count] [GET pattern [GET pattern]] [ASC|DESC|ALPHA] [STORE destination]
注意:
SORT命令的时间复杂度O(n+mlogm),n表示要排序的列表或者集合中的元素的个数,m表示要返回元素的个数
1》尽可能减少带排序中键的数量(使n尽可能的小)
2》使用LIMIT参数限制获取元素的个数(使m尽可能小)
3》如果要排序的数据量比较大,尽可能通过STORE缓存结果
五、发布订阅模式
PUBLISH/SUBSCRIBE
1》发布订阅模式的原理
包含两个角色,一个是发布者,一个是订阅者
订阅者可以订阅一个或者多个频道channel
发布者可以向指定频道发布信息
通过PUBLISH发布消息
PUBLISH channel message
PUBLISH channel1.1 'maiziedu'
通过SUBSCRIBE命令订阅频道
SUBSCRIBE channel ...
注意:发布出去消息是不会被持久化,只有客户端订阅这个频道之后才能收到之后发送消息
UNSUBSCRIBE 取消某个频道订阅,但是在REDIS客户端中做了限制 没有办法进行验证
UNSUBSCRIBE [channel]
PSUBSCRIBE 订阅指定的规则
UNPSUBSCRIBE
六、管道技术
七、通过PHP操纵Redis
PRedis和phpredis,使用Predis做演示,要求PHP版本要大于5.3
https://github.com/phpredis/phpredis/downloads
1.下载安装Redis
2.解压,将解压文件放到PHP的ext目录中
3.配置PHP配置文件,php.ini,按照
extension=php_igbinary.dll
extension=php_redis.dll
4.保存,重启服务器即可