124 Star 849 Fork 0

Apache/RocketMQ

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

rocketmq-proxy

Introduction

RocketMQ Proxy is a stateless component that makes full use of the newly introduced pop consumption mechanism to achieve stateless consumption behavior. gRPC protocol is supported by Proxy now and all the message types including normal, fifo, transaction and delay are supported via pop consumption mode. Proxy will translate incoming traffic into customized Remoting protocol to access Broker and Namesrv.

Proxy also handles SSL, authorization/authentication and logging/tracing/metrics and is in charge of connection management and traffic governance.

Multi-language support.

gRPC combined with Protocol Buffer makes it easy to implement clients with both java and other programming languages while the server side doesn't need extra work to support different programming languages. See rocketmq-clients for more information.

Multi-protocol support.

With Proxy served as a traffic interface, it's convenient to implement multiple protocols upon proxy. gRPC protocol is implemented first and the customized Remoting protocol will be implemented later. HTTP/1.1 will also be taken into consideration.

Architecture

RocketMQ Proxy has two deployment modes: Cluster mode and Local mode. With both modes, Pop mode is natively supported in Proxy.

Cluster mode

While in Cluster mode, Proxy is an independent cluster that communicates with Broker with remote procedure call. In this scenario, Proxy acts as a stateless computing component while Broker is a stateful component with local storage. This form of deployment introduces the architecture of separation of computing and storage for RocketMQ.

Due to the separation of computing and storage, RocketMQ Proxy can be scaled out indefinitely in Cluster mode to handle traffic peak while Broker can focus on storage engine and high availability.

Local mode

Proxy in Local mode has more similarity with RocketMQ 4.x version, which is easily deployed or upgraded for current RocketMQ users. With Local mode, Proxy deployed with Broker in the same process with inter-process communication so the network overhead is reduced compared to Cluster mode.

Deploy guide

See Proxy Deployment

Related

马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Java
1
https://gitee.com/apache/rocketmq.git
git@gitee.com:apache/rocketmq.git
apache
rocketmq
RocketMQ
develop

搜索帮助