之前有写过一篇介绍c#操作redis的文章 http://www.cnblogs.com/axel10/p/8459434.html ,这篇文章中的案例使用了StringIncrement来实现了高并发情况下key值的稳定增加,但如果要用锁的方式而不是StringIncrement方法,那该怎么做呢?

LockTake涉及到三个参数:key,token和TimeSpan,分别表示redis数据库中该锁的名称、锁的持有者标识和有效时间。下面将用一个多线程增加key值的案例来演示LockTake/LockRelease的用法。

  1. using StackExchange.Redis;
  2. using StackExchange.Redis.Extensions.Core;
  3. using StackExchange.Redis.Extensions.Core.Configuration;
  4. using StackExchange.Redis.Extensions.Newtonsoft;
  5. using System;
  6. using System.Threading;
  7.  
  8. namespace RedisTest
  9. {
  10. class Program
  11. {
  12. static RedisValue Token = Environment.MachineName;
  13. static RedisKey Key = "lock";
  14.  
  15. static void Ins()
  16. {
  17. Thread thread = new Thread(() =>
  18. {
  19. for (int i = ; i < ; i++)
  20. {
  21.  
  22. if (client.Database.LockTake(Key, Token, TimeSpan.MaxValue)) //key表示的是redis数据库中该锁的名称,不可重复。 Token用来标识谁拥有该锁并用来释放锁。TimeSpan表示该锁的有效时间。
  23. {
  24. try
  25. {
  26. int key = client.Get<int>("key");
  27.  
  28. client.Add("key", key + );
  29. }
  30. catch (Exception e)
  31. {
  32. Console.WriteLine(e);
  33. throw;
  34. }
  35. finally
  36. {
  37. client.Database.LockRelease(Key, Token);
  38. }
  39. }
  40. else
  41. {
  42. Console.WriteLine("locking");
  43. while (!TryAgain())
  44. {
  45. Thread.Sleep();
  46. }
  47. }
  48. }
  49. });
  50. thread.Start();
  51. }
  52.  
  53. private static StackExchangeRedisCacheClient client;
  54.  
  55. static void Main(string[] args)
  56. {
  57. var redisConfiguration = new RedisConfiguration() //配置
  58. {
  59. Hosts = new RedisHost[]
  60. {
  61. new RedisHost() {Host = "127.0.0.1", Port = }
  62. }
  63. };
  64.  
  65. client = new StackExchangeRedisCacheClient(new NewtonsoftSerializer(), redisConfiguration);
  66. client.Add("key", );
  67.  
  68. for (int j = ; j < ; j++)
  69. {
  70. Ins();
  71. }
  72.  
  73. Thread.Sleep();
  74.  
  75. int i = client.Get<int>("key");
  76. Console.WriteLine(i);
  77. Console.ReadKey();
  78. }
  79.  
  80. static bool TryAgain(int value)
  81. {
  82. if (client.Database.LockTake(Key, Token, TimeSpan.MaxValue))
  83. {
  84. try
  85. {
  86. int key = client.Get<int>("key");
  87.  
  88. client.Add("key", key + value);
  89. }
  90. catch (Exception e)
  91. {
  92. Console.WriteLine(e);
  93. throw;
  94. }
  95. finally
  96. {
  97. client.Database.LockRelease(Key, Token);
  98. }
  99.  
  100. return true;
  101. }
  102. else
  103. {
  104. return false;
  105. }
  106. }
  107. }
  108. }

