| title | sidebar_position | id | license |
|---|---|---|---|
Troubleshooting |
11 |
troubleshooting |
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
|
This page covers common issues and their solutions.
If you create Fory without setting CompatibleMode to org.apache.fory.config.CompatibleMode.COMPATIBLE, and you get a strange serialization error, it may be caused by class inconsistency between the serialization peer and deserialization peer.
In such cases, you can invoke ForyBuilder#withClassVersionCheck to create Fory to validate it. If deserialization throws org.apache.fory.exception.ClassNotCompatibleException, it shows classes are inconsistent, and you should create Fory with ForyBuilder#withCompatibleMode(CompatibleMode.COMPATIBLE).
// Enable class version check to diagnose issues
Fory fory = Fory.builder()
.withLanguage(Language.JAVA)
.withClassVersionCheck(true)
.build();
// If ClassNotCompatibleException is thrown, use compatible mode
Fory fory = Fory.builder()
.withLanguage(Language.JAVA)
.withCompatibleMode(CompatibleMode.COMPATIBLE)
.build();Note: CompatibleMode.COMPATIBLE has more performance and space cost. Do not set it by default if your classes are always consistent between serialization and deserialization.
Use serialize with one of the deserialize overloads:
| Serialization API | Deserialization API |
|---|---|
Fory#serialize |
Fory#deserialize |
Wrong usage example:
// ❌ Wrong: deserialize with an incompatible target class
byte[] bytes = fory.serialize(struct1);
Struct2 result = fory.deserialize(bytes, Struct2.class); // May throw ClassCastExceptionCorrect usage:
byte[] bytes = fory.serialize(object);
Object result = fory.deserialize(bytes);
byte[] typedBytes = fory.serialize(object);
MyClass typedResult = fory.deserialize(typedBytes, MyClass.class);If you want to serialize one POJO and deserialize it into a different POJO type, you must use CompatibleMode.COMPATIBLE:
public class DeserializeIntoType {
static class Struct1 {
int f1;
String f2;
public Struct1(int f1, String f2) {
this.f1 = f1;
this.f2 = f2;
}
}
static class Struct2 {
int f1;
String f2;
double f3;
}
static ThreadSafeFory fory = Fory.builder()
.withCompatibleMode(CompatibleMode.COMPATIBLE).buildThreadSafeFory();
public static void main(String[] args) {
Struct1 struct1 = new Struct1(10, "abc");
byte[] data = fory.serialize(struct1);
Struct2 struct2 = fory.deserialize(data, Struct2.class);
}
}Cause: Class registration is required but the class wasn't registered.
Solution: Register the class before serialization:
fory.register(MyClass.class);
// or with explicit ID
fory.register(MyClass.class, 100);Cause: Class schema differs between serialization and deserialization.
Solution: Use compatible mode:
Fory fory = Fory.builder()
.withCompatibleMode(CompatibleMode.COMPATIBLE)
.build();Cause: Object graph is too deep, possibly indicating a circular reference attack.
Solution: Increase max depth if legitimate, or check for malicious data:
Fory fory = Fory.builder()
.withMaxDepth(100) // Increase from default 50
.build();Cause: No serializer registered for the type.
Solution: Register a custom serializer:
fory.registerSerializer(MyClass.class, new MyClassSerializer(fory));Cause: JIT compilation happening on first serialization.
Solution: Enable async compilation:
Fory fory = Fory.builder()
.withAsyncCompilation(true)
.build();Cause: Large object graphs or reference tracking overhead.
Solutions:
- Disable reference tracking if not needed:
.withRefTracking(false) - Use custom memory allocator for pooling
- Consider row format for large datasets
Cause: Metadata overhead or uncompressed data.
Solutions:
- Enable compression:
.withIntCompressed(true),.withLongCompressed(true) - Use compatible mode only when needed
- Register classes to avoid class name serialization
- Enable class version check to diagnose schema issues
- Check API pairing - ensure serialize/deserialize APIs match
- Verify registration order - must be consistent across peers
- Enable logging to see internal operations:
LoggerFactory.setLogLevel(LogLevel.DEBUG_LEVEL);- Configuration - All ForyBuilder options
- Schema Evolution - Compatible mode details
- Type Registration - Registration best practices
- Migration Guide - Upgrading Fory versions