ServiceStack.Redis的问题与修正

数据库 Redis
Redis是开源、高性能的Key-value存储引擎。最近我们在一个日访问量约1kw的网站上使用redis替换以前的memcache,成功将CPU从30%下降到15%,效果相当显著。

Redis是开源、高性能的Key-value存储引擎。

最近我们在一个日访问量约1kw的网站上使用redis替换以前的memcache,成功将CPU从30%下降到15%,效果相当显著。

ServiceStackRedis是***的C#驱动之一。关于如何使用ServiceStackRedis请参见这里——使用ServiceStackRedis链接Redis简介

不过我们在使用ServiceStackRedis的线程池(PooledRedisClientManager)还是碰到了不少问题。

1 链接数异常。

一个webserver会占用80个链接。当15台webserver就过千了,这时会出现有些客户端链接不上的情况。

解决方案:

GetInActiveWriteClient方法中

  1. //找下一个目标 
  2. //从当前读写指针的后面开始查找,而不是从0开始 
  3. var nextIndex = (WritePoolIndex + i) % writeClients.Length; 
  4. 更改为 
  5. var nextIndex = i; 

同时修改DisposeClient方法中将readClient.Active == false将DisposeConnection一下。线程就能很好的回收了。

效果:

在我们这样一个网站下,单台webserver大约会占用10个~15个链接,比之前的80个少了不少。

分析:

从代码上来看,作者的初衷是为了更快的找到空闲的线程,但是却认所有线程都不间断的使用,没有一个线程可能空闲。如果站点较小,webserver不太多,不改问题也不大。不过我认为用长链接并不划算,因为与redis建立一个链接还是相对比较“便宜”的。

2 多台redis存储相同的内容。

相同的内容会冗余在所有redis中

解决方案

在GetInActiveWriteClient中加入int型参数来标识出使用那台redis

  1. var start = 0
  2. var step = 1
  3. if (index > -1 && index < ReadWriteHosts.Count) 
  4.   start = index; 
  5.   step = ReadWriteHosts.Count; 
  6. //遍历读写池 
  7. //这个时候池是锁定的 
  8. for (var i = start; i < writeClients.Length; i += step) 
  9.   省略 

这样线程池中就会按ReadWriteHosts的个数来顺序分配。

效果:

在进行读写时只需要使用key.GetHashCode方法获得一个hash值就能准确分配到其中一台redis上。保证所有的redis的数据不重复。

原文链接:http://www.cnblogs.com/goodspeed/archive/2011/07/26/servicestack_redis_optimize.html

【编辑推荐】

  1. 几点建议,让Redis在你的系统中发挥更大作用
责任编辑:艾婧 来源: Goodspeed's Blog
相关推荐

2009-02-06 10:56:45

Windows 7漏洞UAC

2023-10-10 23:06:46

RedisMySQL

2023-10-08 13:10:00

Redis数据库

2009-11-12 09:42:51

Linux版本Linux问题修正

2023-10-13 12:05:55

RedisBig Key

2024-04-11 13:45:14

Redis数据库缓存

2020-07-17 21:15:08

Redis内存数据库

2021-10-13 10:32:37

算法Facebook技术

2022-06-06 09:56:38

编程语言Python

2019-10-23 09:00:06

Redis数据库

2020-09-21 14:15:58

Redis数据库命令

2014-05-13 15:00:59

2014-07-22 09:51:19

面板数据分析

2009-09-10 09:14:34

微软思科终修正TCP DoS漏洞

2020-03-26 11:04:00

Linux命令光标

2009-11-26 14:23:10

PHP正则模式修正符

2013-09-09 13:52:14

开放网络

2013-12-10 14:00:02

AndroidAndroid4.4Kitkat

2010-03-05 08:58:21

2014-03-18 13:27:55

Redis数据存储
点赞
收藏

51CTO技术栈公众号