RocketMQError

Enum RocketMQError 

Source
pub enum RocketMQError {
Show 53 variants Network(NetworkError), Serialization(SerializationError), Protocol(ProtocolError), BrokerNotFound { name: String, }, BrokerRegistrationFailed { name: String, reason: String, }, BrokerOperationFailed { operation: &'static str, code: i32, message: String, broker_addr: Option<String>, }, TopicNotExist { topic: String, }, QueueNotExist { topic: String, queue_id: i32, }, SubscriptionGroupNotExist { group: String, }, QueueIdOutOfRange { topic: String, queue_id: i32, max: i32, }, MessageTooLarge { actual: usize, limit: usize, }, MessageValidationFailed { reason: String, }, RetryLimitExceeded { group: String, current: i32, max: i32, }, TransactionRejected, BrokerPermissionDenied { operation: String, }, NotMasterBroker { master_address: String, }, MessageLookupFailed { offset: i64, }, TopicSendingForbidden { topic: String, }, BrokerAsyncTaskFailed { task: &'static str, context: String, source: Box<dyn Error + Send + Sync>, }, RequestBodyInvalid { operation: &'static str, reason: String, }, RequestHeaderError(String), ResponseProcessFailed { operation: &'static str, reason: String, }, RouteNotFound { topic: String, }, RouteInconsistent { topic: String, reason: String, }, RouteRegistrationConflict { broker_name: String, reason: String, }, RouteVersionConflict { expected: u64, actual: u64, }, ClusterNotFound { cluster: String, }, ClientNotStarted, ClientAlreadyStarted, ClientShuttingDown, ClientInvalidState { expected: &'static str, actual: String, }, ProducerNotAvailable, ConsumerNotAvailable, Tools(ToolsError), StorageReadFailed { path: String, reason: String, }, StorageWriteFailed { path: String, reason: String, }, StorageCorrupted { path: String, }, StorageOutOfSpace { path: String, }, StorageLockFailed { path: String, }, ConfigParseFailed { key: &'static str, reason: String, }, ConfigMissing { key: &'static str, }, ConfigInvalidValue { key: &'static str, value: String, reason: String, }, ControllerNotLeader { leader_id: Option<u64>, }, ControllerRaftError { reason: String, }, ControllerConsensusTimeout { operation: &'static str, timeout_ms: u64, }, ControllerSnapshotFailed { reason: String, }, IO(Error), IllegalArgument(String), Timeout { operation: &'static str, timeout_ms: u64, }, Internal(String), Service(ServiceError), InvalidVersionOrdinal(u32), Legacy(String),
}
Expand description

Main error type for all RocketMQ operations

This enum provides a unified error system across all RocketMQ crates. Each variant represents a logical category of errors with rich context information.

§Design Principles

  • Semantic: Each error clearly expresses what went wrong
  • Performance: Minimal heap allocations, use of &’static str where possible
  • Debuggability: Rich context for production debugging
  • Ergonomics: Automatic conversions via From trait

§Examples

use rocketmq_error::RocketMQError;
use rocketmq_error::RocketMQResult;

fn send_message(addr: &str) -> RocketMQResult<()> {
    // Create a network error
    if addr.is_empty() {
        return Err(RocketMQError::network_connection_failed(
            "localhost:9876",
            "empty address",
        ));
    }
    Ok(())
}

Variants§

§

Network(NetworkError)

Network operation errors (connection, timeout, send/receive failures)

§

Serialization(SerializationError)

Serialization/deserialization errors (encoding, decoding, format validation)

§

Protocol(ProtocolError)

RocketMQ protocol errors (invalid commands, version mismatch, etc.)

§

BrokerNotFound

Broker not found

Fields

§name: String
§

BrokerRegistrationFailed

Broker registration failed

Fields

§name: String
§reason: String
§

BrokerOperationFailed

Broker operation failed with error code

Fields

§operation: &'static str
§code: i32
§message: String
§broker_addr: Option<String>
§

TopicNotExist

Topic does not exist

Fields

§topic: String
§

QueueNotExist

Queue does not exist

Fields

§topic: String
§queue_id: i32
§

SubscriptionGroupNotExist

Subscription group not found

Fields

§group: String
§

QueueIdOutOfRange

Queue ID out of range

Fields

§topic: String
§queue_id: i32
§max: i32
§

MessageTooLarge

Message body too large

Fields

§actual: usize
§limit: usize
§

MessageValidationFailed

Message validation failed

Fields

§reason: String
§

RetryLimitExceeded

Retry limit exceeded

Fields

§group: String
§current: i32
§max: i32
§

TransactionRejected

Transaction message rejected

§

BrokerPermissionDenied

Broker permission denied

Fields

§operation: String
§

NotMasterBroker

Not master broker

Fields

§master_address: String
§

MessageLookupFailed

Message lookup failed

Fields

§offset: i64
§

TopicSendingForbidden

Topic sending forbidden

Fields

§topic: String
§

BrokerAsyncTaskFailed

Async task failed

Fields

§task: &'static str
§context: String
§source: Box<dyn Error + Send + Sync>
§

RequestBodyInvalid

Request body missing or invalid

Fields

§operation: &'static str
§reason: String
§

RequestHeaderError(String)

Request header missing or invalid

§

ResponseProcessFailed

Response encoding/decoding failed

Fields

§operation: &'static str
§reason: String
§

RouteNotFound

Route information not found

Fields

§topic: String
§

RouteInconsistent

Route data inconsistency detected

Fields

§topic: String
§reason: String
§

RouteRegistrationConflict

Broker registration conflict

