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



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的性能可以提高一两个数量级。







你可能感兴趣的:([C#] 用ServiceStack读写redis的性能问题)