一. 键的生存时间

  1. expire设置一个已经存在的key的生存时间,到时间后redis自动删除这个<k,v>
  2. 命令
  1. expire 设置生存时间(单位/秒)
  2. pexpire设置生存时间(单位/毫秒)
  3. ttl/pttl 查看键的剩余生存时间
  4. persist 取消生存时间
  5. expireat [key] unix时间戳1351858600
  6. pexpireat [key] unix时间戳(毫秒)1351858700000
  1. [注]:应用场景:
  2. 1)限时优惠活动
  3. 2)网站数据缓存,一定时间后更新数据
  4. 3)限制网站访客频率 eg:每分钟最多访问10次)

二. redis事务

  1. 事务控制原理 :

    当事务开启后, 一条redis操作语句不会立刻执行,而是先缓存起来, 等到事务内的语句全部缓存后, 再一起执行

    事务控制,使得一组操作不被其他线程的操作插入, 并且保持所有语句全部执行或全部不执行
  2. 操作

    multi 事务开始

    exec 事务结束,开始执行事务中的命令

    discard 放弃事务
  1. 127.0.0.1:6379> multi #开启事务
  2. OK
  3. 127.0.0.1:6379> set aaa 1
  4. QUEUED
  5. 127.0.0.1:6379> lpush aaa 4
  6. QUEUED
  7. 127.0.0.1:6379> get aaa
  8. QUEUED
  9. 127.0.0.1:6379> exec #执行事务,结果如下
  10. 1) OK
  11. 2) (error) WRONGTYPE Operation against a key holding the wrong kind of value
  12. 3) "1" # 上一条操作失败,但这一条操作成功
  1. [注] : redis在缓存命令时, 会检查命令的语法是否正确(编译时异常),发现编译时异常,redis的事务会让这一组操作全部失败
  2. 但是, redis发生运行时异常时,只是这句运行时异常的命令执行失败,而事务里的其他命令会执行成功.
  3. 因为,redis没有事务回滚机制,当缓存数据时没发现语法错误,则redis默认命令全部正确(例入lpush str1 a不被检查出来),逐条执行

三. watch

  1. 作用 :

    当一个客户端连接用watch监控一个变量,随后multi开启事务,在事务开启且未被执行时,若监控的变量值发生变化,则该客户端开启的事务执行失败,exec命令返回nil
  2. exec执行事务后,watch操作自动失效
  3. unwatch取消监控

    [注]: watch不提供通至客户端回调,只是一次性的控制事务是否被执行

四. Jedis

  1. /**
  2. * jedis连接池
  3. */
  4. public class RedisTool {
  5. private static JedisPool pool = null;
  6. private static String host;
  7. private static int port;
  8. public static synchronized Jedis getJedis(){
  9. if(pool==null){
  10. JedisPoolConfig config = new JedisPoolConfig();
  11. config.setMaxTotal(100);
  12. config.setMaxIdle(10);
  13. config.setMaxWaitMillis(10000);
  14. config.setTestOnBorrow(true);
  15. pool = new JedisPool(config,host,port,10000);
  16. }
  17. System.out.println("获取链接中。。");
  18. Jedis jedis = pool.getResource();
  19. System.out.println("链接获取成功");
  20. return jedis;
  21. }
  22. public static void setHostandPort(String host,int port){
  23. RedisTool.host = host;
  24. RedisTool.port = port;
  25. }
  26. public static void returnJedis(Jedis jedis){
  27. pool.returnResourceObject(jedis);
  28. }
  29. }