c# redis 利用锁(StackExchange.Redis LockTake)来保证数据在高并发情况下的正确性的更多相关文章

  1. Java高并发情况下的锁机制优化

    本文主要讲并行优化的几种方式, 其结构如下: 锁优化 减少锁的持有时间 例如避免给整个方法加锁 1 public synchronized void syncMethod(){ 2 othercode ...

  2. Redis 利用锁机制来防止缓存过期产生的惊群现象-转载自 http://my.oschina.net/u/1156660/blog/360552

    首先,所谓的缓存过期引起的“惊群”现象是指,在大并发情况下,我们通常会用缓存来给数据库分压,但是会有这么一种情况发生,那就是在一定时间 内生成大量的缓存,然后当缓存到期之后又有大量的缓存失效,导致后端 ...

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

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

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

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

  5. 【11】Redis .net 实例 StackExchange.Redis框架

    1.创建测试项目并下载nuget包:StackExchange.Redis PM> Install-Package StackExchange.Redis 2.创建 RedisHelper类 p ...

  6. Redis系列(一)StackExchange.Redis的使用

    Redis系列(一)StackExchange.Redis的使用 一.DLL安装 用NuGet搜索StackExchange.Redis,然后下载就可以. ConnectionMultiplexer对 ...

  7. Qunar机票技术部就有一个全年很关键的一个指标:搜索缓存命中率,当时已经做到了>99.7%。再往后,每提高0.1%,优化难度成指数级增长了。哪怕是千分之一,也直接影响用户体验,影响每天上万张机票的销售额。 在高并发场景下,提供了保证线程安全的对象、方法。比如经典的ConcurrentHashMap,它比起HashMap,有更小粒度的锁,并发读写性能更好。线程安全的StringBuilder取代S

    Qunar机票技术部就有一个全年很关键的一个指标:搜索缓存命中率,当时已经做到了>99.7%.再往后,每提高0.1%,优化难度成指数级增长了.哪怕是千分之一,也直接影响用户体验,影响每天上万张机 ...

  8. NET 5 MemoryCache与Redis使用以及StackExchange.Redis和CSRedisCore

    简介以及区别 ASP.NET Core 缓存Caching,.NET Core 中为我们提供了Caching 的组件. 目前Caching 组件提供了三种存储方式. Memory Redis SqlS ...

  9. Redis集群~StackExchange.redis连接Twemproxy代理服务器

    回到目录 本文是Redis集群系列的一篇文章,主要介绍使用StackExchange.Redis进行Twemproxy(文中简称TW)代理服务的连接过程,事务上,对于TW来说,我们需要理解一下它的物理 ...

随机推荐

  1. HDU:2846-Repository

    传送门:http://acm.hdu.edu.cn/showproblem.php?pid=2846 Repository Time Limit: 2000/1000 MS (Java/Others) ...

  2. 《鸟哥的Linux私房菜》学习笔记(7)——grep及正则表达式

    一.grep命令 grep:根据模式搜索文本,并将符合模式的文本行显示出来 模式:由文本字符和正则表达式的元字符组合成的匹配条件 命令格式:grep [options] [file...] [root ...

  3. WPF学习笔记(8):DataGrid单元格数字为空时避免验证问题的解决

    原文:WPF学习笔记(8):DataGrid单元格数字为空时避免验证问题的解决 如下图,在凭证编辑窗体中,有的单元格不需要数字,但如果录入数字后再删除,会触发数字验证,单元格显示红色框线,导致不能执行 ...

  4. EXCEL合并单元格快捷键暨WORD+EXCEL自定义快捷键

    最近在写测试用例时,用到合并单元格,只能点,没有快捷键,觉得很蛋疼,上网找了一下,没有直接设置其对应快捷键的方法,但有种曲线救国的方法: 一.右击功能区,选择‘自定义快速访问工具栏’   二.可以在这 ...

  5. Android 数据存储-文件读写操作

    本来已经写了一部分,后来发现这篇博客写的比我的好,就直接引用一下: https://www.cnblogs.com/LiHuiGe8/p/5604725.html

  6. Leetcode 500.键盘行

    键盘行 给定一个单词列表,只返回可以使用在键盘同一行的字母打印出来的单词.键盘如下图所示. 示例: 输入: ["Hello", "Alaska", " ...

  7. TextBox的值随dropdownlist值而变化

    转自:http://bytes.com/topic/asp-net/answers/443065-textbox-value-change-select-other-item-dropdownlist ...

  8. mvc-自定义视图引擎

    //自定义视图引擎的实质是把数据模型(moudle)和模板(View)转换成html页面,输出到客户端public class MyView:IView { string _viewPath; pub ...

  9. Vue2.0 - 构造器的延伸 Vue.extend

    Vue.extend 返回的是一个“扩展实例构造器”,也就是预设了部分选项的Vue实例构造器.经常服务于Vue.component用来生成组件,可以简单理解为当在模板中遇到该组件名称作为标签的自定义元 ...

  10. POJ 3321:Apple Tree(dfs序+树状数组)

    题目大意:对树进行m次操作,有两类操作,一种是改变一个点的权值(将0变为1,1变为0),另一种为查询以x为根节点的子树点权值之和,开始时所有点权值为1. 分析: 对树进行dfs,将树变为序列,记录每个 ...