Redise 笔记

来源:互联网 发布:淘宝售后是什么 编辑:程序博客网 时间:2024/05/16 11:37

Redis 是 Key -Value 型的内存数据库,其中Value可以是String、List、Set、Hash、Sorted Set等类型的数据结构。

Redis 的优点:

1.支持丰富的数据类型:如 String、List、Set、Hash、Sorted Set
2.支持两种数据持久化方式:Snapshotting(快照) 和 Append-Only file(追加)
3.支持主从复制

安装 与启动

1.1.编译安装

$ wget http://download.redis.io/releases/redis-2.8.9.tar.gz
$ tar xzvf redis-2.8.9.tar.gz
$ cd redis-2.8.9
$ make

为了方便可以将可执行文件复制到 /usr/local/bin ,配置文件复制到 /usr/local/etc/

主要命令说明:
redis-server:   Redis服务器的daemon启动程序
redis-cli:      Redis命令行操作工具。也可以用telnet根据其纯文本协议来操作
redis-benchmark:Redis性能测试工具,测试Redis在当前系统下的读写性能
redis-check-aof:数据修复

1.2. redis.conf配置选项如下

daemonize                是否以后台进程运行,默认为no
pidfile                          如以后台进程运行,则需指定一个pid,默认为/var/run/redis.pid
bind                             绑定主机IP,默认值为127.0.0.1(注释)
port                              监听端口,默认为6379
timeout                       超时时间,默认为300(秒)
loglevel                       日志记录等级,有4个可选值,debug,verbose(默认值),notice,warning
logfile                          日志记录方式,默认值为stdout
databases                 可用数据库数,默认值为16,默认数据库为0
save <seconds> <changes>  保存快照的频率,指出在多长时间内,有多少次更新操作,就将数据同步到数据文件。可设置多个条件
rdbcompression            存储至本地数据库时是否压缩数据,默认为yes
dbfilename                本地数据库文件名,默认值为dump.rdb
dir                               本地数据库存放路径,默认值为 ./

slaveof <masterip> <masterport>  当本机为从服务时,设置主服务的IP及端口(注释)
masterauth <master-password>    当本机为从服务时,设置主服务的连接密码(注释)
requirepass                       连接密码(注释)
maxclients                         最大客户端连接数,默认不限制(注释)
maxmemory <bytes>       设置最大内存,达到最大内存设置后,Redis会先尝试清除已到期或即将到期的Key
appendonly                       是否在每次更新操作后进行日志记录,如果不开启,可能会在断电时导致一段时间内的数据丢失。
appendfilename               更新日志文件名,默认值为appendonly.aof(注释)
appendfsync                     更新日志条件,共有3个可选值。no表示等操作系统进行数据缓存同步到磁盘,always表示每
                                            次更新操作后手动调用fsync()将数据写到磁盘,everysec表示每秒同步一次(默认值)。
vm-enabled                            是否使用虚拟内存,默认值为no
vm-swap-file                          虚拟内存文件路径,默认值为/tmp/redis.swap,不可多个Redis实例共享
vm-max-memory                   将所有大于vm-max-memory的数据存入虚拟内存

1.3. 启动

/usr/local/bin/redis-server /usr/local/etc/redis.conf

查看Redis是否启动:  ps -ef |grep redis  查看端口: netstat -tunpl |grep 6379


Key相关命令

exists key                 检测key是否存在
del key1 key2 …… keyN   删除指定key 返回删除key的数目,返回0表示key都不存在
type key                    返回给定key的value类型。返回none表示不存在的key
keys pattern            返回匹配指定模式下的所有key
expire key second             设定给定key的过期时间
randomkey                          返回从当前数据库中随机选择的一个key, 如果当前数据为空,返回空串
rename oldkey newkey     重命名key,如果newkey存在则被覆盖,返回1表示成功
renamenx oldkey newkey  同上,如果newkey存在返回失败
ttl key                                     返回设置过期时间key的剩余秒数,-1表示key不存在或者没有设置过期时间
move key db-index             将key从当前数据库移动到指定数据库,返回1成功

String 类型


String 类型是安全的二进制类型,为了提高网站的运行速度,可以使用String类型缓存一些静态文件,如图片文件,css文件

String 持的命令:
set key value                            设置key对应的String类型的值,成功返回1,失败返回0
setnx key value                         如果key不存在,设置key 的Sting 类型的值,如果key已经存在,返回0
get key                                        获取key 对应的String值
getset key value                       现获取key的值,再设置key的值。若key不存在返回nil
mset key1 value …… keyN valueN           一次设置多个key的值,成功返回1,表示所有值都设置,失败返回0,表示没有任何值被设置
mget key1 key2 …… keyN                          一次获取多个key的值,若key不存在返回nil
msetnx key1 value …… keyN valueN       一次设置多个key的值,但不会覆盖已存在的key
incr key                                                           向key对应的值+1并返回新的值。incr一个不是int的value返回错误,key不存在,key设置为1
decr key                                                          向key对应的值-1,decr不存在的一个key 则设置key值为-1
incrby  key integer                                        向key对应的值加上一个指定的整数 integer
decrby  key integer                                       向key对应的值减去一个指定的整数 integer

list 类型


List 数据类型指定key对应的value是一个双向链表结构,所以List类型提供链表支持的所有操作。

