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。参见: https://redis.io/commands/rpush
改用批量RPUSH之后,AddRangeToList的性能可以提高一两个数量级。