产品架构
<p class="shortdesc"></p>
<section class="section" id="architecture__section_qht_mhx_1mb"><h2 class="doc-tairway">Kafka 应用架构</h2>
<div class="p">
<img class="image" id="architecture__image_fkt_shx_1mb" src="https://pcp-portal-sca.obs-cn-shenzhen.pinganyun.com/pcp-portal-sca/20200212172810-12e3b15b9e16.png">
<ul class="ul" id="architecture__ul_y2d_vhx_1mb">
<li class="li"><strong class="ph b">Producer</strong>:通过 Push 模式向消息队列 Kafka 的 Broker
发送消息,发送的消息可以是网站的页面访问、服务器日志等。</li>
<li class="li"><strong class="ph b">Kafka Broker</strong>:消息队列 Kafka 的服务器,用于存储消息。支持横向扩展,一般 Broker
节点数量越多,集群吞吐率越高。</li>
<li class="li"><strong class="ph b">Consumer Group</strong>:通过 Pull 模式从消息队列 Kafka Broker 订阅并消费消息。</li>
<li class="li"><strong class="ph b">Zookeeper</strong>:管理集群的配置、选举 Leader,以及在 Consumer Group 发生变化时进行负载均衡。</li>
</ul>
</div>
</section>
<section class="section" id="architecture__section_vfg_d3x_1mb"><h2 class="doc-tairway">Kafka 发布订阅关系图</h2>
<div class="p">
<img class="image" id="architecture__image_yyz_23x_1mb" src="https://pcp-portal-sca.obs-cn-shenzhen.pinganyun.com/pcp-portal-sca/20200212172810-1d2c528a9156.png" width="830">
</div>
<p class="p">消息队列 Kafka 采用 Pub/Sub(发布/订阅)模型,其中:</p>
<ul class="ul" id="architecture__ul_plt_g3x_1mb">
<li class="li">Consumer Group 和 Topic 的关系是 N:N。 同一个 Consumer Group 可以订阅多个 Topic,同一个 Topic
也可以同时被多个 Consumer Group 订阅。</li>
<li class="li">同一 Topic 的某一条消息只能被同一个 Consumer Group 内的任意一个 Consumer 消费,但多个 Consumer Group
可同时消费这一消息。</li>
</ul>
</section>
<section class="section" id="architecture__section_b24_j3x_1mb"><h2 class="doc-tairway">Kafka 部署架构</h2>
<div class="p">
<img class="image" id="architecture__image_ujd_l3x_1mb" src="https://pcp-portal-sca.obs-cn-shenzhen.pinganyun.com/pcp-portal-sca/20200212172810-1c02e10297df.png">
</div>
<ul class="ul" id="architecture__ul_alk_m3x_1mb">
<li class="li"><strong class="ph b">Kafka管理控制台</strong>:标准J2EE应用,采用Tomcat部署,数据库使用PostgreSQL。</li>
<li class="li"><strong class="ph b">Kafka 服务端</strong>:Zookeeper和Broker节点数量可按需部署,
Broker集群采用主从模式,消息至少保存两份,建议不同节点跨可用区部署。</li>
<li class="li"><strong class="ph b">客户端SDK支持多语言</strong>:支持JAVA、C语言等,客户端通过TCP访问Broker。</li>
</ul>
</section>
提交成功!非常感谢您的反馈,我们会继续努力做到更好!