本文共 5885 字,大约阅读时间需要 19 分钟。
内存的读写速度远远高于硬盘。如果能够把数据放在内存中,那么数据的读写效率就会有一很大的提升。
在程序开发中,如果需要频繁操作数据库中的一些数据,那么比较高效的做法是把这些数据先读出来,用一个或者多个变量来保存。程序只读一次数据库,之后直接操作变量。等到数据处理完成后,再将数据更新回原数据库或者插入新的数据库中。 在不同进程之间共享变量,虽然也可能做到,但是过程非常烦琐。 更不要说在不同机器之间共享变量了。所以,使用程序变量这种方式虽然读写速度快,却有很大的局限性。如果数据库的速度能快到即使频繁读写也不会影响程序的性能,那么在多个机器之间共享数据也变得轻而易举了。这就是Redis。 redis没有使用空字符串结尾的C字符串,而是自己构建了一种名为简单动态字符串的抽象类型(简称SDS) 通过使用 SDS 而不是 C 字符串,Redis 将获取字符串长度所需的复杂度从 O(N) 降低到了0 (1) ,这确保了获取字符串长度的工作不会成为Redis 的 性能瓶颈。例如,因为字符串键在底层使用SDS 来实现,所以即使我们对一个非常长的字符串键反复执行 STRLEN 命令,也不会对系统性能造成任何影响,因为STRLEN 命令的复杂度仅为 0 (1) 。Redis有多种数据结构,适合多种不同的应用场景。
1.使用Redis做缓存 Redis的字符串、哈希表两种数据结构适合用来储存大量的键值对信息,从而实现高速缓存。 2.使用Redis做队列 Redis有多几种数据结构适于做队列: ● 使用“列表”数据结构,可以实现普通级和优先级队列的功能。 ● 使用“有序集合”数据结构,可以实现优先级队列; ● 使用“哈希表”数据结构,可以实现延时队列。 3.使用Redis去重 Redis有多几种数据结构适于做去重: ● 利用“集合”数据结构,可以实现小批量数据的去重; ● 利用“字符串”数据结构的位操作,可以实现布隆过滤器,从而实现超大规模的数据去重; ● 利用Redis自带的HyperLogLog数据结构,可以实现超大规模数据的去重和计数。 4.使用Redis实现积分板 Redis的“有序集合”功能可以实现积分板功能,还能实现自动排序、排名功能。 5.使用Redis实现“发布/订阅”功能 Redis自带的“发布/订阅”模式可以实现多对多的“发布/订阅”功能。□ 键值对的键是一个字符串对象,对象的底层实现是一个保存着字符串 " msg " 的SDS。
□ 键值对的值也是一个字符串对象,对象的底层实现是一个保存着字符串 " he l lo world " 的 SDS。Redis 键命令用于管理 redis 的键。
语法
Redis 键命令的基本语法如下:redis 127.0.0.1:6379> COMMAND KEY_NAME
实例 redis 127.0.0.1:6379> SET w3ckey redis OK redis 127.0.0.1:6379> DEL w3ckey (integer) 1 在以上实例中 DEL 是一个命令, w3ckey 是一个键。 如果键被删除成功,命令执行后输出 (integer) 1,否则将输出 (integer) 0Redis keys 命令
下表给出了与 Redis 键相关的基本命令:序号 命令及描述
1 DEL key 该命令用于在 key 存在是删除 key。 2 DUMP key 序列化给定 key ,并返回被序列化的值。 3 EXISTS key 检查给定 key 是否存在。 4 EXPIRE key seconds 为给定 key 设置过期时间。 5 EXPIREAT key timestamp EXPIREAT 的作用和 EXPIRE 类似,都用于为 key 设置过期时间。 不同在于 EXPIREAT 命令接受的时间参数是 UNIX 时间戳(unix timestamp)。 6 PEXPIRE key milliseconds 设置 key 的过期时间亿以毫秒计。 7 PEXPIREAT key milliseconds-timestamp 设置 key 过期时间的时间戳(unix timestamp) 以毫秒计 8 KEYS pattern 查找所有符合给定模式( pattern)的 key 。 9 MOVE key db 将当前数据库的 key 移动到给定的数据库 db 当中。 10 PERSIST key 移除 key 的过期时间,key 将持久保持。 11 PTTL key 以毫秒为单位返回 key 的剩余的过期时间。 12 TTL key 以秒为单位,返回给定 key 的剩余生存时间(TTL, time to live)。 13 RANDOMKEY 从当前数据库中随机返回一个 key 。 14 RENAME key newkey 修改 key 的名称 15 RENAMENX key newkey 仅当 newkey 不存在时,将 key 改名为 newkey 。 16 TYPE key 返回 key 所储存的值的类型。incr key
对key的值做加加操作,并返回新的值。注意incr一个不是int的value会返回错误,incr一个不存在的key,则设置key为1。范围为64有符号, -9223372036854775808~9223372036854775807。 decr key 同上,但是做的是减减操作,decr一个不存在key,则设置key为-1 incrby key integer 同incr,加指定值 ,key不存在时候会设置key,并认为原来的value是 0用于序列化给定 key ,并返回被序列化的值。
redis DUMP 命令基本语法如下:
redis 127.0.0.1:6379> DUMP KEY_NAME
如果 key 不存在,那么返回 nil 。 否则,返回序列化之后的值。
实例
首先,我们在 redis 中创建一个 key 并设置值。redis> SET greeting “hello, dumping world!”
OK 现在使用 DUMP 序列化键值。redis> DUMP greeting
“\x00\x15hello, dumping world!\x06\x00E\xa0Z\x82\xd8r\xc1\xde”Redis EXISTS 命令用于检查给定 key 是否存在。
语法
redis EXISTS 命令基本语法如下:redis 127.0.0.1:6379> EXISTS KEY_NAME
Redis Expire 命令用于设置 key 的过期时间。key 过期后将不再可用。
语法
redis Expire 命令基本语法如下:redis 127.0.0.1:6379> Expire KEY_NAME TIME_IN_SECONDS
redis 127.0.0.1:6379> EXPIRE w3ckey 60
(integer) 1 以上实例中我们为键 w3ckey 设置了过期时间为 1 分钟,1分钟后该键会自动删除。 附: Redis命令有: Redis DEL 命令 Redis Dump 命令 Redis EXISTS 命令 Redis Expire 命令 Redis Expireat 命令 Redis PEXPIREAT 命令 Redis PEXPIREAT 命令 Redis Keys 命令 Redis Move 命令 Redis PERSIST 命令 Redis Pttl 命令 Redis TTL 命令 Redis RANDOMKEY 命令 Redis Rename 命令 Redis Renamenx 命令 Redis Type 命令 Redis 字符串(String) Redis SET 命令 Redis Get 命令 Redis Getrange 命令 Redis Getset 命令 Redis Getbit 命令 Redis Mget 命令 Redis Setbit 命令 Redis Setex 命令 Redis Setnx 命令 Redis Setrange 命令 Redis Strlen 命令 Redis Mset 命令 Redis Msetnx 命令 Redis Psetex 命令 Redis Incr 命令 Redis Incrby 命令 Redis Incrbyfloat 命令 Redis Decr 命令 Redis Decrby 命令 Redis Append 命令 Redis 哈希(Hash) Redis Hdel 命令 Redis Hexists 命令 Redis Hget 命令 Redis Hgetall 命令 Redis Hincrby 命令 Redis Hincrbyfloat 命令 Redis Hkeys 命令 Redis Hlen 命令 Redis Hmget 命令 Redis Hmset 命令 Redis Hset 命令 Redis Hsetnx 命令 Redis Hvals 命令 Redis 列表(List) Redis Blpop 命令 Redis Brpop 命令 Redis Brpoplpush 命令 Redis Lindex 命令 Redis Linsert 命令 Redis Llen 命令 Redis Lpop 命令 Redis Lpush 命令 Redis Lpushx 命令 Redis Lrange 命令 Redis Lrem 命令 Redis Lset 命令 Redis Ltrim 命令 Redis Rpop 命令 Redis Rpoplpush 命令 Redis Rpush 命令 Redis Rpushx 命令 Redis 集合(Set) Redis Sadd 命令 Redis Scard 命令 Redis Sdiff 命令 Redis Sdiffstore 命令 Redis Sinter 命令 Redis Sinterstore 命令 Redis Sismember 命令 Redis Smembers 命令 Redis Smove 命令 Redis Spop 命令 Redis Srandmember 命令 Redis Srem 命令 Redis Sunion 命令 Redis Sunionstore 命令 Redis Sscan 命令 Redis 有序集合(sorted set) Redis Zadd 命令 Redis Zcard 命令 Redis Zcount 命令 Redis Zincrby 命令 Redis Zinterstore 命令 Redis Zlexcount 命令 Redis Zrange 命令 Redis Zrangebylex 命令 Redis Zrangebyscore 命令 Redis Zrank 命令 Redis Zrem 命令 Redis Zremrangebylex 命令 Redis Zremrangebyrank 命令 Redis Zremrangebyscore 命令 Redis Zrevrange 命令 Redis Zrevrangebyscore 命令 Redis Zrevrank 命令 Redis Zscore 命令 Redis Zunionstore 命令 Redis Zscan 命令 Redis HyperLogLog Redis Pfadd 命令 Redis Pfcount 命令 Redis Pgmerge 命令 Redis 发布订阅 Redis Psubscribe 命令 Redis Pubsub 命令 Redis Publish 命令 Redis Punsubscribe 命令 Redis Subscribe 命令 Redis Unsubscribe 命令 Redis 事务 Redis Discard 命令 Redis Exec 命令 Redis Multi 命令 Redis Unwatch 命令 Redis Watch 命令 Redis 脚本 Redis Eval 命令 Redis Evalsha 命令 Redis Script Exists 命令 Redis Script Flush 命令 Redis Script kill 命令 Redis Script Load 命令 Redis 连接 Redis Auth 命令 Redis Echo 命令 Redis Ping 命令 Redis Quit 命令 Redis Select 命令 Redis 服务器 Redis Bgrewriteaof 命令 Redis Bgsave 命令 Redis Client Kill 命令 Redis Client List 命令 Redis Client Getname 命令 Redis Client Pause 命令 Redis Client Setname 命令 Redis Cluster Slots 命令 Redis Command 命令 Redis Command Count 命令 Redis Command Getkeys 命令 Redis Time 命令 Redis Command Info 命令 Redis Config Get 命令 Redis Config rewrite 命令 Redis Config Set 命令 Redis Config Resetstat 命令 Redis Dbsize 命令 Redis Debug Object 命令 Redis Debug Segfault 命令 Redis Flushall 命令 Redis Flushdb 命令 Redis Info 命令 Redis Lastsave 命令 Redis Monitor 命令 Redis Role 命令 Redis Save 命令 Redis Shutdown 命令 Redis Slaveof 命令 Redis Showlog 命令 Redis Sync 命令转载地址:http://stten.baihongyu.com/