3. redis的超时,事务,watch的更多相关文章

  1. Redis系列之key操作命令与Redis中的事务详解(六)

    序言 本篇主要目的有二: 1.展示所有数据类型中key的所有操作命令,以供大家学习,查阅,更深入的挖掘redis潜力. 2.掌握redis中的事务,让你的数据完整性一致性拥有更优的保障. redis命 ...

  2. redis中的事务

    首先明白在java中线程和进程的区别: 1.什么是多线程? 是指一个应用程序同时执行多个任务,一般来说一个任务就是一个线程 ,而一个应用程序有一个以上的线程我们称之为多线程. 2.什么是进程? 进程是 ...

  3. 高并发场景系列(一) 利用redis实现分布式事务锁,解决高并发环境下减库存

    原文:http://blog.csdn.net/heyewu4107/article/details/71009712 高并发场景系列(一) 利用redis实现分布式事务锁,解决高并发环境下减库存 问 ...

  4. 第四节:Geo类型介绍以及Redis批量操作、事务、分布式锁

    一. Geo类型 1. 类型说明 Geo 是 Redis 3.2 版本后新增的数据类型,用来保存兴趣点(POI,point of interest)的坐标信息.可以实现计算两 POI 之间的距离.获取 ...

  5. 利用redis实现分布式事务锁,解决高并发环境下库存扣减

    利用redis实现分布式事务锁,解决高并发环境下库存扣减   问题描述: 某电商平台,首发一款新品手机,每人限购2台,预计会有10W的并发,在该情况下,如果扣减库存,保证不会超卖 解决方案一 利用数据 ...

  6. Redis 中的事务

    Redis支持简单的事务 Redis与mysql事务的对比 Mysql Redis 开启 start transaction muitl 语句 普通sql 普通命令 失败 rollback 回滚 di ...

  7. Redis 学习(三) —— 事务、消息发布订阅

    一.Redis事务 Redis 提供的事务机制与传统的数据库事务有些不同,传统数据库事务必须维护以下特性:原子性(Atomicity), 一致性(Consistency),隔离性(Isolation) ...

  8. Redis数据库 02事务| 持久化| 主从复制| 集群

    1. Redis事务 Redis不支持事务,此事务不是关系型数据库中的事务: Redis事务是一个单独的隔离操作:事务中的所有命令都会序列化.按顺序地执行.事务在执行的过程中,不会被其他客户端发送来的 ...

  9. 三、redis系列之事务

    1. 绪言 Redis也提供了事务机制,可以一次执行多个命令,本质是一组命令的集合.一个事务中的所有命令都会序列化,按顺序地串行化执行而不会被其他命令插入,不许加塞.但Redis对事务的支持是部分支持 ...

随机推荐

  1. Android开发优化

    一:Android性能优化之渲染篇 1.双层LinearLayout重叠用一个RelatayLout替代布局 二:Android性能优化之运算篇 1.float比较时间是int的4倍,尽量使用int类 ...

  2. 【渗透测试学习平台】 web for pentester -2.SQL注入

    Example 1 字符类型的注入,无过滤 http://192.168.91.139/sqli/example1.php?name=root http://192.168.91.139/sqli/e ...

  3. HTML 常见代码整合;

    html+css代码 文本设置 1.font-size: 字号参数 2.font-style: 字体格式 3.font-weight: 字体粗细 4.颜色属性 color: 参数 注意使用网页安全色 ...

  4. ZOJ-3929 Deque and Balls (DP+找规律)

    题目大意:n个数,每个数的大小都在1~n之间.操作n次,第 i 次将第 i 个数放到一个双端队列里面,放到队列两端的概率是相等的.问操作n次之后双端队列中元素满足xi>xi+1的对数的期望,输出 ...

  5. oh-my-zsh的使用

    一.自动安装wget https://github.com/robbyrussell/oh-my-zsh/raw/master/tools/install.sh -O - | sh 二.配置文件~/. ...

  6. URL 正则表达式

    (http|ftp|https):\/\/[\w\-_]+(\.[\w\-_]+)+([\w\-\.,@?^=%&:/~\+#]*[\w\-\@?^=%&/~\+#])? From h ...

  7. Android TextView换行问题

    本文转载于:http://niufc.iteye.com/blog/1729792 ndroid的TextView在显示文字的时候有个问题就是一行还没显示满就跳到下一行,原因是: 1) TextVie ...

  8. Wireshark抓包实例分析TCP重复ACK与乱序

    转载请在文首保留原文出处: EMC 中文支持论坛https://community.emc.com/go/chinese 介绍 TCP 的一大常见问题在于重复 ACK 与快速重传.这一现象的发生也是由 ...

  9. 论文笔记之:Asynchronous Methods for Deep Reinforcement Learning

    Asynchronous Methods for Deep Reinforcement Learning ICML 2016 深度强化学习最近被人发现貌似不太稳定,有人提出很多改善的方法,这些方法有很 ...

  10. PHP-线程一直不释放调试

    一.现象 1.查看进程是否存在 ps -ef | grep -v 'grep' |grep -E 'shell/cron/bonus/cash' www      2624    1  0 Oct24 ...