4

谁能指出我的 NEventStore 3.0 的 protobuf-net 序列化程序?

我遇到了麻烦,我认为主要是由于事件存储 3 中的序列化将事件主体和标头包装在 EventMessage 中。

我不确定如何正确设置自定义序列化程序。

4

1 回答 1

3

基于对 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()

于 2013-04-05T07:15:40.473 回答