[C#] 用ServiceStack读写redis的性能问题

时间:2015-02-26 18:38:33   收藏:0   阅读:486



ServiceStack.Redis有个方法叫 AddRangeToList,这个方法是有性能问题的。这个方法的实现代码如下:

public void AddRangeToList(string listId, List<string> values)
{
	var uListId = listId.ToUtf8Bytes();

	var pipeline = CreatePipelineCommand();
	foreach (var value in values)
	{
		pipeline.WriteCommand(Commands.RPush, uListId, value.ToUtf8Bytes());
	}
	pipeline.Flush();

	//the number of items after 
	var intResults = pipeline.ReadAllAsInts();
}

这样实际上是把N条数据转换成了N条命令。redis那边要一条一条命令的解析执行,性能会下降很多。


正确的做法是使用批量RPUSH。参见:http://redis.readthedocs.org/en/latest/list/rpush.html


改用批量RPUSH之后,AddRangeToList的性能可以提高一两个数量级。







原文:http://blog.csdn.net/wwwsq/article/details/43954539

评论(0
© 2014 bubuko.com 版权所有 - 联系我们:wmxa8@hotmail.com
打开技术之扣,分享程序人生!