gRPC 2 UNKNOWN vs 10 ABORTED
Both gRPC 2 (UNKNOWN) and 10 (ABORTED) belong to the gRPC Status Codes category. 2 indicates that an unknown error occurred. This may be returned when a server raises an exception that doesn't map to any known gRPC status code. Meanwhile, 10 means that the operation was aborted, typically due to a concurrency issue such as a sequencer check failure or transaction abort.
คำอธิบาย
An unknown error occurred. This may be returned when a server raises an exception that doesn't map to any known gRPC status code.
เมื่อคุณพบเห็น
The server threw an unhandled exception or returned an error that gRPC couldn't classify into a more specific status code.
วิธีแก้ไข
Check the server logs for the underlying exception. Wrap server-side errors with explicit gRPC status codes instead of letting them bubble up as UNKNOWN.
คำอธิบาย
The operation was aborted, typically due to a concurrency issue such as a sequencer check failure or transaction abort.
เมื่อคุณพบเห็น
A transaction or optimistic concurrency check failed — for example, a read-modify-write cycle detected a conflict with another concurrent operation.
วิธีแก้ไข
Retry the entire read-modify-write sequence from the beginning. Implement proper optimistic concurrency control with version tokens or ETags.
ความแตกต่างหลัก
gRPC 2: An unknown error occurred. This may be returned when a server raises an exception that doesn't map to any known gRPC status code.
gRPC 10: The operation was aborted, typically due to a concurrency issue such as a sequencer check failure or transaction abort.
You encounter 2 when the server threw an unhandled exception or returned an error that gRPC couldn't classify into a more specific status code.
You encounter 10 when a transaction or optimistic concurrency check failed — for example, a read-modify-write cycle detected a conflict with another concurrent operation.
ควรใช้อันไหนเมื่อไร
For 2 (UNKNOWN): Check the server logs for the underlying exception. Wrap server-side errors with explicit gRPC status codes instead of letting them bubble up as UNKNOWN. For 10 (ABORTED): Retry the entire read-modify-write sequence from the beginning. Implement proper optimistic concurrency control with version tokens or ETags.