Redis(二) 扩展
事务
multi ... exec 之间的操作先进入等待队列,到exec时一起执行
事物的所有操作结果都是一起返回的,所以前一条指令的结果无法作为后一条指令的参数
其中的指令有语法错误时,都不执行;有“类型不匹配”等逻辑错误时,只执行对的指令;没有回滚
watch 监控一个或多个key 一旦监控的键值有修改,其后的事务就不执行
监控范围:从开始监控到事务执行之前(实际上是从watch到exec,
但是由于multi...exec之间的指令是在exec这个点一起执行的,所以看上去是从watch到multi)
生存时间
expire key seconds 设置key的生存时间为seconds秒(该键在seconds秒后自动删除)
ttl key 查看键key的剩余生存时间
persist key 该键持久化
##在生存时间相关的指令前加p(pexpire pttl),时间单位变为毫秒
expireat key unixtime 设置该键在unixtime时自动删除
可以设置在内存到达规定时,键的自动删除策略
{如:对所有键执行LRU;对设置了生存时间的键执行LRU;在内存满了时报错;对所有键随机删除;对设置了生存时间的键随机删除}
排序
sort s/l/z 返回从小到大的序列(有序集合是对元素自身的值进行排列)(若元素是纯字符串,报错)
sort s/l/z ALPHA 按字典序输出纯字符串
加 DESC 参数 倒序输出
加 limit 1 2 参数 带偏移量 输出数量
加 by (by 后可接 String、hashmap)
形如:sort s/l/z by item:*->time *是将sort序列循环一遍代替* ->是按hashmap中time排序
sort s/l/z by item:* 字符串
注:当要排序值相等时 按元素自身值排序 不存在该排序值默认为0
by后面可加get(可加多个)#代表循环值
形如:sort tag:ruby:posts by post:*->time DESC
get post:*->time get #
get后可加store 将结果保存在列表中,并返回列表长度
形如:sort tag:ruby:posts by post:*->time DESC
get post:*->time get # store sort:result
sort很容易成为性能瓶颈 O(n+mlogm)n为要排序的数据总量 m为要返回的个数
消息通知
brpop lkeyA [lkeyB ...] time (time为等待时长,0为无限等待 )
当多个等待队列都没有值时,等待,若等了time还没值,就返回nil
当都有值时,前面的队列 优先取
返回值是个数组 [0]为返回队列的名称 [1]返回的内容
订阅、发布模式
发布消息:public channel message 返回值为收到消息者的数量
订阅频道:subscribe channel (可以订阅多个频道,进入订阅模式后,只能使用订阅相关指令)
订阅模式三种返回值:
“subscribe” “频道名称” “你共订阅了几个频道”
“message” “频道名称” “消息内容”
“unsubscribe” “频道名称” “你剩余几个频道”
unsubscribe [channel ...] 若未指定 频道名 会取消订阅所有频道
还可以订阅一类频道 如:psubscribe item:*
Redis(二) 扩展的更多相关文章
- php7对redis的扩展及redis主从搭建
这两天在学习一下php7下面的安装及redis相关配置认识.并将笔记记下来.以备后用.主要涉及到redis的扩展php-redis 及redis主从的配置. 一:redis安装 1:下载并安装 ...
- nginx/php的redis模块扩展
redis模块介绍 redis2-nginx-module 可以实现 Nginx 以非阻塞方式直接防问远方的 Redis 服务,可以启用强大的 Redis 连接池功能,进而实现更多的连接与更快速的访问 ...
- inux redis 安装配置, 以及redis php扩展
一,什么是redis redis是一个key-value存储系统. 和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合)和zset ...
- 【转】php7对redis的扩展及redis主从搭建
一:redis安装 1:下载并安装 cd /home/software wget http://download.redis.io/releases/redis-3.2.3.tar.gz ta ...
- redis php扩展安装下载
php的redis 扩展下载地址 Windows :http://windows.php.net/downloads/pecl/releases/redis/2.2.7/ 下载对应版本,一般有两个 n ...
- redis和redis php扩展安装(转)
redis是一个内存数据库,比memcache支持更丰富的value类型,新浪微博就使用redis来做缓存. redis的源码安装 wget http://download.redis.io/redi ...
- redis php扩展及基本命令
linux 安装php mysql redis memchache 等工具 用 OneinStack 安装步骤 注意 如果有单独数据盘,建议您先挂载数据盘,建议将网站内容.数据库放在数据盘中.如何挂载 ...
- redis水平扩展实践,完全配置,无需代码改动
设计思路 思路很简单,就是基于用户ID进行分库,将用户的ID字符串按照byte逐个计算ID对应的hash原值(一个数字,取绝对值,因为原始值可能过大溢出,变成负数),然后,再用这个hash原值对库的个 ...
- 分布式数据存储 之 Redis(二) —— spring中的缓存抽象
分布式数据存储 之 Redis(二) -- spring中的缓存抽象 一.spring boot 中的 StringRedisTemplate 1.StringRedisTemplate Demo 第 ...
- 深入理解MVC C#+HtmlAgilityPack+Dapper走一波爬虫 StackExchange.Redis 二次封装 C# WPF 用MediaElement控件实现视频循环播放 net 异步与同步
深入理解MVC MVC无人不知,可很多程序员对MVC的概念的理解似乎有误,换言之他们一直在错用MVC,尽管即使如此软件也能被写出来,然而软件内部代码的组织方式却是不科学的,这会影响到软件的可维护性 ...
随机推荐
- [HDU 4336] Card Collector (状态压缩概率dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4336 题目大意:有n种卡片,需要吃零食收集,打开零食,出现第i种卡片的概率是p[i],也有可能不出现卡 ...
- cocos2dx day 1
原文:http://www.cocos2d-x.org/programmersguide/2/index.html 一.Basic Concepts 1.director 2.scene 2.1 sc ...
- disposition
该文为堕落的天使不再来原创.欢迎转载. 在尽心web开发时,可能遇到以下几种需求:(disposition配置) 希望某类或者某已知MIME 类型的文件(比如:*.gif;*.txt;*.htm)能够 ...
- 1、NASA Super Cloud Library(SCL)
Empowering Data Management, Diagnosis, and Visualization of Cloud-Resolving Models (CRM) by Cloud Li ...
- MAGIC XPA最新版本Magic xpa 2.4c Release Notes
New Features, Feature Enhancements and Behavior ChangesSubforms – Behavior Change for Unsupported Ta ...
- Arch Linux PDF格式文件无法显示中文
From: http://blog.sina.com.cn/s/blog_5e54bc6801012gfg.html $ sudo pacman -S poppler-data
- [ json editor] 如何在网页中使用Json editor 插件
[目的] 在自己的网页上交由用户进行json的可视化编辑 [难点]1.json中含有递归嵌套的数组和对象 2.json中的基本值类型有数字.字符串和布尔型 [方法]使用daviddurman的Flex ...
- reverse iterator
Problem 1: vector<int> coll = { 1, 2, 3, 4, 5, 6, 7, 8, 9 }; vector<int>::const_iterator ...
- Dynamic V Strongly Typed Views
Come From https://blogs.msdn.microsoft.com/rickandy/2011/01/28/dynamic-v-strongly-typed-views/ There ...
- js处理url参数
var UrlArgent = { Parsed: false, //是否已解析 Cache: {}, //缓存值 ParseArg: function () { // 解析地址栏的参数值 UrlAr ...