redis 学习(常用命令及demo)
2015-04-29 16:20
591 查看
redis
NOSQL 介绍:是一项全新的数据库革命性运动,是一个非关系型数据库,在超大规模和高并发的SNS类型网站中应用广泛。
NoSql是以key-value形式存储,特点是:非关系型、分布式、开源的水平可扩展。
特点优势:
处理超大量数据
运行在便宜pc集群上
击碎了性能瓶颈
应用场景:
1. 对数据高并发读写
2. 对海量数据的高效率存储和访问
3. 对数据的高可扩展性和高可用性
redis
Redis is an open source, BSD licensed, advanced key-value cache and store. It is often referred to as a data structure server since keys can contain strings, hashes, lists, sets, sorted sets, bitmaps and hyperloglogs.
redis是一个开源的,先进的key-value缓存存储。它常作为缓存数据库,键可包含字符串、哈希、链表、集合(有序&无序)
支持 push/pop add/move 以及集合的操作,数据保存在内存中,会周期写入硬盘中。
redis数据类型:
string hash list set zset
string是最简单的类型,一个key对应一个value,string类型是二进制安全的。redis的string可以包括任何数据,比如jpg或者序列化的对象。
String类型:
1.设置key的value(set)127.0.0.1:6379> set key pm OK 127.0.0.1:6379> get key "pm" 127.0.0.1:6379>
2.如果不存在设置(setnx)
127.0.0.1:6379> setnx key df (integer) 0 127.0.0.1:6379> get key "pm"
3.设置键的有效期(setex 10s有效期)
127.0.0.1:6379> setex key 10 value OK 127.0.0.1:6379> get key "value" 127.0.0.1:6379> get key (nil) 127.0.0.1:6379>
4.设置替换(setrange)
127.0.0.1:6379> set key pmx@gmail.com OK 127.0.0.1:6379> get key "pmx@gmail.com" 127.0.0.1:6379> setrange key 4 qq (integer) 13 127.0.0.1:6379> get key "pmx@qqail.com" 127.0.0.1:6379>
5.一次性设置多个key(mset)
127.0.0.1:6379> mset key1 value1 key2 value2 key3 value3 OK 127.0.0.1:6379> get key1 "value1" 127.0.0.1:6379> get key2 "value2" 127.0.0.1:6379> get key3 "value3" 127.0.0.1:6379>
6.如果不存在设置(msetnx),如果有一个不成功(已存在),全部失效。
127.0.0.1:6379> msetnx key4 value4 key5 value5 (integer) 0 127.0.0.1:6379>
7.获得旧值并设置新值
127.0.0.1:6379> get key4 "value4" 127.0.0.1:6379> getset key4 kkkk "value4"
8.截取字符并返回(getrange)
127.0.0.1:6379> get key "pmx@qqail.com" 127.0.0.1:6379> 127.0.0.1:6379> 127.0.0.1:6379> getrange key 0 2 "pmx" 127.0.0.1:6379>
9.批量返回数据(mget)
127.0.0.1:6379> mget key1 key2 kye3
10.递增/递减(incr incrby/decr decrby)
127.0.0.1:6379> incrby key 10 (integer) 11 127.0.0.1:6379> incrby key 10 (integer) 21
11.追加value & 查看字符串长度
127.0.0.1:6379> append key 10 (integer) 4 127.0.0.1:6379> get key "2110" 127.0.0.1:6379> strlen key (integer) 4 127.0.0.1:6379>
2.hashes类型:
hash一个string类型的field和value的映射表。它的添加、删除操作都是O(1),特别适合存储对象。
1.设置hash field(hset)
127.0.0.1:6379> hset user:001 name pmx (integer) 1
2.如果不存在设置(hsetnx)与setnx类似
127.0.0.1:6379> hsetnx user:001 name mm (integer) 0 127.0.0.1:6379> hget user:001 name "pmx"
3.批量设置多个field、得到多个field(hmset,hmget)
127.0.0.1:6379> hmset user:001 name mx age 17 OK 127.0.0.1:6379> hget user:001 name "mx" 127.0.0.1:6379> hmget user:001 name age 1) "mx" 2) "17"
4.给指定hash field加上固定值(hincrby)
127.0.0.1:6379> hincrby user:001 age 8 (integer) 25
5.判断field是否存在(hexists)得到field个数(hlen)删除field
127.0.0.1:6379> hexists user:001 age (integer) 1 127.0.0.1:6379> hlen user:001 (integer) 2 127.0.0.1:6379> hdel user:001 age (integer) 1 127.0.0.1:6379> hlen user:001 (integer) 1
6.得到hash的所有 字段 & 值 &得到所有(hkeys & hvals & hgetall)
127.0.0.1:6379> hmset user:002 key1 value1 key2 value2 key3 value3 OK 127.0.0.1:6379> hkeys user:002 1) "key1" 2) "key2" 3) "key3" 127.0.0.1:6379> hvals user:002 1) "value1" 2) "value2" 3) "value3" 127.0.0.1:6379> hgetall user:002 1) "key1" 2) "value1" 3) "key2" 4) "value2" 5) "key3" 6) "value3"
3.list类型
1.左压栈(lpush)右压栈(rpush) 左出栈(lpop)右出栈(rpop)(可以作队列用)插入(linsert)127.0.0.1:6379> lpush mystack world (integer) 1 127.0.0.1:6379> lpush mystack hello (integer) 2 127.0.0.1:6379> lpop mystack "hello" 127.0.0.1:6379> lpop mystack "world" 127.0.0.1:6379> lpush mystack hello (integer) 1 127.0.0.1:6379> lpush mystack world (integer) 2 127.0.0.1:6379> rpop mystack "hello" 127.0.0.1:6379> rpop mystack "world" 127.0.0.1:6379> lpush mystack kkkk (integer) 1 127.0.0.1:6379> linsert mystack before kkkk jjjj (integer) 2 127.0.0.1:6379> lrange mystack 0 -1 1) "jjjj" 2) "kkkk" 127.0.0.1:6379>
2.设置list中指定下标的元素值(lset)(仿数组)删除(lrem)
注:lrem n value n<0时 从尾删除,n=0时全部删除
127.0.0.1:6379> lrange mystack 0 -1 1) "jjjj" 2) "kkkk" 127.0.0.1:6379> lset mystack 0 mmmm OK 127.0.0.1:6379> lrange mystack 0 -1 1) "mmmm" 2) "kkkk" 127.0.0.1:6379> lrange mystack 0 -1 1) "one" 2) "one" 3) "one" 4) "mmmm" 5) "kkkk" 127.0.0.1:6379> lrem mystack 2 one (integer) 2
3.保留指定key的值范围内的数据(ltrim)
127.0.0.1:6379> lrange mystack 0 -1 1) "jjjj" 2) "mmmm" 3) "kkkk" 127.0.0.1:6379> ltrim mystack 1 -1 OK 127.0.0.1:6379> lrange mystack 0 -1 1) "mmmm" 2) "kkkk" 127.0.0.1:6379>
4.从第一个list尾部移除元素并添加第二个list的头部(rpoplpush)
127.0.0.1:6379> rpoplpush mystack mystack1 "kkkk" 127.0.0.1:6379> 127.0.0.1:6379> 127.0.0.1:6379> lrange mystack 0 -1 1) "mmmm" 127.0.0.1:6379> lrange mystack1 0 -1
5.返回名称为key的list中index位置的元素(lindex)
127.0.0.1:6379> lrange mystack 0 -1 1) "ssdsd" 2) "kkld" 3) "mmmm" 127.0.0.1:6379> lindex mystack 2 "mmmm"
6.返回key对应list的长度(llen)
127.0.0.1:6379> llen mystack (integer) 3
4.sets类型
set是集合,string类型的无序集合, set是通过hash table实现的,添加、删除和查找的复杂度都是O(1)。对集合可以取并集、交集、查集。sns好友推荐取差集推荐。1.向集合中添加元素。(sadd)查看集合元素(smembers)
127.0.0.1:6379> sadd myset one (integer) 1 127.0.0.1:6379> sadd myset two (integer) 1 127.0.0.1:6379> sadd myset one (integer) 0 127.0.0.1:6379> smembers myset 1) "two" 2) "one"
2.删除集合中元素(srem)
127.0.0.1:6379> srem myset one (integer) 1
3.随机返回并删除一个元素(spop)
127.0.0.1:6379> smembers myset 1) "two" 2) "three" 3) "one" 127.0.0.1:6379> spop myset "one"
4.返回两个集合的差集(sdiff)以第一个为标准(可以做sns好友推荐)
127.0.0.1:6379> smembers myset 1) "two" 2) "three" 127.0.0.1:6379> smembers myset1 1) "two" 2) "lll" 3) "kkk" 127.0.0.1:6379> sdiff myset myset1 1) "three" 127.0.0.1:6379> sdiff myset1 myset2 1) "two" 2) "lll" 3) "kkk"
5.返回两个集合的差集并存储(sdiffstore)
127.0.0.1:6379> sdiffstore myset2 myset1 myset (integer) 2
6.返回所有给定key的交集(sinter)以及存储(sinterstore)
127.0.0.1:6379> sinter myset1 myset2 1) "lll" 2) "kkk" 127.0.0.1:6379> sinter myset1 myset2 myset (empty list or set) 127.0.0.1:6379> sinterstore myset4 myset1 myset2 (integer) 2 127.0.0.1:6379> smembers myset4 1) "lll" 2) "kkk"
7.返回所有给定key的并集(sunion)以及存储(sunionstore)
127.0.0.1:6379> sadd myset1 myset1 (integer) 1 127.0.0.1:6379> sadd myset2 myset2 (integer) 1 127.0.0.1:6379> sunionstore myset myset1 myset2 (integer) 2 127.0.0.1:6379> smembers myset 1) "myset2" 2) "myset1" 127.0.0.1:6379>
8.从第一个key对应的set中移除member并添加到第二个set中(smove)
127.0.0.1:6379> smove myset1 myset2 myset1 (integer) 1 127.0.0.1:6379> smembers myset1 (empty list or set) 127.0.0.1:6379> smembers myset2 1) "myset2" 2) "myset1"
9.返回名称为key集合中元素的个数(scard)判断某元素是否为集合元素(sismember)
127.0.0.1:6379> scard myset (integer) 2 127.0.0.1:6379> smembers myset 1) "myset2" 2) "myset1" 127.0.0.1:6379> sismember myset myset (integer) 0 127.0.0.1:6379> sismember myset myset1 (integer) 1
10.随机删除名称为key的set的一个元素,不删除(srandmember)
127.0.0.1:6379> srandmember myset "myset1" 127.0.0.1:6379> srandmember myset "myset2" 127.0.0.1:6379> srandmember myset "myset2"
5.有序结合(zset)
sorted set是set的一个升级版本,它在set的基础上增加了一个顺序属性,这一属性在添加元素时可以指定,每次指定后,zset会自动重新按照新的值调整顺序。1.向有序集合中添加元素(zadd)
127.0.0.1:6379> zadd myset 1 one (integer) 1 127.0.0.1:6379> zadd myset 2 two (integer) 1 127.0.0.1:6379> zadd myset 3 two (integer) 0 127.0.0.1:6379> zrange myset 0 -1 withscores 1) "one" 2) "1" 3) "two" 4) "3"
删除名称为key的zset中元素的member(zrem)
127.0.0.1:6379> zrem myset one (integer) 1 127.0.0.1:6379> zrange myset 0 -1 1) "two"
3.如果在名称为key的zset中已经存在元素member,则该元素的score增加increment,否则向该集合中添加该元素,其score的值为increment(zincrby)
127.0.0.1:6379> zincrby myset 2 one "4" 127.0.0.1:6379> zrange myset 0 -1 withscores 1) "two" 2) "3" 3) "one" 4) "4" 127.0.0.1:6379> zincrby myset -2 one "2"
4.返回名称为key的zset中member元素的排名(按score从小到大排序[下标]值)(zrank)以及反转(zrevrank)降序
127.0.0.1:6379> zrange myset 0 -1 withscores 1) "one" 2) "2" 3) "two" 4) "3" 127.0.0.1:6379> zrank myset two (integer) 1 127.0.0.1:6379> zrevrank myset one (integer) 1
zrangebyscore
127.0.0.1:6379> zrangebyscore myset 2 2 withscores 1) "one" 2) "2"
6.返回集合中score在给定区间的数量(zcount)
127.0.0.1:6379> zcount myset 2 5 (integer) 2
7.返回集合中元素个数
127.0.0.1:6379> zcount myset 2 5 (integer) 2
8.返回集合中所有元素个数(zcard)
127.0.0.1:6379> zcard myset (integer) 2
9.删除集合中排名在给定区间的元素(zremrangebyrank)(zremrangebyscore)
127.0.0.1:6379> zrange myset 0 -1 withscores 1) "one" 2) "2" 3) "two" 4) "3" 5) "five" 6) "5" 127.0.0.1:6379> zremrangebyrank myset 2 2 (integer) 1 127.0.0.1:6379> zrange myset 0 -1 1) "one" 2) "two" 127.0.0.1:6379> zremrangebyscore myset 2 2 (integer) 1 127.0.0.1:6379> zrange myset 0 -1 1) "two"
键值相关命令:
1.keys * 得到所有键
2.exists 是否存在键
3.del 删除key
expire 设置一个key过期时间(ttl查看过期时间)移除key的过期时间(persist)
127.0.0.1:6379> set age 20 OK 127.0.0.1:6379> 127.0.0.1:6379> expire age 10 (integer) 1 127.0.0.1:6379> ttl age (integer) 8 127.0.0.1:6379> ttl age (integer) -2 127.0.0.1:6379> get age (nil) 127.0.0.1:6379[1]> set age 20 OK 127.0.0.1:6379[1]> expire age 20 (integer) 1 127.0.0.1:6379[1]> persist age (integer) 1
5.移动数据库
127.0.0.1:6379> select 0 OK 127.0.0.1:6379> set age 20 OK 127.0.0.1:6379> get age "20" 127.0.0.1:6379> move age 1 (integer) 1 127.0.0.1:6379> get age (nil) 127.0.0.1:6379> select 1 OK 127.0.0.1:6379[1]> get age "20"
6.随机返回一个key(randomkey)
127.0.0.1:6379> randomkey "posts:count" 127.0.0.1:6379> randomkey "post:43" 127.0.0.1:6379> randomkey "post:content"
7.重命名key(rename )
127.0.0.1:6379> rename key2 key_new OK
8.返回值的类型(type)
127.0.0.1:6379> type post string 127.0.0.1:6379> type car hash 127.0.0.1:6379> type list none 127.0.0.1:6379> type myset zset 127.0.0.1:6379> type mylist list
9.测试服务是否存活 (ping) 打印显示 (echo)退出(quit)
127.0.0.1:6379> ping PONG
10.返回当前数据库中key的数目(dbsize)服务器信息(info)
127.0.0.1:6379> dbsize (integer) 22 127.0.0.1:6379> info # Server redis_version:3.0.0 redis_git_sha1:00000000 redis_git_dirty:0 redis_build_id:3946449f969be394 redis_mode:standalone
11.实时存储收到的请求(config get [*] )
12.删除当前选择数据库中的所有key(flushdb)
13.清除所有数据库所有key(flushall)
redis高级应用
1.安全性(设置连接密码,尽量复杂,放置暴力破解,[每分钟可达到150w次密码尝试])
1.在redis.conf中设置requirepass 123456
2.redis-cli 中连接1. ./redis-cli -a 123456 2. ./redis-cli –>auth
2.主从复制
1.redis主从复制特点
1.Master可以复制多个slave
2.多个slave可以连接同一个master,还可以连接其他slave
3.主从复制不会阻塞master,在同步数据时,master可以继续处理client。
4.提高系统的伸展性
2.配置主从服务器:
1.在slave中redis.conf开启slaveof 192.168.1.1 6379
2.masterauth 123456
3.info 查看主从(role)
3. 事务处理(multi)不回滚
1.开启事务multi
2.取消事务discard
[注]乐观锁:大多数是基于数据版本的记录机制实现的。即为数据增加一个版本标识,在基于数据库表的版本解决方案中,一般是通过为数据库表添加一个version字段来实现读取数据时,将此版本号一同读出,之后更新时,对此版本号加1。此时,将提交数据的版本号与数据库表对应纪录的当前版本号进行比对,如果提交的数据版本号大于数据库当前版本号,则予以更新,否则认为过期数据。[版本控制器]
3.持久化机制
redis是一个支持持久化的内存数据库,redis需要经常讲内存中的数据库同步到硬盘来保持持久化。
redis持久化有两种:
1.snapshootting(快照,默认dump.rdb,数据)
save 900 1 #900秒如果超过1个key被修改,发起快照保存
save 300 10 #300秒内容如超过10个key被修改,发起保存快照
2.append-only file(缩写aof,操作)
appendonly yes//启用aof模式 #appendfsync always //收到写命令立即写入磁盘,完全持久话 appendonly everysec//每秒写入磁盘一次,在性能上折中 #appendfsync no//依赖os 性能最好,持久化没保证
3.发布与订阅消息(publish & subscribe)
client 1 127.0.0.1:6379> subscribe tv1 client 2 127.0.0.1:6379> subscribe tv1 client 3 127.0.0.1:6379> publish tv1 qwe (integer) 2 127.0.0.1:6379> subscribe tv1 Reading messages... (press Ctrl-C to quit) 1) "subscribe" 2) "tv1" 3) (integer) 1 1) "message" 2) "tv1" 3) "qwe"
4.虚拟内存的使用
redis的虚拟内存和操作系统虚拟内存不一样,是把不经常访问的数据从内存交换到磁盘中,从而腾出宝贵的内存空间用于其他需要访问的数据。
1.配置
vm-enabled yes #开启vm功能
vm-swap-file /tmp/redis.swap #交换出来的value保存文件路径
vm-max-memory 100000 #redis使用最大内存上线
vm-page-size 32 #每个页面大小32字节
vm-pages 134217728 #最多使用多少页面
vm-max-threads 4 #用于执行value对象换入的工作线程数量
really-use-vm yes
相关文章推荐
- Redis学习笔记二:Redis的常用操作命令
- 分布式缓存技术redis学习系列(二)——详细讲解redis数据结构(内存模型)以及常用命令
- 分布式缓存技术redis学习系列(二)——详细讲解redis数据结构(内存模型)以及常用命令
- redis常用命令----- redis学习(2)
- Redis 学习笔记--数据类型常用命令
- 王高利:CentOS6.5下redis安装部署配置指南、常用命令、主从同步集群、redis-php学习资料整合详解
- 分布式缓存技术redis学习系列(二)——详细讲解redis数据结构(内存模型)以及常用命令
- Redis学习(二)- 常用命令
- Redis 学习 (三) 常用命令
- 分布式缓存技术redis学习系列(二)——详细讲解redis数据结构(内存模型)以及常用命令
- Redis学习笔记~常用命令总结
- CentOS6.5下redis安装部署配置指南、常用命令、主从同步集群、redis-php学习资料整合详解
- Redis数据库的学习与实践—Redis的常用命令及高级应用
- 【学习Redis】- 散列(哈希)类型和常用命令
- 【学习Redis】- 列表类型和常用命令
- redis 常用命令学习1
- 【学习Redis】- 字符串类型和常用命令
- Redis数据库的学习与实践—Redis的常用命令及高级应用
- Redis 常用命令学习笔记
- Redis学习笔记二:Redis的常用操作命令