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在给定区间的元素
- Redise 笔记
- Redise
- tomcat7 使用redise 保存session
- redise数据结构之之字符串和链表
- 笔记
- 笔记
- 笔记
- 笔记
- 笔记
- 笔记
- 笔记
- 笔记
- 笔记
- 笔记
- 笔记
- 笔记
- 笔记
- 笔记
- 深入理解PHP内核
- 链表原理
- 黑马程序员---银行业务调度系统
- 使用wordpress 建设公司网站
- 云计算是什么?
- Redise 笔记
- linux驱动开发-经典的系统调用BUG
- hdu 1814 字典序最小的2sat(暴力深搜)
- 对SplitAction Bar 的认识
- mysql_query()函数的返回值问题
- 企业该如何搭建论坛互动平台
- chengji
- 自定义事件:
- java.sql.SQLIntegrityConstraintViolationException: ORA-02291