我正在开发一个“任务控制系统”,它允许用户输入任务描述信息,包括何时执行任务以及任务需要什么环境(操作系统、浏览器等)。
“控制器”保存描述信息并安排任务。当预定时间到达时,调度程序检索任务信息并将任务“排队”以匹配所需环境的远程机器。
我的第一个切入点是使用关系数据库来保存任务描述和足够的历史信息来跟踪问题(大约 2 周的时间)。但这不是“大数据”问题,关系很简单,我需要更好的性能。
所以我正在寻找能提供更多性能的东西。我正在尝试为此使用redis,但我遇到了一些问题。我正在为客户端使用 ServiceStack.Redis 版本 3.9.71.0,而 Redis 2.8.4 是服务器。
此示例代码取自 Dan Swain 的教程。它已更新为与 ServiceStack.Redis 客户端 v 3.9.71.0 一起使用。大部分都有效,但 'currentShippers.Remove(lameShipper);' 不工作。谁能明白为什么会这样?
谢谢
public void ShippersUseCase()
{
using (var redisClient = new RedisClient("localhost"))
{
//Create a 'strongly-typed' API that makes all Redis Value operations to apply against Shippers
var redis = redisClient.As<Shipper>();
//Redis lists implement IList<T> while Redis sets implement ICollection<T>
var currentShippers = redis.Lists["urn:shippers:current"];
var prospectiveShippers = redis.Lists["urn:shippers:prospective"];
currentShippers.Add(
new Shipper
{
Id = redis.GetNextSequence(),
CompanyName = "Trains R Us",
DateCreated = DateTime.UtcNow,
ShipperType = ShipperType.Trains,
UniqueRef = Guid.NewGuid()
});
currentShippers.Add(
new Shipper
{
Id = redis.GetNextSequence(),
CompanyName = "Planes R Us",
DateCreated = DateTime.UtcNow,
ShipperType = ShipperType.Planes,
UniqueRef = Guid.NewGuid()
});
var lameShipper = new Shipper
{
Id = redis.GetNextSequence(),
CompanyName = "We do everything!",
DateCreated = DateTime.UtcNow,
ShipperType = ShipperType.All,
UniqueRef = Guid.NewGuid()
};
currentShippers.Add(lameShipper);
Dump("ADDED 3 SHIPPERS:", currentShippers);
currentShippers.Remove(lameShipper);
.
.
.
}
}
通过将这些覆盖添加到“Shipper”类来解决问题:
public override bool Equals(object obj)
{
if (obj == null)
{
return false;
}
var input = obj as Shipper;
return input != null && Equals(input);
}
public bool Equals(Shipper other)
{
return other != null && (Id.Equals(other.Id));
}
public override int GetHashCode()
{
return (int)Id;
}