谁能指出我的 NEventStore 3.0 的 protobuf-net 序列化程序?
我遇到了麻烦,我认为主要是由于事件存储 3 中的序列化将事件主体和标头包装在 EventMessage 中。
我不确定如何正确设置自定义序列化程序。
谁能指出我的 NEventStore 3.0 的 protobuf-net 序列化程序?
我遇到了麻烦,我认为主要是由于事件存储 3 中的序列化将事件主体和标头包装在 EventMessage 中。
我不确定如何正确设置自定义序列化程序。
基于对 github 的简短浏览,这完全是未经测试的猜测,但看起来您想使用连线 API 来指定自定义序列化程序,例如:
var store = Wireup.Init()
.UsingSqlPersistence("Name Of EventStore ConnectionString In Config File")
.InitializeStorageEngine()
.UsingCustomSerialization(mySerializer)
... etc
wheremySerializer
是实现ISerialize
接口的类型的实例。看起来这应该有效:
class ProtobufSerializer : EventStore.Serialization.ISerialize
{
public void Serialize<T>(Stream output, T graph)
{
ProtoBuf.Serializer.Serialize<T>(output, graph);
}
public T Deserialize<T>(Stream input)
{
return ProtoBuf.Serializer.Deserialize<T>(input);
}
}
(所以显然mySerializer
这里将是一个new ProtobufSerializer()
)