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