• 10.27-Redis-mz 深入浅出Redis



    深入浅出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.保存,重启服务器即可








  • 相关阅读:
    波卡(Polkadot)创始人Gavin Wood眼中加密世界
    DOT的目的是什么
    如何在波卡测试网上起验证人节点
    Polkadot波卡链众筹成本价与总量、创始人团队简介
    Polkadot验证节点的安全性和可用性
    RSA算法详解
    haproxy+keepalived原理特点
    haproxy+keepalived原理特点
    haproxy+keepalived原理特点
    python基础1习题练习
  • 原文地址:https://www.cnblogs.com/fadewalk/p/13068557.html
Copyright © 2020-2023  润新知