List类型数据操作指令:
lpush key string             在key对应list的头部添加字符串元素,返回1表示成功,0表示key存在且不是list类型。
rpush key string             在key对应list的尾部添加字符串元素。
llen key                            返回key对应list的长度,如果key不存在返回0,如果key对应类型不是list返回错误。
lrange keys tart end      返回指定区间内的元素,下标从0开始,负值表示从后面计算,-1表示倒数第一个元素,key不存在返回空列表。  
ltrim key start end          截取list指定区间内元素,成功返回1,key不存在返回错误。
lset  key index value      设置list中指定下标的元素值,成功返回1,key或者下标不存在返回错误。
lrem key count value     从 List 的头部(count正数)或尾部(count负数)删除一定数量(count)匹配value的元素, 返回删除的元素数量。count为0时候删除全部。
lpop key                           从list的头部删除并返回删除元素。如果key对应list不存在或者是空返回nil
rpop key                           从list的尾部删除并返回删除元素。
blpop key1……keyN timeout     从左到右扫描,返回对第一个非空list进行lpop操作并返回。比如blpop list1 list2 list3 0 ,
                                                        如果list1不存在list2,list3都是非空则对list2做lpop并返回从list2中删除的元素。如果所有的list
                                                        都是空或不存在,则会阻塞timeout 秒,timeout为0表示一直阻塞。当阻塞时,如果有client对key1...keyN中的任意key进行push操作,则第一

                                                       在 这个key上被阻塞的client会立即返回。如果超时发生, 则返回 nil。有点像unix的select或者poll。
brpop key1……keyN timeout   同blpop,一个是从头部删除一个是从尾部删除。 

3.3 Hash 类型


Hash类型是每个key对应一个HashTable,添加、删除和修改操作的时间复杂度都是O(1),Hash类型适合用于存储对象,例如用户信息对象,把ID作为key,可以把用户信息保存到Hash 类型中

Hash 类型数据操作指令:


hset key field value               设置key对应的Hash对象中指定域的值。如果key对应的Hash对象不存在,将创建此Hash对象。
                                                  如果指定域的值存在,其值则会被覆盖
hget key field                          获取指定的hash field。
hmget key filed1...fieldN      获取全部指定的 hash filed。
hmset key filed1 value1...filedN valueN    同时设置hash的多个field。
hincrby key field integer                               将指定的hashfiled 加上指定值。成功返回hashfiled变更后的值。
hexists key field          检测指定field是否存在。
hdel keyfield                删除指定的hash field。
hlen  key                      返回指定hash的field数量。
hkeys key                    返回hash的所有field。
hvals key                     返回hash的所有value。
hgetall key                  返回hash的所有filed和value 


Set 类型

Set 类型是一种无序集合,在Redis 内部通过HashTable实现,添加、删除和修改操作的时间复杂度都是O(1)。Set数据类型的优点是快速查找元素是否存在,用于记录一些不能重复的数据。

Set 类型数据操作指令:

sadd key member                添加一个String 元素到key对应的set集合中,成功返回1,如果元素在集合中返回0,key对应的set不在返回错误
srem key member                从key对应的set中移除给定元素。
spop key                                 删除并返回key对应set中随机的一个元素,如果set是空或者key对应的set不存在返回nil
srandmember key                同spop,随机取出一个set中的元素,单数不删除元素
smove srckey dstkey member     从srckey 对应的set 中移除member 并添加大dstkey 对应的set中
scard key                                         返回set的元素个数,如果set是空或者key不存在返回0
sismember key member            判断member是否在set中,存在返回1.
sinter key1 key2 keyN                  返回所有给定key的交集
sinterstore dstkey key1……keyN      同 sinter,同时将交集放到dstkey对应的set集合中
sunion key1 key2……keyN                返回所有给定key的并集。
sunionstore dstkey key1……keyN   返回所有给定key的并集,并保存并集到dstkey下。
sdiff key1 key2……keyN                     返回所有给定key的差集。
sdiffstore dstkey key1……keyN        返回所有给定key的差集,并保存差集到dstkey下。
smembers key                                    返回key对应set的所有元素,结果是无序的。

Sorted Set 类型

Sorted Set 类型和Set类型类似,都是String类型的元素集合,不同的是,Sorted Set 属于有序的集合,而Sorted Set 通过一个double 类型的整数score 进行排序。

Sorted Set 类型数据操作指令:

zadd key score member           添加元素member到集合,元素在集合中存在则更新对应的score
zrem key member                 删除指定元素,1表示成功,如果元素不存在返回0
zincrby key incr member         增加对应member的score 值,并且重新排序,返回更新后的score
zrank key member                返回直指定元素在集合中的排名(下标),集合中元素按score 从小到大排序的
zrevrank key member             同上,但是集合中的元素是从大到小排的
zrange key start end            从集合中指定区间的元素,返回结果按score顺序排序
zrevrange key start end         同上,返回结果按score逆序排序
zrangebyscore key min max       返回集合中score在给定区间的元素、
zcount key min max              返回集合中score在给定区间的数量
zcard key                       返回集合中元素的个数
zscore key element              返回给定元素对应的score
zremrangebyrank key min max     删除集合中排名在给定区间的元素
zremrangebyscore key min max    删除集合中score在给定区间的元素


1 1
原创粉丝点击