跳到主要内容
版本:0.17

Schema 演进

Apache Fory™ C# 在 Compatible(true) 模式下支持 Schema 演进。

兼容模式

Fory fory = Fory.Builder()
.Compatible(true)
.Build();

兼容模式会写入类型元信息,使结构体定义不同的读写端也能互操作。

示例:新增一个字段

using Apache.Fory;

[ForyObject]
public sealed class OneStringField
{
public string? F1 { get; set; }
}

[ForyObject]
public sealed class TwoStringField
{
public string F1 { get; set; } = string.Empty;
public string F2 { get; set; } = string.Empty;
}

Fory fory1 = Fory.Builder().Compatible(true).Build();
fory1.Register<OneStringField>(200);

Fory fory2 = Fory.Builder().Compatible(true).Build();
fory2.Register<TwoStringField>(200);

byte[] payload = fory1.Serialize(new OneStringField { F1 = "hello" });
TwoStringField evolved = fory2.Deserialize<TwoStringField>(payload);

// F2 falls back to default value on reader side.
System.Diagnostics.Debug.Assert(evolved.F1 == "hello");
System.Diagnostics.Debug.Assert(evolved.F2 == string.Empty);

带版本校验的 Schema 一致模式

如果你需要严格的 Schema 身份校验,而不是演进行为:

Fory strict = Fory.Builder()
.Compatible(false)
.CheckStructVersion(true)
.Build();

这种模式会在 schema hash 不匹配时抛出异常。

最佳实践

  1. 对独立部署的服务启用 Compatible(true)
  2. 在不同版本之间保持稳定的 type ID。
  3. 新增字段时提供安全的默认值。
  4. 如果要求严格匹配,使用 CheckStructVersion(true)

相关主题