You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
132 lines
4.8 KiB
132 lines
4.8 KiB
package broker
|
|
|
|
// Broker Error Codes
|
|
// These codes are used internally by the broker and can be mapped to Kafka protocol error codes
|
|
const (
|
|
// Success
|
|
BrokerErrorNone int32 = 0
|
|
|
|
// General broker errors
|
|
BrokerErrorUnknownServerError int32 = 1
|
|
BrokerErrorTopicNotFound int32 = 2
|
|
BrokerErrorPartitionNotFound int32 = 3
|
|
BrokerErrorNotLeaderOrFollower int32 = 6 // Maps to Kafka ErrorCodeNotLeaderOrFollower
|
|
BrokerErrorRequestTimedOut int32 = 7
|
|
BrokerErrorBrokerNotAvailable int32 = 8
|
|
BrokerErrorMessageTooLarge int32 = 10
|
|
BrokerErrorNetworkException int32 = 13
|
|
BrokerErrorOffsetLoadInProgress int32 = 14
|
|
BrokerErrorInvalidRecord int32 = 42
|
|
BrokerErrorTopicAlreadyExists int32 = 36
|
|
BrokerErrorInvalidPartitions int32 = 37
|
|
BrokerErrorInvalidConfig int32 = 40
|
|
|
|
// Publisher/connection errors
|
|
BrokerErrorPublisherNotFound int32 = 100
|
|
BrokerErrorConnectionFailed int32 = 101
|
|
BrokerErrorFollowerConnectionFailed int32 = 102
|
|
)
|
|
|
|
// BrokerErrorInfo contains metadata about a broker error
|
|
type BrokerErrorInfo struct {
|
|
Code int32
|
|
Name string
|
|
Description string
|
|
KafkaCode int16 // Corresponding Kafka protocol error code
|
|
}
|
|
|
|
// BrokerErrors maps broker error codes to their metadata and Kafka equivalents
|
|
var BrokerErrors = map[int32]BrokerErrorInfo{
|
|
BrokerErrorNone: {
|
|
Code: BrokerErrorNone, Name: "NONE",
|
|
Description: "No error", KafkaCode: 0,
|
|
},
|
|
BrokerErrorUnknownServerError: {
|
|
Code: BrokerErrorUnknownServerError, Name: "UNKNOWN_SERVER_ERROR",
|
|
Description: "Unknown server error", KafkaCode: 1,
|
|
},
|
|
BrokerErrorTopicNotFound: {
|
|
Code: BrokerErrorTopicNotFound, Name: "TOPIC_NOT_FOUND",
|
|
Description: "Topic not found", KafkaCode: 3, // UNKNOWN_TOPIC_OR_PARTITION
|
|
},
|
|
BrokerErrorPartitionNotFound: {
|
|
Code: BrokerErrorPartitionNotFound, Name: "PARTITION_NOT_FOUND",
|
|
Description: "Partition not found", KafkaCode: 3, // UNKNOWN_TOPIC_OR_PARTITION
|
|
},
|
|
BrokerErrorNotLeaderOrFollower: {
|
|
Code: BrokerErrorNotLeaderOrFollower, Name: "NOT_LEADER_OR_FOLLOWER",
|
|
Description: "Not leader or follower for this partition", KafkaCode: 6,
|
|
},
|
|
BrokerErrorRequestTimedOut: {
|
|
Code: BrokerErrorRequestTimedOut, Name: "REQUEST_TIMED_OUT",
|
|
Description: "Request timed out", KafkaCode: 7,
|
|
},
|
|
BrokerErrorBrokerNotAvailable: {
|
|
Code: BrokerErrorBrokerNotAvailable, Name: "BROKER_NOT_AVAILABLE",
|
|
Description: "Broker not available", KafkaCode: 8,
|
|
},
|
|
BrokerErrorMessageTooLarge: {
|
|
Code: BrokerErrorMessageTooLarge, Name: "MESSAGE_TOO_LARGE",
|
|
Description: "Message size exceeds limit", KafkaCode: 10,
|
|
},
|
|
BrokerErrorNetworkException: {
|
|
Code: BrokerErrorNetworkException, Name: "NETWORK_EXCEPTION",
|
|
Description: "Network error", KafkaCode: 13,
|
|
},
|
|
BrokerErrorOffsetLoadInProgress: {
|
|
Code: BrokerErrorOffsetLoadInProgress, Name: "OFFSET_LOAD_IN_PROGRESS",
|
|
Description: "Offset loading in progress", KafkaCode: 14,
|
|
},
|
|
BrokerErrorInvalidRecord: {
|
|
Code: BrokerErrorInvalidRecord, Name: "INVALID_RECORD",
|
|
Description: "Invalid record", KafkaCode: 42,
|
|
},
|
|
BrokerErrorTopicAlreadyExists: {
|
|
Code: BrokerErrorTopicAlreadyExists, Name: "TOPIC_ALREADY_EXISTS",
|
|
Description: "Topic already exists", KafkaCode: 36,
|
|
},
|
|
BrokerErrorInvalidPartitions: {
|
|
Code: BrokerErrorInvalidPartitions, Name: "INVALID_PARTITIONS",
|
|
Description: "Invalid partition count", KafkaCode: 37,
|
|
},
|
|
BrokerErrorInvalidConfig: {
|
|
Code: BrokerErrorInvalidConfig, Name: "INVALID_CONFIG",
|
|
Description: "Invalid configuration", KafkaCode: 40,
|
|
},
|
|
BrokerErrorPublisherNotFound: {
|
|
Code: BrokerErrorPublisherNotFound, Name: "PUBLISHER_NOT_FOUND",
|
|
Description: "Publisher not found", KafkaCode: 1, // UNKNOWN_SERVER_ERROR
|
|
},
|
|
BrokerErrorConnectionFailed: {
|
|
Code: BrokerErrorConnectionFailed, Name: "CONNECTION_FAILED",
|
|
Description: "Connection failed", KafkaCode: 13, // NETWORK_EXCEPTION
|
|
},
|
|
BrokerErrorFollowerConnectionFailed: {
|
|
Code: BrokerErrorFollowerConnectionFailed, Name: "FOLLOWER_CONNECTION_FAILED",
|
|
Description: "Failed to connect to follower brokers", KafkaCode: 13, // NETWORK_EXCEPTION
|
|
},
|
|
}
|
|
|
|
// GetBrokerErrorInfo returns error information for the given broker error code
|
|
func GetBrokerErrorInfo(code int32) BrokerErrorInfo {
|
|
if info, exists := BrokerErrors[code]; exists {
|
|
return info
|
|
}
|
|
return BrokerErrorInfo{
|
|
Code: code, Name: "UNKNOWN", Description: "Unknown broker error code", KafkaCode: 1,
|
|
}
|
|
}
|
|
|
|
// GetKafkaErrorCode returns the corresponding Kafka protocol error code for a broker error
|
|
func GetKafkaErrorCode(brokerErrorCode int32) int16 {
|
|
return GetBrokerErrorInfo(brokerErrorCode).KafkaCode
|
|
}
|
|
|
|
// CreateBrokerError creates a structured broker error with both error code and message
|
|
func CreateBrokerError(code int32, message string) (int32, string) {
|
|
info := GetBrokerErrorInfo(code)
|
|
if message == "" {
|
|
message = info.Description
|
|
}
|
|
return code, message
|
|
}
|