04-Redis综述.pptVIP

  • 12
  • 0
  • 约 31页
  • 2017-03-26 发布于湖北
  • 举报
04-Redis综述

8个人 周一 set Mondaysetbit monday 0 1 setbit monday 2 1 setbit monday 7 1 结果: 1010001 周二 set Tuesdaysetbit Tuesday 1 1 setbit Tuesday 2 1 setbit Tuesday 3 1 结果: 0111000 * 基于内存亦可持久化的日志型数据库 Redis 赵渝强 collen7788@126.com Agenda Redis特点及安装 Redis键值操作 Redis数据类型 事务和锁机制 消息订阅 持久化 集群 Redis的Java客户端 运维 仿微博实战 Redis的特点和安装 Remote DIctionary Server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统。 Redis提供了一些丰富的数据结构 包括 lists, sets, ordered sets 以及 hashes , 还有和Memcached一样的 strings结构. Redis当然还包括了对这些数据结构的丰富操作。 Redis的高级特性 数据结构丰富 持久化 支持简单事务 主从配置方便 Redis的安装 安装: 不必configure make make PREFIX=/usr/local/redis install 启服务 ./redis-server /path/to/redis.conf Redis的连接 Redis的协议是基础文本的协议,(http,memcached也是)客户端的开发较为简便。 Redis官方提供了C,java,C#,PHP,lua脚本的客户端 我们在学习时,用到redis-cli 官方客户端及Java-Redis客户端 在与redis-server同一目录下,redis-cli即是 Redis的键值操作-1 操作 说明 keys pattern 支持*,?,[]匹配 randomkey 随机返回key,但不删除 exists key 判断key是否存在,返回1/0 type key 判断key的类型。返回string,set,zset,link,hash expire key 用秒设置生命周期 pexpire key 用毫秒设置生命周期 persist key 使key变为永久 ttl key 查询key的剩余生命周期(返回秒) pttl key 查询key的剩余生命周期(返回毫秒) 对于不存在的key或过期key,返回-1 redis2.8对于不存在的key返回-2 Redis的键值操作-2 操作 说明 DEL key [key ...] 删除多个key,返回真正被删除的key数量 rename key newkey 重命名key-newkey。如果newkey存在,值被覆盖 renamenx key newkey 同rename,只是newkey存在时,不进行操作 move key db 移动key到另一个db,如果另一db有相同key,不做操作 Redis的数据类型及命令 Redis的数据类型 字符串 链表 Hash(Map) 集合(无序、有序) 字符串类型 String:最基础的类型,二进制的数据 512M set 、get、append mset 、mget 、incr、decr 链表List lpush、lrange、lpop rpush、rrange、rpop Hash Map hset 、hget hmset hmget hgetall 集合 Set:无序的集合、不可重复 sadd 、smembers sdiff、sinter、sunion Sortedset:一个可以排序的集合,根据(scores)来排序 zadd 、zrange、zrangebyscore zrevrange、zrevrangebyscore Redis基本操作的经典案例 背景:网站用户的登录情况 问题: 1亿个用户。有经常登录的,有不经常登录的 如何记录用户的登录信息 如何来查询活用户,如一周登录3次的用户 Redis的事务和锁机制 watch key1 key2 unwtach [key1 key2 multi command command ... discard/exec 注意:如果命令格式有误,exec会报错 如果命令格式不错,只是逻辑错,exec不执行正确的命令---需要程序员去负责 Redis消息的发布和订阅 subscribe------频道----------publish subscribe news --订阅新闻频道 publish

文档评论(0)

1亿VIP精品文档

相关文档