Fields

§broker_name: String
§reason: String
§

RouteVersionConflict

Route state version conflict

Fields

§expected: u64
§actual: u64
§

ClusterNotFound

Cluster not found

Fields

§cluster: String
§

ClientNotStarted

Client not started

§

ClientAlreadyStarted

Client already started

§

ClientShuttingDown

Client is shutting down

§

ClientInvalidState

Invalid client state

Fields

§expected: &'static str
§actual: String
§

ProducerNotAvailable

Producer not available

§

ConsumerNotAvailable

Consumer not available

§

Tools(ToolsError)

Tools and admin operation errors

§

StorageReadFailed

Storage read failed

Fields

§path: String
§reason: String
§

StorageWriteFailed

Storage write failed

Fields

§path: String
§reason: String
§

StorageCorrupted

Data corruption detected

Fields

§path: String
§

StorageOutOfSpace

Out of storage space

Fields

§path: String
§

StorageLockFailed

Storage lock failed

Fields

§path: String
§

ConfigParseFailed

Configuration parsing failed

Fields

§key: &'static str
§reason: String
§

ConfigMissing

Required configuration missing

Fields

§key: &'static str
§

ConfigInvalidValue

Invalid configuration value

Fields

§key: &'static str
§value: String
§reason: String
§

ControllerNotLeader

Not the Raft leader

Fields

§leader_id: Option<u64>
§

ControllerRaftError

Raft consensus error

Fields

§reason: String
§

ControllerConsensusTimeout

Consensus operation timeout

Fields

§operation: &'static str
§timeout_ms: u64
§

ControllerSnapshotFailed

Snapshot operation failed

Fields

§reason: String
§

IO(Error)

IO error from std::io

§

IllegalArgument(String)

Illegal argument

§

Timeout

Operation timeout

Fields

§operation: &'static str
§timeout_ms: u64
§

Internal(String)

Internal error (should be rare)

§

Service(ServiceError)

Service lifecycle error

§

InvalidVersionOrdinal(u32)

Invalid RocketMQ version ordinal value

§

Legacy(String)

👎Deprecated since 0.7.0: Use specific error types instead

Legacy error - use specific error types instead

Implementations§

Source§

impl RocketMQError

Source

pub fn network_connection_failed( addr: impl Into<String>, reason: impl Into<String>, ) -> Self

Create a network connection failed error

Source

pub fn broker_operation_failed( operation: &'static str, code: i32, message: impl Into<String>, ) -> Self

Create a broker operation failed error

Source

pub fn storage_read_failed( path: impl Into<String>, reason: impl Into<String>, ) -> Self

Create a storage read failed error

Source

pub fn storage_write_failed( path: impl Into<String>, reason: impl Into<String>, ) -> Self

Create a storage write failed error

Source

pub fn illegal_argument(message: impl Into<String>) -> Self

Create an illegal argument error

Source

pub fn route_not_found(topic: impl Into<String>) -> Self

Create a route not found error

Source

pub fn route_registration_conflict( broker_name: impl Into<String>, reason: impl Into<String>, ) -> Self

Create a route registration conflict error

Source

pub fn cluster_not_found(cluster: impl Into<String>) -> Self

Create a cluster not found error

Source

pub fn request_body_invalid( operation: &'static str, reason: impl Into<String>, ) -> Self

Create a request body invalid error

Source

pub fn request_header_error(message: impl Into<String>) -> Self

Create a request header error

Source

pub fn response_process_failed( operation: &'static str, reason: impl Into<String>, ) -> Self

Create a response process failed error

Source

pub fn with_broker_addr(self, addr: impl Into<String>) -> Self

Add broker address context to broker operation error

Source

pub fn validation_error( field: impl Into<String>, reason: impl Into<String>, ) -> Self

Create a validation error

Source

pub fn topic_not_found(topic: impl Into<String>) -> Self

Create a topic not found error (alias for TopicNotExist)

Source

pub fn topic_already_exists(topic: impl Into<String>) -> Self

Create a topic already exists error

Source

pub fn nameserver_unreachable(addr: impl Into<String>) -> Self

Create a nameserver unreachable error

Source

pub fn nameserver_config_invalid(reason: impl Into<String>) -> Self

Create a nameserver config invalid error

Trait Implementations§

Source§

impl Debug for RocketMQError

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Display for RocketMQError

Source§

fn fmt(&self, __formatter: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Error for RocketMQError

Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl From<Error> for RocketMQError

Source§

fn from(source: Error) -> Self

Converts to this type from the input type.
Source§

impl From<NetworkError> for RocketMQError

Source§

fn from(source: NetworkError) -> Self

Converts to this type from the input type.
Source§

impl From<ProtocolError> for RocketMQError

Source§

fn from(source: ProtocolError) -> Self

Converts to this type from the input type.
Source§

impl From<RocketmqError> for RocketMQError

Automatic conversion from legacy RocketmqError to unified RocketMQError

This allows legacy error-producing code to work with new error-expecting code

Source§

fn from(err: RocketmqError) -> Self

Converts to this type from the input type.
Source§

impl From<SerializationError> for RocketMQError

Source§

fn from(source: SerializationError) -> Self

Converts to this type from the input type.
Source§

impl From<ServiceError> for RocketMQError

Source§

fn from(source: ServiceError) -> Self

Converts to this type from the input type.
Source§

impl From<ToolsError> for RocketMQError

Source§

fn from(source: ToolsError) -> Self

Converts to this type from the input type.
Source§

impl From<Utf8Error> for RocketMQError

Source§

fn from(e: Utf8Error) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.