大数据之Kafka史上最详细原理总结_慕课手记


本站和网页 https://www.imooc.com/article/299379 的作者无关,不对其内容负责。快照谨为网络故障时之索引,不代表被搜索网站的即时页面。

大数据之Kafka史上最详细原理总结_慕课手记
慕课网首页
免费课
实战课
体系课
教程
发现
专栏
手记
商业合作
企业服务
讲师入驻
热搜
最近搜索清空
登录 / 注册
新人专属100元礼包 | 查看
写文章
为了账号安全,请及时绑定邮箱和手机立即绑定
首页
手记
大数据之Kafka史上最详细原理总结
推荐
评论
分享
大数据之Kafka史上最详细原理总结
标签:
大数据
Hadoop
Spark
收藏
KafkaKafka&#26159;&#26368;&#21021;&#30001;Linkedin&#20844;&#21496;&#24320;&#21457;&#65292;&#26159;&#19968;&#20010;&#20998;&#24067;&#24335;&#12289;&#25903;&#25345;&#20998;&#21306;&#30340;&#65288;partition&#65289;&#12289;&#22810;&#21103;&#26412;&#30340;&#65288;replica&#65289;&#65292;&#22522;&#20110;zookeeper&#21327;&#35843;&#30340;&#20998;&#24067;&#24335;&#28040;&#24687;&#31995;&#32479;&#65292;&#23427;&#30340;&#26368;&#22823;&#30340;&#29305;&#24615;&#23601;&#26159;&#21487;&#20197;&#23454;&#26102;&#30340;&#22788;&#29702;&#22823;&#37327;&#25968;&#25454;&#20197;&#28385;&#36275;&#21508;&#31181;&#38656;&#27714;&#22330;&#26223;&#65306;&#27604;&#22914;&#22522;&#20110;hadoop&#30340;&#25209;&#22788;&#29702;&#31995;&#32479;&#12289;&#20302;&#24310;&#36831;&#30340;&#23454;&#26102;&#31995;&#32479;&#12289;storm/Spark&#27969;&#24335;&#22788;&#29702;&#24341;&#25806;&#65292;web/nginx&#26085;&#24535;&#12289;&#35775;&#38382;&#26085;&#24535;&#65292;&#28040;&#24687;&#26381;&#21153;&#31561;&#31561;&#65292;&#29992;scala&#35821;&#35328;&#32534;&#20889;&#65292;Linkedin&#20110;2010&#24180;&#36129;&#29486;&#32473;&#20102;Apache&#22522;&#37329;&#20250;&#24182;&#25104;&#20026;&#39030;&#32423;&#24320;&#28304;&#39033;&#30446;&#12290;1.&#21069;&#35328;&#28040;&#24687;&#38431;&#21015;&#30340;&#24615;&#33021;&#22909;&#22351;&#65292;&#20854;&#25991;&#20214;&#23384;&#20648;&#26426;&#21046;&#35774;&#35745;&#26159;&#34913;&#37327;&#19968;&#20010;&#28040;&#24687;&#38431;&#21015;&#26381;&#21153;&#25216;&#26415;&#27700;&#24179;&#21644;&#26368;&#20851;&#38190;&#25351;&#26631;&#20043;&#19968;&#12290;&#19979;&#38754;&#23558;&#20174;Kafka&#25991;&#20214;&#23384;&#20648;&#26426;&#21046;&#21644;&#29289;&#29702;&#32467;&#26500;&#35282;&#24230;&#65292;&#20998;&#26512;Kafka&#26159;&#22914;&#20309;&#23454;&#29616;&#39640;&#25928;&#25991;&#20214;&#23384;&#20648;&#65292;&#21450;&#23454;&#38469;&#24212;&#29992;&#25928;&#26524;&#12290; 1.1 Kafka&#30340;&#29305;&#24615;:- &#39640;&#21534;&#21520;&#37327;&#12289;&#20302;&#24310;&#36831;&#65306;kafka&#27599;&#31186;&#21487;&#20197;&#22788;&#29702;&#20960;&#21313;&#19975;&#26465;&#28040;&#24687;&#65292;&#23427;&#30340;&#24310;&#36831;&#26368;&#20302;&#21482;&#26377;&#20960;&#27627;&#31186;&#65292;&#27599;&#20010;topic&#21487;&#20197;&#20998;&#22810;&#20010;partition, consumer group &#23545;partition&#36827;&#34892;consume&#25805;&#20316;&#12290;- &#21487;&#25193;&#23637;&#24615;&#65306;kafka&#38598;&#32676;&#25903;&#25345;&#28909;&#25193;&#23637;- &#25345;&#20037;&#24615;&#12289;&#21487;&#38752;&#24615;&#65306;&#28040;&#24687;&#34987;&#25345;&#20037;&#21270;&#21040;&#26412;&#22320;&#30913;&#30424;&#65292;&#24182;&#19988;&#25903;&#25345;&#25968;&#25454;&#22791;&#20221;&#38450;&#27490;&#25968;&#25454;&#20002;&#22833;- &#23481;&#38169;&#24615;&#65306;&#20801;&#35768;&#38598;&#32676;&#20013;&#33410;&#28857;&#22833;&#36133;&#65288;&#33509;&#21103;&#26412;&#25968;&#37327;&#20026;n,&#21017;&#20801;&#35768;n-1&#20010;&#33410;&#28857;&#22833;&#36133;&#65289;- &#39640;&#24182;&#21457;&#65306;&#25903;&#25345;&#25968;&#21315;&#20010;&#23458;&#25143;&#31471;&#21516;&#26102;&#35835;&#20889;1.2 Kafka&#30340;&#20351;&#29992;&#22330;&#26223;&#65306;- &#26085;&#24535;&#25910;&#38598;&#65306;&#19968;&#20010;&#20844;&#21496;&#21487;&#20197;&#29992;Kafka&#21487;&#20197;&#25910;&#38598;&#21508;&#31181;&#26381;&#21153;&#30340;log&#65292;&#36890;&#36807;kafka&#20197;&#32479;&#19968;&#25509;&#21475;&#26381;&#21153;&#30340;&#26041;&#24335;&#24320;&#25918;&#32473;&#21508;&#31181;consumer&#65292;&#20363;&#22914;hadoop&#12289;Hbase&#12289;Solr&#31561;&#12290;- &#28040;&#24687;&#31995;&#32479;&#65306;&#35299;&#32806;&#21644;&#29983;&#20135;&#32773;&#21644;&#28040;&#36153;&#32773;&#12289;&#32531;&#23384;&#28040;&#24687;&#31561;&#12290;- &#29992;&#25143;&#27963;&#21160;&#36319;&#36394;&#65306;Kafka&#32463;&#24120;&#34987;&#29992;&#26469;&#35760;&#24405;web&#29992;&#25143;&#25110;&#32773;app&#29992;&#25143;&#30340;&#21508;&#31181;&#27963;&#21160;&#65292;&#22914;&#27983;&#35272;&#32593;&#39029;&#12289;&#25628;&#32034;&#12289;&#28857;&#20987;&#31561;&#27963;&#21160;&#65292;&#36825;&#20123;&#27963;&#21160;&#20449;&#24687;&#34987;&#21508;&#20010;&#26381;&#21153;&#22120;&#21457;&#24067;&#21040;kafka&#30340;topic&#20013;&#65292;&#28982;&#21518;&#35746;&#38405;&#32773;&#36890;&#36807;&#35746;&#38405;&#36825;&#20123;topic&#26469;&#20570;&#23454;&#26102;&#30340;&#30417;&#25511;&#20998;&#26512;&#65292;&#25110;&#32773;&#35013;&#36733;&#21040;hadoop&#12289;&#25968;&#25454;&#20179;&#24211;&#20013;&#20570;&#31163;&#32447;&#20998;&#26512;&#21644;&#25366;&#25496;&#12290;- &#36816;&#33829;&#25351;&#26631;&#65306;Kafka&#20063;&#32463;&#24120;&#29992;&#26469;&#35760;&#24405;&#36816;&#33829;&#30417;&#25511;&#25968;&#25454;&#12290;&#21253;&#25324;&#25910;&#38598;&#21508;&#31181;&#20998;&#24067;&#24335;&#24212;&#29992;&#30340;&#25968;&#25454;&#65292;&#29983;&#20135;&#21508;&#31181;&#25805;&#20316;&#30340;&#38598;&#20013;&#21453;&#39304;&#65292;&#27604;&#22914;&#25253;&#35686;&#21644;&#25253;&#21578;&#12290;- &#27969;&#24335;&#22788;&#29702;&#65306;&#27604;&#22914;spark streaming&#21644;storm- &#20107;&#20214;&#28304;1.3 Kakfa&#30340;&#35774;&#35745;&#24605;&#24819;-Kakfa Broker Leader&#30340;&#36873;&#20030;&#65306;Kakfa Broker&#38598;&#32676;&#21463;Zookeeper&#31649;&#29702;&#12290;&#25152;&#26377;&#30340;Kafka Broker&#33410;&#28857;&#19968;&#36215;&#21435;Zookeeper&#19978;&#27880;&#20876;&#19968;&#20010;&#20020;&#26102;&#33410;&#28857;&#65292;&#22240;&#20026;&#21482;&#26377;&#19968;&#20010;Kafka Broker&#20250;&#27880;&#20876;&#25104;&#21151;&#65292;&#20854;&#20182;&#30340;&#37117;&#20250;&#22833;&#36133;&#65292;&#25152;&#20197;&#36825;&#20010;&#25104;&#21151;&#22312;Zookeeper&#19978;&#27880;&#20876;&#20020;&#26102;&#33410;&#28857;&#30340;&#36825;&#20010;Kafka Broker&#20250;&#25104;&#20026;Kafka Broker Controller&#65292;&#20854;&#20182;&#30340;Kafka broker&#21483;Kafka Broker follower&#12290;&#65288;&#36825;&#20010;&#36807;&#31243;&#21483;Controller&#22312;ZooKeeper&#27880;&#20876;Watch&#65289;&#12290;&#36825;&#20010;Controller&#20250;&#30417;&#21548;&#20854;&#20182;&#30340;Kafka Broker&#30340;&#25152;&#26377;&#20449;&#24687;&#65292;&#22914;&#26524;&#36825;&#20010;kafka broker controller&#23445;&#26426;&#20102;&#65292;&#22312;zookeeper&#19978;&#38754;&#30340;&#37027;&#20010;&#20020;&#26102;&#33410;&#28857;&#23601;&#20250;&#28040;&#22833;&#65292;&#27492;&#26102;&#25152;&#26377;&#30340;kafka broker&#21448;&#20250;&#19968;&#36215;&#21435;Zookeeper&#19978;&#27880;&#20876;&#19968;&#20010;&#20020;&#26102;&#33410;&#28857;&#65292;&#22240;&#20026;&#21482;&#26377;&#19968;&#20010;Kafka Broker&#20250;&#27880;&#20876;&#25104;&#21151;&#65292;&#20854;&#20182;&#30340;&#37117;&#20250;&#22833;&#36133;&#65292;&#25152;&#20197;&#36825;&#20010;&#25104;&#21151;&#22312;Zookeeper&#19978;&#27880;&#20876;&#20020;&#26102;&#33410;&#28857;&#30340;&#36825;&#20010;Kafka Broker&#20250;&#25104;&#20026;Kafka Broker Controller&#65292;&#20854;&#20182;&#30340;Kafka broker&#21483;Kafka Broker follower&#12290;&#20363;&#22914;&#65306;&#19968;&#26086;&#26377;&#19968;&#20010;broker&#23445;&#26426;&#20102;&#65292;&#36825;&#20010;kafka broker controller&#20250;&#35835;&#21462;&#35813;&#23445;&#26426;broker&#19978;&#25152;&#26377;&#30340;partition&#22312;zookeeper&#19978;&#30340;&#29366;&#24577;&#65292;&#24182;&#36873;&#21462;ISR&#21015;&#34920;&#20013;&#30340;&#19968;&#20010;replica&#20316;&#20026;partition leader&#65288;&#22914;&#26524;ISR&#21015;&#34920;&#20013;&#30340;replica&#20840;&#25346;&#65292;&#36873;&#19968;&#20010;&#24184;&#23384;&#30340;replica&#20316;&#20026;leader; &#22914;&#26524;&#35813;partition&#30340;&#25152;&#26377;&#30340;replica&#37117;&#23445;&#26426;&#20102;&#65292;&#21017;&#23558;&#26032;&#30340;leader&#35774;&#32622;&#20026;-1&#65292;&#31561;&#24453;&#24674;&#22797;&#65292;&#31561;&#24453;ISR&#20013;&#30340;&#20219;&#19968;&#20010;Replica&ldquo;&#27963;&rdquo;&#36807;&#26469;&#65292;&#24182;&#19988;&#36873;&#23427;&#20316;&#20026;Leader&#65307;&#25110;&#36873;&#25321;&#31532;&#19968;&#20010;&ldquo;&#27963;&rdquo;&#36807;&#26469;&#30340;Replica&#65288;&#19981;&#19968;&#23450;&#26159;ISR&#20013;&#30340;&#65289;&#20316;&#20026;Leader&#65289;&#65292;&#36825;&#20010;broker&#23445;&#26426;&#30340;&#20107;&#24773;&#65292;kafka controller&#20063;&#20250;&#36890;&#30693;zookeeper&#65292;zookeeper&#23601;&#20250;&#36890;&#30693;&#20854;&#20182;&#30340;kafka broker&#12290;&#36825;&#37324;&#26366;&#32463;&#21457;&#29983;&#36807;&#19968;&#20010;bug&#65292;TalkingData&#20351;&#29992;Kafka0.8.1&#30340;&#26102;&#20505;&#65292;kafka controller&#22312;Zookeeper&#19978;&#27880;&#20876;&#25104;&#21151;&#21518;&#65292;&#23427;&#21644;Zookeeper&#36890;&#20449;&#30340;timeout&#26102;&#38388;&#26159;6s&#65292;&#20063;&#23601;&#26159;&#22914;&#26524;kafka controller&#22914;&#26524;&#26377;6s&#20013;&#27809;&#26377;&#21644;Zookeeper&#20570;&#24515;&#36339;&#65292;&#37027;&#20040;Zookeeper&#23601;&#35748;&#20026;&#36825;&#20010;kafka controller&#24050;&#32463;&#27515;&#20102;&#65292;&#23601;&#20250;&#22312;Zookeeper&#19978;&#25226;&#36825;&#20010;&#20020;&#26102;&#33410;&#28857;&#21024;&#25481;&#65292;&#37027;&#20040;&#20854;&#20182;Kafka&#23601;&#20250;&#35748;&#20026;controller&#24050;&#32463;&#27809;&#20102;&#65292;&#23601;&#20250;&#20877;&#27425;&#25250;&#30528;&#27880;&#20876;&#20020;&#26102;&#33410;&#28857;&#65292;&#27880;&#20876;&#25104;&#21151;&#30340;&#37027;&#20010;kafka broker&#25104;&#20026;controller&#65292;&#28982;&#21518;&#65292;&#20043;&#21069;&#30340;&#37027;&#20010;kafka controller&#23601;&#38656;&#35201;&#21508;&#31181;shut down&#21435;&#20851;&#38381;&#21508;&#31181;&#33410;&#28857;&#21644;&#20107;&#20214;&#30340;&#30417;&#21548;&#12290;&#20294;&#26159;&#24403;kafka&#30340;&#35835;&#20889;&#27969;&#37327;&#37117;&#38750;&#24120;&#24040;&#22823;&#30340;&#26102;&#20505;&#65292;TalkingData&#30340;&#19968;&#20010;bug&#26159;&#65292;&#30001;&#20110;&#32593;&#32476;&#31561;&#21407;&#22240;&#65292;kafka controller&#21644;Zookeeper&#26377;6s&#20013;&#27809;&#26377;&#36890;&#20449;&#65292;&#20110;&#26159;&#37325;&#26032;&#36873;&#20030;&#20986;&#20102;&#19968;&#20010;&#26032;&#30340;kafka controller&#65292;&#20294;&#26159;&#21407;&#26469;&#30340;controller&#22312;shut down&#30340;&#26102;&#20505;&#24635;&#26159;&#19981;&#25104;&#21151;&#65292;&#36825;&#20010;&#26102;&#20505;producer&#36827;&#26469;&#30340;message&#30001;&#20110;Kafka&#38598;&#32676;&#20013;&#23384;&#22312;&#20004;&#20010;kafka controller&#32780;&#26080;&#27861;&#33853;&#22320;&#12290;&#23548;&#33268;&#25968;&#25454;&#28132;&#31215;&#12290;&#36825;&#37324;&#26366;&#32463;&#36824;&#26377;&#19968;&#20010;bug&#65292;TalkingData&#20351;&#29992;Kafka0.8.1&#30340;&#26102;&#20505;&#65292;&#24403;ack=0&#30340;&#26102;&#20505;&#65292;&#34920;&#31034;producer&#21457;&#36865;&#20986;&#21435;message&#65292;&#21482;&#35201;&#23545;&#24212;&#30340;kafka broker topic partition leader&#25509;&#25910;&#21040;&#30340;&#36825;&#26465;message&#65292;producer&#23601;&#36820;&#22238;&#25104;&#21151;&#65292;&#19981;&#31649;partition leader &#26159;&#21542;&#30495;&#30340;&#25104;&#21151;&#25226;message&#30495;&#27491;&#23384;&#21040;kafka&#12290;&#24403;ack=1&#30340;&#26102;&#20505;&#65292;&#34920;&#31034;producer&#21457;&#36865;&#20986;&#21435;message&#65292;&#21516;&#27493;&#30340;&#25226;message&#23384;&#21040;&#23545;&#24212;topic&#30340;partition&#30340;leader&#19978;&#65292;&#28982;&#21518;producer&#23601;&#36820;&#22238;&#25104;&#21151;&#65292;partition leader&#24322;&#27493;&#30340;&#25226;message&#21516;&#27493;&#21040;&#20854;&#20182;partition replica&#19978;&#12290;&#24403;ack=all&#25110;-1&#65292;&#34920;&#31034;producer&#21457;&#36865;&#20986;&#21435;message&#65292;&#21516;&#27493;&#30340;&#25226;message&#23384;&#21040;&#23545;&#24212;topic&#30340;partition&#30340;leader&#21644;&#23545;&#24212;&#30340;replica&#19978;&#20043;&#21518;&#65292;&#25165;&#36820;&#22238;&#25104;&#21151;&#12290;&#20294;&#26159;&#22914;&#26524;&#26576;&#20010;kafka controller&#20999;&#25442;&#30340;&#26102;&#20505;&#65292;&#20250;&#23548;&#33268;partition leader&#30340;&#20999;&#25442;&#65288;&#32769;&#30340;kafka controller&#19978;&#38754;&#30340;partition leader&#20250;&#36873;&#20030;&#21040;&#20854;&#20182;&#30340;kafka broker&#19978;&#65289;,&#20294;&#26159;&#36825;&#26679;&#23601;&#20250;&#23548;&#33268;&#20002;&#25968;&#25454;&#12290;- Consumergroup&#65306;&#21508;&#20010;consumer&#65288;consumer &#32447;&#31243;&#65289;&#21487;&#20197;&#32452;&#25104;&#19968;&#20010;&#32452;&#65288;Consumer group&#65289;&#65292;partition&#20013;&#30340;&#27599;&#20010;message&#21482;&#33021;&#34987;&#32452;&#65288;Consumer group&#65289;&#20013;&#30340;&#19968;&#20010;consumer&#65288;consumer &#32447;&#31243;&#65289;&#28040;&#36153;&#65292;&#22914;&#26524;&#19968;&#20010;message&#21487;&#20197;&#34987;&#22810;&#20010;consumer&#65288;consumer &#32447;&#31243;&#65289;&#28040;&#36153;&#30340;&#35805;&#65292;&#37027;&#20040;&#36825;&#20123;consumer&#24517;&#39035;&#22312;&#19981;&#21516;&#30340;&#32452;&#12290;Kafka&#19981;&#25903;&#25345;&#19968;&#20010;partition&#20013;&#30340;message&#30001;&#20004;&#20010;&#25110;&#20004;&#20010;&#20197;&#19978;&#30340;&#21516;&#19968;&#20010;consumer group&#19979;&#30340;consumer thread&#26469;&#22788;&#29702;&#65292;&#38500;&#38750;&#20877;&#21551;&#21160;&#19968;&#20010;&#26032;&#30340;consumer group&#12290;&#25152;&#20197;&#22914;&#26524;&#24819;&#21516;&#26102;&#23545;&#19968;&#20010;topic&#20570;&#28040;&#36153;&#30340;&#35805;&#65292;&#21551;&#21160;&#22810;&#20010;consumer group&#23601;&#21487;&#20197;&#20102;&#65292;&#20294;&#26159;&#35201;&#27880;&#24847;&#30340;&#26159;&#65292;&#36825;&#37324;&#30340;&#22810;&#20010;consumer&#30340;&#28040;&#36153;&#37117;&#24517;&#39035;&#26159;&#39034;&#24207;&#35835;&#21462;partition&#37324;&#38754;&#30340;message&#65292;&#26032;&#21551;&#21160;&#30340;consumer&#40664;&#35748;&#20174;partition&#38431;&#21015;&#26368;&#22836;&#31471;&#26368;&#26032;&#30340;&#22320;&#26041;&#24320;&#22987;&#38459;&#22622;&#30340;&#35835;message&#12290;&#23427;&#19981;&#33021;&#20687;AMQ&#37027;&#26679;&#21487;&#20197;&#22810;&#20010;BET&#20316;&#20026;consumer&#21435;&#20114;&#26021;&#30340;&#65288;for update&#24754;&#35266;&#38145;&#65289;&#24182;&#21457;&#22788;&#29702;message&#65292;&#36825;&#26159;&#22240;&#20026;&#22810;&#20010;BET&#21435;&#28040;&#36153;&#19968;&#20010;Queue&#20013;&#30340;&#25968;&#25454;&#30340;&#26102;&#20505;&#65292;&#30001;&#20110;&#35201;&#20445;&#35777;&#19981;&#33021;&#22810;&#20010;&#32447;&#31243;&#25343;&#21516;&#19968;&#26465;message&#65292;&#25152;&#20197;&#23601;&#38656;&#35201;&#34892;&#32423;&#21035;&#24754;&#35266;&#25152;&#65288;for update&#65289;,&#36825;&#23601;&#23548;&#33268;&#20102;consume&#30340;&#24615;&#33021;&#19979;&#38477;&#65292;&#21534;&#21520;&#37327;&#19981;&#22815;&#12290;&#32780;kafka&#20026;&#20102;&#20445;&#35777;&#21534;&#21520;&#37327;&#65292;&#21482;&#20801;&#35768;&#21516;&#19968;&#20010;consumer group&#19979;&#30340;&#19968;&#20010;consumer&#32447;&#31243;&#21435;&#35775;&#38382;&#19968;&#20010;partition&#12290;&#22914;&#26524;&#35273;&#24471;&#25928;&#29575;&#19981;&#39640;&#30340;&#26102;&#20505;&#65292;&#21487;&#20197;&#21152;partition&#30340;&#25968;&#37327;&#26469;&#27178;&#21521;&#25193;&#23637;&#65292;&#37027;&#20040;&#20877;&#21152;&#26032;&#30340;consumer thread&#21435;&#28040;&#36153;&#12290;&#22914;&#26524;&#24819;&#22810;&#20010;&#19981;&#21516;&#30340;&#19994;&#21153;&#37117;&#38656;&#35201;&#36825;&#20010;topic&#30340;&#25968;&#25454;&#65292;&#36215;&#22810;&#20010;consumer group&#23601;&#22909;&#20102;&#65292;&#22823;&#23478;&#37117;&#26159;&#39034;&#24207;&#30340;&#35835;&#21462;message&#65292;offsite&#30340;&#20540;&#20114;&#19981;&#24433;&#21709;&#12290;&#36825;&#26679;&#27809;&#26377;&#38145;&#31454;&#20105;&#65292;&#20805;&#20998;&#21457;&#25381;&#20102;&#27178;&#21521;&#30340;&#25193;&#23637;&#24615;&#65292;&#21534;&#21520;&#37327;&#26497;&#39640;&#12290;&#36825;&#20063;&#23601;&#24418;&#25104;&#20102;&#20998;&#24067;&#24335;&#28040;&#36153;&#30340;&#27010;&#24565;&#12290;&#24403;&#21551;&#21160;&#19968;&#20010;consumer group&#21435;&#28040;&#36153;&#19968;&#20010;topic&#30340;&#26102;&#20505;&#65292;&#26080;&#35770;topic&#37324;&#38754;&#26377;&#22810;&#20010;&#23569;&#20010;partition&#65292;&#26080;&#35770;&#25105;&#20204;consumer group&#37324;&#38754;&#37197;&#32622;&#20102;&#22810;&#23569;&#20010;consumer thread&#65292;&#36825;&#20010;consumer group&#19979;&#38754;&#30340;&#25152;&#26377;consumer thread&#19968;&#23450;&#20250;&#28040;&#36153;&#20840;&#37096;&#30340;partition&#65307;&#21363;&#20415;&#36825;&#20010;consumer group&#19979;&#21482;&#26377;&#19968;&#20010;consumer thread&#65292;&#37027;&#20040;&#36825;&#20010;consumer thread&#20063;&#20250;&#21435;&#28040;&#36153;&#25152;&#26377;&#30340;partition&#12290;&#22240;&#27492;&#65292;&#26368;&#20248;&#30340;&#35774;&#35745;&#23601;&#26159;&#65292;consumer group&#19979;&#30340;consumer thread&#30340;&#25968;&#37327;&#31561;&#20110;partition&#25968;&#37327;&#65292;&#36825;&#26679;&#25928;&#29575;&#26159;&#26368;&#39640;&#30340;&#12290;&#21516;&#19968;partition&#30340;&#19968;&#26465;message&#21482;&#33021;&#34987;&#21516;&#19968;&#20010;Consumer Group&#20869;&#30340;&#19968;&#20010;Consumer&#28040;&#36153;&#12290;&#19981;&#33021;&#22815;&#19968;&#20010;consumer group&#30340;&#22810;&#20010;consumer&#21516;&#26102;&#28040;&#36153;&#19968;&#20010;partition&#12290;&#19968;&#20010;consumer group&#19979;&#65292;&#26080;&#35770;&#26377;&#22810;&#23569;&#20010;consumer&#65292;&#36825;&#20010;consumer group&#19968;&#23450;&#20250;&#21435;&#25226;&#36825;&#20010;topic&#19979;&#25152;&#26377;&#30340;partition&#37117;&#28040;&#36153;&#20102;&#12290;&#24403;consumer group&#37324;&#38754;&#30340;consumer&#25968;&#37327;&#23567;&#20110;&#36825;&#20010;topic&#19979;&#30340;partition&#25968;&#37327;&#30340;&#26102;&#20505;&#65292;&#22914;&#19979;&#22270;groupA,groupB&#65292;&#23601;&#20250;&#20986;&#29616;&#19968;&#20010;conusmer thread&#28040;&#36153;&#22810;&#20010;partition&#30340;&#24773;&#20917;&#65292;&#24635;&#20043;&#26159;&#36825;&#20010;topic&#19979;&#30340;partition&#37117;&#20250;&#34987;&#28040;&#36153;&#12290;&#22914;&#26524;consumer group&#37324;&#38754;&#30340;consumer&#25968;&#37327;&#31561;&#20110;&#36825;&#20010;topic&#19979;&#30340;partition&#25968;&#37327;&#30340;&#26102;&#20505;&#65292;&#22914;&#19979;&#22270;groupC&#65292;&#27492;&#26102;&#25928;&#29575;&#26159;&#26368;&#39640;&#30340;&#65292;&#27599;&#20010;partition&#37117;&#26377;&#19968;&#20010;consumer thread&#21435;&#28040;&#36153;&#12290;&#24403;consumer group&#37324;&#38754;&#30340;consumer&#25968;&#37327;&#22823;&#20110;&#36825;&#20010;topic&#19979;&#30340;partition&#25968;&#37327;&#30340;&#26102;&#20505;&#65292;&#22914;&#19979;&#22270;GroupD&#65292;&#23601;&#20250;&#26377;&#19968;&#20010;consumer thread&#31354;&#38386;&#12290;&#22240;&#27492;&#65292;&#25105;&#20204;&#22312;&#35774;&#23450;consumer group&#30340;&#26102;&#20505;&#65292;&#21482;&#38656;&#35201;&#25351;&#26126;&#37324;&#38754;&#26377;&#20960;&#20010;consumer&#25968;&#37327;&#21363;&#21487;&#65292;&#26080;&#38656;&#25351;&#23450;&#23545;&#24212;&#30340;&#28040;&#36153;partition&#24207;&#21495;&#65292;consumer&#20250;&#33258;&#21160;&#36827;&#34892;rebalance&#12290;&#22810;&#20010;Consumer Group&#19979;&#30340;consumer&#21487;&#20197;&#28040;&#36153;&#21516;&#19968;&#26465;message&#65292;&#20294;&#26159;&#36825;&#31181;&#28040;&#36153;&#20063;&#26159;&#20197;o&#65288;1&#65289;&#30340;&#26041;&#24335;&#39034;&#24207;&#30340;&#35835;&#21462;message&#21435;&#28040;&#36153;,&#65292;&#25152;&#20197;&#19968;&#23450;&#20250;&#37325;&#22797;&#28040;&#36153;&#36825;&#25209;message&#30340;&#65292;&#19981;&#33021;&#21521;AMQ&#37027;&#26679;&#22810;&#20010;BET&#20316;&#20026;consumer&#28040;&#36153;&#65288;&#23545;message&#21152;&#38145;&#65292;&#28040;&#36153;&#30340;&#26102;&#20505;&#19981;&#33021;&#37325;&#22797;&#28040;&#36153;message&#65289;-Consumer Rebalance&#30340;&#35302;&#21457;&#26465;&#20214;&#65306;&#65288;1&#65289;Consumer&#22686;&#21152;&#25110;&#21024;&#38500;&#20250;&#35302;&#21457; Consumer Group&#30340;Rebalance&#65288;2&#65289;Broker&#30340;&#22686;&#21152;&#25110;&#32773;&#20943;&#23569;&#37117;&#20250;&#35302;&#21457; Consumer Rebalance-Consumer&#65306;Consumer&#22788;&#29702;partition&#37324;&#38754;&#30340;message&#30340;&#26102;&#20505;&#26159;o&#65288;1&#65289;&#39034;&#24207;&#35835;&#21462;&#30340;&#12290;&#25152;&#20197;&#24517;&#39035;&#32500;&#25252;&#30528;&#19978;&#19968;&#27425;&#35835;&#21040;&#21738;&#37324;&#30340;offsite&#20449;&#24687;&#12290;high level API,offset&#23384;&#20110;Zookeeper&#20013;&#65292;low level API&#30340;offset&#30001;&#33258;&#24049;&#32500;&#25252;&#12290;&#19968;&#33324;&#26469;&#35828;&#37117;&#26159;&#20351;&#29992;high level api&#30340;&#12290;Consumer&#30340;delivery gurarantee&#65292;&#40664;&#35748;&#26159;&#35835;&#23436;message&#20808;commmit&#20877;&#22788;&#29702;message&#65292;autocommit&#40664;&#35748;&#26159;true&#65292;&#36825;&#26102;&#20505;&#20808;commit&#23601;&#20250;&#26356;&#26032;offsite+1&#65292;&#19968;&#26086;&#22788;&#29702;&#22833;&#36133;&#65292;offsite&#24050;&#32463;+1&#65292;&#36825;&#20010;&#26102;&#20505;&#23601;&#20250;&#20002;message&#65307;&#20063;&#21487;&#20197;&#37197;&#32622;&#25104;&#35835;&#23436;&#28040;&#24687;&#22788;&#29702;&#20877;commit&#65292;&#36825;&#31181;&#24773;&#20917;&#19979;consumer&#31471;&#30340;&#21709;&#24212;&#23601;&#20250;&#27604;&#36739;&#24930;&#30340;&#65292;&#38656;&#35201;&#31561;&#22788;&#29702;&#23436;&#25165;&#34892;&#12290;&#19968;&#33324;&#24773;&#20917;&#19979;&#65292;&#19968;&#23450;&#26159;&#19968;&#20010;consumer group&#22788;&#29702;&#19968;&#20010;topic&#30340;message&#12290;Best Practice&#26159;&#36825;&#20010;consumer group&#37324;&#38754;consumer&#30340;&#25968;&#37327;&#31561;&#20110;topic&#37324;&#38754;partition&#30340;&#25968;&#37327;&#65292;&#36825;&#26679;&#25928;&#29575;&#26159;&#26368;&#39640;&#30340;&#65292;&#19968;&#20010;consumer thread&#22788;&#29702;&#19968;&#20010;partition&#12290;&#22914;&#26524;&#36825;&#20010;consumer group&#37324;&#38754;consumer&#30340;&#25968;&#37327;&#23567;&#20110;topic&#37324;&#38754;partition&#30340;&#25968;&#37327;&#65292;&#23601;&#20250;&#26377;consumer thread&#21516;&#26102;&#22788;&#29702;&#22810;&#20010;partition&#65288;&#36825;&#20010;&#26159;kafka&#33258;&#21160;&#30340;&#26426;&#21046;&#65292;&#25105;&#20204;&#19981;&#29992;&#25351;&#23450;&#65289;&#65292;&#20294;&#26159;&#24635;&#20043;&#36825;&#20010;topic&#37324;&#38754;&#30340;&#25152;&#26377;partition&#37117;&#20250;&#34987;&#22788;&#29702;&#21040;&#30340;&#12290;&#12290;&#22914;&#26524;&#36825;&#20010;consumer group&#37324;&#38754;consumer&#30340;&#25968;&#37327;&#22823;&#20110;topic&#37324;&#38754;partition&#30340;&#25968;&#37327;&#65292;&#22810;&#20986;&#30340;consumer thread&#23601;&#20250;&#38386;&#30528;&#21861;&#20063;&#19981;&#24178;&#65292;&#21097;&#19979;&#30340;&#26159;&#19968;&#20010;consumer thread&#22788;&#29702;&#19968;&#20010;partition&#65292;&#36825;&#23601;&#36896;&#25104;&#20102;&#36164;&#28304;&#30340;&#28010;&#36153;&#65292;&#22240;&#20026;&#19968;&#20010;partition&#19981;&#21487;&#33021;&#34987;&#20004;&#20010;consumer thread&#21435;&#22788;&#29702;&#12290;&#25152;&#20197;&#25105;&#20204;&#32447;&#19978;&#30340;&#20998;&#24067;&#24335;&#22810;&#20010;service&#26381;&#21153;&#65292;&#27599;&#20010;service&#37324;&#38754;&#30340;kafka consumer&#25968;&#37327;&#37117;&#23567;&#20110;&#23545;&#24212;&#30340;topic&#30340;partition&#25968;&#37327;&#65292;&#20294;&#26159;&#25152;&#26377;&#26381;&#21153;&#30340;consumer&#25968;&#37327;&#21482;&#21644;&#31561;&#20110;partition&#30340;&#25968;&#37327;&#65292;&#36825;&#26159;&#22240;&#20026;&#20998;&#24067;&#24335;service&#26381;&#21153;&#30340;&#25152;&#26377;consumer&#37117;&#26469;&#33258;&#19968;&#20010;consumer group&#65292;&#22914;&#26524;&#26469;&#33258;&#19981;&#21516;&#30340;consumer group&#23601;&#20250;&#22788;&#29702;&#37325;&#22797;&#30340;message&#20102;&#65288;&#21516;&#19968;&#20010;consumer group&#19979;&#30340;consumer&#19981;&#33021;&#22788;&#29702;&#21516;&#19968;&#20010;partition&#65292;&#19981;&#21516;&#30340;consumer group&#21487;&#20197;&#22788;&#29702;&#21516;&#19968;&#20010;topic&#65292;&#37027;&#20040;&#37117;&#26159;&#39034;&#24207;&#22788;&#29702;message&#65292;&#19968;&#23450;&#20250;&#22788;&#29702;&#37325;&#22797;&#30340;&#12290;&#19968;&#33324;&#36825;&#31181;&#24773;&#20917;&#37117;&#26159;&#20004;&#20010;&#19981;&#21516;&#30340;&#19994;&#21153;&#36923;&#36753;&#65292;&#25165;&#20250;&#21551;&#21160;&#20004;&#20010;consumer group&#26469;&#22788;&#29702;&#19968;&#20010;topic&#65289;&#12290;&#22914;&#26524;producer&#30340;&#27969;&#37327;&#22686;&#22823;&#65292;&#24403;&#21069;&#30340;topic&#30340;parition&#25968;&#37327;=consumer&#25968;&#37327;&#65292;&#36825;&#26102;&#20505;&#30340;&#24212;&#23545;&#26041;&#24335;&#23601;&#26159;&#24456;&#24819;&#25193;&#23637;&#65306;&#22686;&#21152;topic&#19979;&#30340;partition&#65292;&#21516;&#26102;&#22686;&#21152;&#36825;&#20010;consumer group&#19979;&#30340;consumer&#12290;-Delivery Mode :Kafka producer &#21457;&#36865;message&#19981;&#29992;&#32500;&#25252;message&#30340;offsite&#20449;&#24687;&#65292;&#22240;&#20026;&#36825;&#20010;&#26102;&#20505;&#65292;offsite&#23601;&#30456;&#24403;&#20110;&#19968;&#20010;&#33258;&#22686;id&#65292;producer&#23601;&#23613;&#31649;&#21457;&#36865;message&#23601;&#22909;&#20102;&#12290;&#32780;&#19988;Kafka&#19982;AMQ&#19981;&#21516;&#65292;AMQ&#22823;&#37117;&#29992;&#22312;&#22788;&#29702;&#19994;&#21153;&#36923;&#36753;&#19978;&#65292;&#32780;Kafka&#22823;&#37117;&#26159;&#26085;&#24535;&#65292;&#25152;&#20197;Kafka&#30340;producer&#19968;&#33324;&#37117;&#26159;&#22823;&#25209;&#37327;&#30340;batch&#21457;&#36865;message&#65292;&#21521;&#36825;&#20010;topic&#19968;&#27425;&#24615;&#21457;&#36865;&#19968;&#22823;&#25209;message&#65292;load balance&#21040;&#19968;&#20010;partition&#19978;&#65292;&#19968;&#36215;&#25554;&#36827;&#21435;&#65292;offsite&#20316;&#20026;&#33258;&#22686;id&#33258;&#24049;&#22686;&#21152;&#23601;&#22909;&#12290;&#20294;&#26159;Consumer&#31471;&#26159;&#38656;&#35201;&#32500;&#25252;&#36825;&#20010;partition&#24403;&#21069;&#28040;&#36153;&#21040;&#21738;&#20010;message&#30340;offsite&#20449;&#24687;&#30340;&#65292;&#36825;&#20010;offsite&#20449;&#24687;&#65292;high level api&#26159;&#32500;&#25252;&#22312;Zookeeper&#19978;&#65292;low level api&#26159;&#33258;&#24049;&#30340;&#31243;&#24207;&#32500;&#25252;&#12290;&#65288;Kafka&#31649;&#29702;&#30028;&#38754;&#19978;&#21482;&#33021;&#26174;&#31034;high level api&#30340;consumer&#37096;&#20998;&#65292;&#22240;&#20026;low level api&#30340;partition offsite&#20449;&#24687;&#26159;&#31243;&#24207;&#33258;&#24049;&#32500;&#25252;&#65292;kafka&#26159;&#19981;&#30693;&#36947;&#30340;&#65292;&#26080;&#27861;&#22312;&#31649;&#29702;&#30028;&#38754;&#19978;&#23637;&#31034; &#65289;&#24403;&#20351;&#29992;high level api&#30340;&#26102;&#20505;&#65292;&#20808;&#25343;message&#22788;&#29702;&#65292;&#20877;&#23450;&#26102;&#33258;&#21160;commit offsite+1&#65288;&#20063;&#21487;&#20197;&#25913;&#25104;&#25163;&#21160;&#65289;, &#24182;&#19988;kakfa&#22788;&#29702;message&#26159;&#27809;&#26377;&#38145;&#25805;&#20316;&#30340;&#12290;&#22240;&#27492;&#22914;&#26524;&#22788;&#29702;message&#22833;&#36133;&#65292;&#27492;&#26102;&#36824;&#27809;&#26377;commit offsite+1&#65292;&#24403;consumer thread&#37325;&#21551;&#21518;&#20250;&#37325;&#22797;&#28040;&#36153;&#36825;&#20010;message&#12290;&#20294;&#26159;&#20316;&#20026;&#39640;&#21534;&#21520;&#37327;&#39640;&#24182;&#21457;&#30340;&#23454;&#26102;&#22788;&#29702;&#31995;&#32479;&#65292;at least once&#30340;&#24773;&#20917;&#19979;&#65292;&#33267;&#23569;&#19968;&#27425;&#20250;&#34987;&#22788;&#29702;&#21040;&#65292;&#26159;&#21487;&#20197;&#23481;&#24525;&#30340;&#12290;&#22914;&#26524;&#26080;&#27861;&#23481;&#24525;&#65292;&#23601;&#24471;&#20351;&#29992;low level api&#26469;&#33258;&#24049;&#31243;&#24207;&#32500;&#25252;&#36825;&#20010;offsite&#20449;&#24687;&#65292;&#37027;&#20040;&#24819;&#20160;&#20040;&#26102;&#20505;commit offsite+1&#23601;&#33258;&#24049;&#25630;&#23450;&#20102;&#12290;-Topic & Partition&#65306;Topic&#30456;&#24403;&#20110;&#20256;&#32479;&#28040;&#24687;&#31995;&#32479;MQ&#20013;&#30340;&#19968;&#20010;&#38431;&#21015;queue&#65292;producer&#31471;&#21457;&#36865;&#30340;message&#24517;&#39035;&#25351;&#23450;&#26159;&#21457;&#36865;&#21040;&#21738;&#20010;topic&#65292;&#20294;&#26159;&#19981;&#38656;&#35201;&#25351;&#23450;topic&#19979;&#30340;&#21738;&#20010;partition&#65292;&#22240;&#20026;kafka&#20250;&#25226;&#25910;&#21040;&#30340;message&#36827;&#34892;load balance&#65292;&#22343;&#21248;&#30340;&#20998;&#24067;&#22312;&#36825;&#20010;topic&#19979;&#30340;&#19981;&#21516;&#30340;partition&#19978;&#65288; hash(message) % [broker&#25968;&#37327;] &#65289;&#12290;&#29289;&#29702;&#19978;&#23384;&#20648;&#19978;&#65292;&#36825;&#20010;topic&#20250;&#20998;&#25104;&#19968;&#20010;&#25110;&#22810;&#20010;partition&#65292;&#27599;&#20010;partiton&#30456;&#24403;&#20110;&#26159;&#19968;&#20010;&#23376;queue&#12290;&#22312;&#29289;&#29702;&#32467;&#26500;&#19978;&#65292;&#27599;&#20010;partition&#23545;&#24212;&#19968;&#20010;&#29289;&#29702;&#30340;&#30446;&#24405;&#65288;&#25991;&#20214;&#22841;&#65289;&#65292;&#25991;&#20214;&#22841;&#21629;&#21517;&#26159;[topicname]_[partition]_[&#24207;&#21495;]&#65292;&#19968;&#20010;topic&#21487;&#20197;&#26377;&#26080;&#25968;&#22810;&#30340;partition&#65292;&#26681;&#25454;&#19994;&#21153;&#38656;&#27714;&#21644;&#25968;&#25454;&#37327;&#26469;&#35774;&#32622;&#12290;&#22312;kafka&#37197;&#32622;&#25991;&#20214;&#20013;&#21487;&#38543;&#26102;&#26356;&#39640;num.partitions&#21442;&#25968;&#26469;&#37197;&#32622;&#26356;&#25913;topic&#30340;partition&#25968;&#37327;&#65292;&#22312;&#21019;&#24314;Topic&#26102;&#36890;&#36807;&#21442;&#25968;&#25351;&#23450;parittion&#25968;&#37327;&#12290;Topic&#21019;&#24314;&#20043;&#21518;&#36890;&#36807;Kafka&#25552;&#20379;&#30340;&#24037;&#20855;&#20063;&#21487;&#20197;&#20462;&#25913;partiton&#25968;&#37327;&#12290;&#19968;&#33324;&#26469;&#35828;&#65292;&#65288;1&#65289;&#19968;&#20010;Topic&#30340;Partition&#25968;&#37327;&#22823;&#20110;&#31561;&#20110;Broker&#30340;&#25968;&#37327;&#65292;&#21487;&#20197;&#25552;&#39640;&#21534;&#21520;&#29575;&#12290;&#65288;2&#65289;&#21516;&#19968;&#20010;Partition&#30340;Replica&#23613;&#37327;&#20998;&#25955;&#21040;&#19981;&#21516;&#30340;&#26426;&#22120;&#65292;&#39640;&#21487;&#29992;&#12290;&#24403;add a new partition&#30340;&#26102;&#20505;&#65292;partition&#37324;&#38754;&#30340;message&#19981;&#20250;&#37325;&#26032;&#36827;&#34892;&#20998;&#37197;&#65292;&#21407;&#26469;&#30340;partition&#37324;&#38754;&#30340;message&#25968;&#25454;&#19981;&#20250;&#21464;&#65292;&#26032;&#21152;&#30340;&#36825;&#20010;partition&#21018;&#24320;&#22987;&#26159;&#31354;&#30340;&#65292;&#38543;&#21518;&#36827;&#20837;&#36825;&#20010;topic&#30340;message&#23601;&#20250;&#37325;&#26032;&#21442;&#19982;&#25152;&#26377;partition&#30340;load balance-Partition Replica&#65306;&#27599;&#20010;partition&#21487;&#20197;&#22312;&#20854;&#20182;&#30340;kafka broker&#33410;&#28857;&#19978;&#23384;&#21103;&#26412;&#65292;&#20197;&#20415;&#26576;&#20010;kafka broker&#33410;&#28857;&#23445;&#26426;&#19981;&#20250;&#24433;&#21709;&#36825;&#20010;kafka&#38598;&#32676;&#12290;&#23384;replica&#21103;&#26412;&#30340;&#26041;&#24335;&#26159;&#25353;&#29031;kafka broker&#30340;&#39034;&#24207;&#23384;&#12290;&#20363;&#22914;&#26377;5&#20010;kafka broker&#33410;&#28857;&#65292;&#26576;&#20010;topic&#26377;3&#20010;partition&#65292;&#27599;&#20010;partition&#23384;2&#20010;&#21103;&#26412;&#65292;&#37027;&#20040;partition1&#23384;broker1,broker2&#65292;partition2&#23384;broker2,broker3&#12290;&#12290;&#12290;&#20197;&#27492;&#31867;&#25512;&#65288;replica&#21103;&#26412;&#25968;&#30446;&#19981;&#33021;&#22823;&#20110;kafka broker&#33410;&#28857;&#30340;&#25968;&#30446;&#65292;&#21542;&#21017;&#25253;&#38169;&#12290;&#36825;&#37324;&#30340;replica&#25968;&#20854;&#23454;&#23601;&#26159;partition&#30340;&#21103;&#26412;&#24635;&#25968;&#65292;&#20854;&#20013;&#21253;&#25324;&#19968;&#20010;leader&#65292;&#20854;&#20182;&#30340;&#23601;&#26159;copy&#21103;&#26412;&#65289;&#12290;&#36825;&#26679;&#22914;&#26524;&#26576;&#20010;broker&#23445;&#26426;&#65292;&#20854;&#23454;&#25972;&#20010;kafka&#20869;&#25968;&#25454;&#20381;&#28982;&#26159;&#23436;&#25972;&#30340;&#12290;&#20294;&#26159;&#65292;replica&#21103;&#26412;&#25968;&#36234;&#39640;&#65292;&#31995;&#32479;&#34429;&#28982;&#36234;&#31283;&#23450;&#65292;&#20294;&#26159;&#22238;&#26469;&#24102;&#36164;&#28304;&#21644;&#24615;&#33021;&#19978;&#30340;&#19979;&#38477;&#65307;replica&#21103;&#26412;&#23569;&#30340;&#35805;&#65292;&#20063;&#20250;&#36896;&#25104;&#31995;&#32479;&#20002;&#25968;&#25454;&#30340;&#39118;&#38505;&#12290; &#65288;1&#65289;&#24590;&#26679;&#20256;&#36865;&#28040;&#24687;&#65306;producer&#20808;&#25226;message&#21457;&#36865;&#21040;partition leader&#65292;&#20877;&#30001;leader&#21457;&#36865;&#32473;&#20854;&#20182;partition follower&#12290;&#65288;&#22914;&#26524;&#35753;producer&#21457;&#36865;&#32473;&#27599;&#20010;replica&#37027;&#23601;&#22826;&#24930;&#20102;&#65289; &#65288;2&#65289;&#22312;&#21521;Producer&#21457;&#36865;ACK&#21069;&#38656;&#35201;&#20445;&#35777;&#26377;&#22810;&#23569;&#20010;Replica&#24050;&#32463;&#25910;&#21040;&#35813;&#28040;&#24687;&#65306;&#26681;&#25454;ack&#37197;&#30340;&#20010;&#25968;&#32780;&#23450; &#65288;3&#65289;&#24590;&#26679;&#22788;&#29702;&#26576;&#20010;Replica&#19981;&#24037;&#20316;&#30340;&#24773;&#20917;&#65306;&#22914;&#26524;&#36825;&#20010;&#37096;&#24037;&#20316;&#30340;partition replica&#19981;&#22312;ack&#21015;&#34920;&#20013;&#65292;&#23601;&#26159;producer&#22312;&#21457;&#36865;&#28040;&#24687;&#21040;partition leader&#19978;&#65292;partition leader&#21521;partition follower&#21457;&#36865;message&#27809;&#26377;&#21709;&#24212;&#32780;&#24050;&#65292;&#36825;&#20010;&#19981;&#20250;&#24433;&#21709;&#25972;&#20010;&#31995;&#32479;&#65292;&#20063;&#19981;&#20250;&#26377;&#20160;&#20040;&#38382;&#39064;&#12290;&#22914;&#26524;&#36825;&#20010;&#19981;&#24037;&#20316;&#30340;partition replica&#22312;ack&#21015;&#34920;&#20013;&#30340;&#35805;&#65292;producer&#21457;&#36865;&#30340;message&#30340;&#26102;&#20505;&#20250;&#31561;&#24453;&#36825;&#20010;&#19981;&#24037;&#20316;&#30340;partition replca&#20889;message&#25104;&#21151;&#65292;&#20294;&#26159;&#20250;&#31561;&#21040;time out&#65292;&#28982;&#21518;&#36820;&#22238;&#22833;&#36133;&#22240;&#20026;&#26576;&#20010;ack&#21015;&#34920;&#20013;&#30340;partition replica&#27809;&#26377;&#21709;&#24212;&#65292;&#27492;&#26102;kafka&#20250;&#33258;&#21160;&#30340;&#25226;&#36825;&#20010;&#37096;&#24037;&#20316;&#30340;partition replica&#20174;ack&#21015;&#34920;&#20013;&#31227;&#38500;&#65292;&#20197;&#21518;&#30340;producer&#21457;&#36865;message&#30340;&#26102;&#20505;&#23601;&#19981;&#20250;&#26377;&#36825;&#20010;ack&#21015;&#34920;&#19979;&#30340;&#36825;&#20010;&#37096;&#24037;&#20316;&#30340;partition replica&#20102;&#12290; &#65288;4&#65289;&#24590;&#26679;&#22788;&#29702;Failed Replica&#24674;&#22797;&#22238;&#26469;&#30340;&#24773;&#20917;&#65306;&#22914;&#26524;&#36825;&#20010;partition replica&#20043;&#21069;&#19981;&#22312;ack&#21015;&#34920;&#20013;&#65292;&#37027;&#20040;&#21551;&#21160;&#21518;&#37325;&#26032;&#21463;Zookeeper&#31649;&#29702;&#21363;&#21487;&#65292;&#20043;&#21518;producer&#21457;&#36865;message&#30340;&#26102;&#20505;&#65292;partition leader&#20250;&#32487;&#32493;&#21457;&#36865;message&#21040;&#36825;&#20010;partition follower&#19978;&#12290;&#22914;&#26524;&#36825;&#20010;partition replica&#20043;&#21069;&#22312;ack&#21015;&#34920;&#20013;&#65292;&#27492;&#26102;&#37325;&#21551;&#21518;&#65292;&#38656;&#35201;&#25226;&#36825;&#20010;partition replica&#20877;&#25163;&#21160;&#21152;&#21040;ack&#21015;&#34920;&#20013;&#12290;&#65288;ack&#21015;&#34920;&#26159;&#25163;&#21160;&#28155;&#21152;&#30340;&#65292;&#20986;&#29616;&#26576;&#20010;&#37096;&#24037;&#20316;&#30340;partition replica&#30340;&#26102;&#20505;&#33258;&#21160;&#20174;ack&#21015;&#34920;&#20013;&#31227;&#38500;&#30340;&#65289;-Partition leader&#19982;follower&#65306;partition&#20063;&#26377;leader&#21644;follower&#20043;&#20998;&#12290;leader&#26159;&#20027;partition&#65292;producer&#20889;kafka&#30340;&#26102;&#20505;&#20808;&#20889;partition leader&#65292;&#20877;&#30001;partition leader push&#32473;&#20854;&#20182;&#30340;partition follower&#12290;partition leader&#19982;follower&#30340;&#20449;&#24687;&#21463;Zookeeper&#25511;&#21046;&#65292;&#19968;&#26086;partition leader&#25152;&#22312;&#30340;broker&#33410;&#28857;&#23445;&#26426;&#65292;zookeeper&#20250;&#20914;&#20854;&#20182;&#30340;broker&#30340;partition follower&#19978;&#36873;&#25321;follower&#21464;&#20026;parition leader&#12290;-Topic&#20998;&#37197;partition&#21644;partition replica&#30340;&#31639;&#27861;&#65306;&#65288;1&#65289;&#23558;Broker&#65288;size=n&#65289;&#21644;&#24453;&#20998;&#37197;&#30340;Partition&#25490;&#24207;&#12290;&#65288;2&#65289;&#23558;&#31532;i&#20010;Partition&#20998;&#37197;&#21040;&#31532;&#65288;i%n&#65289;&#20010;Broker&#19978;&#12290;&#65288;3&#65289;&#23558;&#31532;i&#20010;Partition&#30340;&#31532;j&#20010;Replica&#20998;&#37197;&#21040;&#31532;&#65288;(i + j) % n&#65289;&#20010;Broker&#19978;- &#28040;&#24687;&#25237;&#36882;&#21487;&#38752;&#24615;&#19968;&#20010;&#28040;&#24687;&#22914;&#20309;&#31639;&#25237;&#36882;&#25104;&#21151;&#65292;Kafka&#25552;&#20379;&#20102;&#19977;&#31181;&#27169;&#24335;&#65306;- &#31532;&#19968;&#31181;&#26159;&#21861;&#37117;&#19981;&#31649;&#65292;&#21457;&#36865;&#20986;&#21435;&#23601;&#24403;&#20316;&#25104;&#21151;&#65292;&#36825;&#31181;&#24773;&#20917;&#24403;&#28982;&#19981;&#33021;&#20445;&#35777;&#28040;&#24687;&#25104;&#21151;&#25237;&#36882;&#21040;broker&#65307;- &#31532;&#20108;&#31181;&#26159;Master-Slave&#27169;&#22411;&#65292;&#21482;&#26377;&#24403;Master&#21644;&#25152;&#26377;Slave&#37117;&#25509;&#25910;&#21040;&#28040;&#24687;&#26102;&#65292;&#25165;&#31639;&#25237;&#36882;&#25104;&#21151;&#65292;&#36825;&#31181;&#27169;&#22411;&#25552;&#20379;&#20102;&#26368;&#39640;&#30340;&#25237;&#36882;&#21487;&#38752;&#24615;&#65292;&#20294;&#26159;&#25439;&#20260;&#20102;&#24615;&#33021;&#65307;- &#31532;&#19977;&#31181;&#27169;&#22411;&#65292;&#21363;&#21482;&#35201;Master&#30830;&#35748;&#25910;&#21040;&#28040;&#24687;&#23601;&#31639;&#25237;&#36882;&#25104;&#21151;&#65307;&#23454;&#38469;&#20351;&#29992;&#26102;&#65292;&#26681;&#25454;&#24212;&#29992;&#29305;&#24615;&#36873;&#25321;&#65292;&#32477;&#22823;&#22810;&#25968;&#24773;&#20917;&#19979;&#37117;&#20250;&#20013;&#21644;&#21487;&#38752;&#24615;&#21644;&#24615;&#33021;&#36873;&#25321;&#31532;&#19977;&#31181;&#27169;&#22411;&#28040;&#24687;&#22312;broker&#19978;&#30340;&#21487;&#38752;&#24615;&#65292;&#22240;&#20026;&#28040;&#24687;&#20250;&#25345;&#20037;&#21270;&#21040;&#30913;&#30424;&#19978;&#65292;&#25152;&#20197;&#22914;&#26524;&#27491;&#24120;stop&#19968;&#20010;broker&#65292;&#20854;&#19978;&#30340;&#25968;&#25454;&#19981;&#20250;&#20002;&#22833;&#65307;&#20294;&#26159;&#22914;&#26524;&#19981;&#27491;&#24120;stop&#65292;&#21487;&#33021;&#20250;&#20351;&#23384;&#22312;&#39029;&#38754;&#32531;&#23384;&#26469;&#19981;&#21450;&#20889;&#20837;&#30913;&#30424;&#30340;&#28040;&#24687;&#20002;&#22833;&#65292;&#36825;&#21487;&#20197;&#36890;&#36807;&#37197;&#32622;flush&#39029;&#38754;&#32531;&#23384;&#30340;&#21608;&#26399;&#12289;&#38408;&#20540;&#32531;&#35299;&#65292;&#20294;&#26159;&#21516;&#26679;&#20250;&#39057;&#32321;&#30340;&#20889;&#30913;&#30424;&#20250;&#24433;&#21709;&#24615;&#33021;&#65292;&#21448;&#26159;&#19968;&#20010;&#36873;&#25321;&#39064;&#65292;&#26681;&#25454;&#23454;&#38469;&#24773;&#20917;&#37197;&#32622;&#12290;&#28040;&#24687;&#28040;&#36153;&#30340;&#21487;&#38752;&#24615;&#65292;Kafka&#25552;&#20379;&#30340;&#26159;&ldquo;At least once&rdquo;&#27169;&#22411;&#65292;&#22240;&#20026;&#28040;&#24687;&#30340;&#35835;&#21462;&#36827;&#24230;&#30001;offset&#25552;&#20379;&#65292;offset&#21487;&#20197;&#30001;&#28040;&#36153;&#32773;&#33258;&#24049;&#32500;&#25252;&#20063;&#21487;&#20197;&#32500;&#25252;&#22312;zookeeper&#37324;&#65292;&#20294;&#26159;&#24403;&#28040;&#24687;&#28040;&#36153;&#21518;consumer&#25346;&#25481;&#65292;offset&#27809;&#26377;&#21363;&#26102;&#20889;&#22238;&#65292;&#23601;&#26377;&#21487;&#33021;&#21457;&#29983;&#37325;&#22797;&#35835;&#30340;&#24773;&#20917;&#65292;&#36825;&#31181;&#24773;&#20917;&#21516;&#26679;&#21487;&#20197;&#36890;&#36807;&#35843;&#25972;commit offset&#21608;&#26399;&#12289;&#38408;&#20540;&#32531;&#35299;&#65292;&#29978;&#33267;&#28040;&#36153;&#32773;&#33258;&#24049;&#25226;&#28040;&#36153;&#21644;commit offset&#20570;&#25104;&#19968;&#20010;&#20107;&#21153;&#35299;&#20915;&#65292;&#20294;&#26159;&#22914;&#26524;&#20320;&#30340;&#24212;&#29992;&#19981;&#22312;&#20046;&#37325;&#22797;&#28040;&#36153;&#65292;&#37027;&#23601;&#24178;&#33030;&#19981;&#35201;&#35299;&#20915;&#65292;&#20197;&#25442;&#21462;&#26368;&#22823;&#30340;&#24615;&#33021;&#12290;-Partition ack&#65306;&#24403;ack=1&#65292;&#34920;&#31034;producer&#20889;partition leader&#25104;&#21151;&#21518;&#65292;broker&#23601;&#36820;&#22238;&#25104;&#21151;&#65292;&#26080;&#35770;&#20854;&#20182;&#30340;partition follower&#26159;&#21542;&#20889;&#25104;&#21151;&#12290;&#24403;ack=2&#65292;&#34920;&#31034;producer&#20889;partition leader&#21644;&#20854;&#20182;&#19968;&#20010;follower&#25104;&#21151;&#30340;&#26102;&#20505;&#65292;broker&#23601;&#36820;&#22238;&#25104;&#21151;&#65292;&#26080;&#35770;&#20854;&#20182;&#30340;partition follower&#26159;&#21542;&#20889;&#25104;&#21151;&#12290;&#24403;ack=-1[parition&#30340;&#25968;&#37327;]&#30340;&#26102;&#20505;&#65292;&#34920;&#31034;&#21482;&#26377;producer&#20840;&#37096;&#20889;&#25104;&#21151;&#30340;&#26102;&#20505;&#65292;&#25165;&#31639;&#25104;&#21151;&#65292;kafka broker&#25165;&#36820;&#22238;&#25104;&#21151;&#20449;&#24687;&#12290;&#36825;&#37324;&#38656;&#35201;&#27880;&#24847;&#30340;&#26159;&#65292;&#22914;&#26524;ack=1&#30340;&#26102;&#20505;&#65292;&#19968;&#26086;&#26377;&#20010;broker&#23445;&#26426;&#23548;&#33268;partition&#30340;follower&#21644;leader&#20999;&#25442;&#65292;&#20250;&#23548;&#33268;&#20002;&#25968;&#25454;&#12290;-message&#29366;&#24577;&#65306;&#22312;Kafka&#20013;&#65292;&#28040;&#24687;&#30340;&#29366;&#24577;&#34987;&#20445;&#23384;&#22312;consumer&#20013;&#65292;broker&#19981;&#20250;&#20851;&#24515;&#21738;&#20010;&#28040;&#24687;&#34987;&#28040;&#36153;&#20102;&#34987;&#35841;&#28040;&#36153;&#20102;&#65292;&#21482;&#35760;&#24405;&#19968;&#20010;offset&#20540;&#65288;&#25351;&#21521;partition&#20013;&#19979;&#19968;&#20010;&#35201;&#34987;&#28040;&#36153;&#30340;&#28040;&#24687;&#20301;&#32622;&#65289;&#65292;&#36825;&#23601;&#24847;&#21619;&#30528;&#22914;&#26524;consumer&#22788;&#29702;&#19981;&#22909;&#30340;&#35805;&#65292;broker&#19978;&#30340;&#19968;&#20010;&#28040;&#24687;&#21487;&#33021;&#20250;&#34987;&#28040;&#36153;&#22810;&#27425;&#12290;-message&#25345;&#20037;&#21270;&#65306;Kafka&#20013;&#20250;&#25226;&#28040;&#24687;&#25345;&#20037;&#21270;&#21040;&#26412;&#22320;&#25991;&#20214;&#31995;&#32479;&#20013;&#65292;&#24182;&#19988;&#20445;&#25345;o(1)&#26497;&#39640;&#30340;&#25928;&#29575;&#12290;&#25105;&#20204;&#20247;&#25152;&#21608;&#30693;IO&#35835;&#21462;&#26159;&#38750;&#24120;&#32791;&#36164;&#28304;&#30340;&#24615;&#33021;&#20063;&#26159;&#26368;&#24930;&#30340;&#65292;&#36825;&#23601;&#26159;&#20026;&#20102;&#25968;&#25454;&#24211;&#30340;&#29942;&#39048;&#32463;&#24120;&#22312;IO&#19978;&#65292;&#38656;&#35201;&#25442;SSD&#30828;&#30424;&#30340;&#21407;&#22240;&#12290;&#20294;&#26159;Kafka&#20316;&#20026;&#21534;&#21520;&#37327;&#26497;&#39640;&#30340;MQ&#65292;&#21364;&#21487;&#20197;&#38750;&#24120;&#39640;&#25928;&#30340;message&#25345;&#20037;&#21270;&#21040;&#25991;&#20214;&#12290;&#36825;&#26159;&#22240;&#20026;Kafka&#26159;&#39034;&#24207;&#20889;&#20837;o&#65288;1&#65289;&#30340;&#26102;&#38388;&#22797;&#26434;&#24230;&#65292;&#36895;&#24230;&#38750;&#24120;&#24555;&#12290;&#20063;&#26159;&#39640;&#21534;&#21520;&#37327;&#30340;&#21407;&#22240;&#12290;&#30001;&#20110;message&#30340;&#20889;&#20837;&#25345;&#20037;&#21270;&#26159;&#39034;&#24207;&#20889;&#20837;&#30340;&#65292;&#22240;&#27492;message&#22312;&#34987;&#28040;&#36153;&#30340;&#26102;&#20505;&#20063;&#26159;&#25353;&#39034;&#24207;&#34987;&#28040;&#36153;&#30340;&#65292;&#20445;&#35777;partition&#30340;message&#26159;&#39034;&#24207;&#28040;&#36153;&#30340;&#12290;&#19968;&#33324;&#30340;&#26426;&#22120;,&#21333;&#26426;&#27599;&#31186;100k&#26465;&#25968;&#25454;&#12290;-message&#26377;&#25928;&#26399;&#65306;Kafka&#20250;&#38271;&#20037;&#20445;&#30041;&#20854;&#20013;&#30340;&#28040;&#24687;&#65292;&#20197;&#20415;consumer&#21487;&#20197;&#22810;&#27425;&#28040;&#36153;&#65292;&#24403;&#28982;&#20854;&#20013;&#24456;&#22810;&#32454;&#33410;&#26159;&#21487;&#37197;&#32622;&#30340;&#12290;-Produer :Producer&#21521;Topic&#21457;&#36865;message&#65292;&#19981;&#38656;&#35201;&#25351;&#23450;partition&#65292;&#30452;&#25509;&#21457;&#36865;&#23601;&#22909;&#20102;&#12290;kafka&#36890;&#36807;partition ack&#26469;&#25511;&#21046;&#26159;&#21542;&#21457;&#36865;&#25104;&#21151;&#24182;&#25226;&#20449;&#24687;&#36820;&#22238;&#32473;producer&#65292;producer&#21487;&#20197;&#26377;&#20219;&#24847;&#22810;&#30340;thread&#65292;&#36825;&#20123;kafka&#26381;&#21153;&#22120;&#31471;&#26159;&#19981;care&#30340;&#12290;Producer&#31471;&#30340;delivery guarantee&#40664;&#35748;&#26159;At least once&#30340;&#12290;&#20063;&#21487;&#20197;&#35774;&#32622;Producer&#24322;&#27493;&#21457;&#36865;&#23454;&#29616;At most once&#12290;Producer&#21487;&#20197;&#29992;&#20027;&#38190;&#24130;&#31561;&#24615;&#23454;&#29616;Exactly once-Kafka&#39640;&#21534;&#21520;&#37327;&#65306;Kafka&#30340;&#39640;&#21534;&#21520;&#37327;&#20307;&#29616;&#22312;&#35835;&#20889;&#19978;&#65292;&#20998;&#24067;&#24335;&#24182;&#21457;&#30340;&#35835;&#21644;&#20889;&#37117;&#38750;&#24120;&#24555;&#65292;&#20889;&#30340;&#24615;&#33021;&#20307;&#29616;&#22312;&#20197;o(1)&#30340;&#26102;&#38388;&#22797;&#26434;&#24230;&#36827;&#34892;&#39034;&#24207;&#20889;&#20837;&#12290;&#35835;&#30340;&#24615;&#33021;&#20307;&#29616;&#22312;&#20197;o(1)&#30340;&#26102;&#38388;&#22797;&#26434;&#24230;&#36827;&#34892;&#39034;&#24207;&#35835;&#21462;&#65292;&#23545;topic&#36827;&#34892;partition&#20998;&#21306;&#65292;consume group&#20013;&#30340;consume&#32447;&#31243;&#21487;&#20197;&#20197;&#24456;&#39640;&#33021;&#24615;&#33021;&#36827;&#34892;&#39034;&#24207;&#35835;&#12290;- Kafka delivery guarantee(message&#20256;&#36865;&#20445;&#35777;)&#65306;&#65288;1&#65289;At most once&#28040;&#24687;&#21487;&#33021;&#20250;&#20002;&#65292;&#32477;&#23545;&#19981;&#20250;&#37325;&#22797;&#20256;&#36755;&#65307;&#65288;2&#65289;At least once &#28040;&#24687;&#32477;&#23545;&#19981;&#20250;&#20002;&#65292;&#20294;&#26159;&#21487;&#33021;&#20250;&#37325;&#22797;&#20256;&#36755;&#65307;&#65288;3&#65289;Exactly once&#27599;&#26465;&#20449;&#24687;&#32943;&#23450;&#20250;&#34987;&#20256;&#36755;&#19968;&#27425;&#19988;&#20165;&#20256;&#36755;&#19968;&#27425;&#65292;&#36825;&#26159;&#29992;&#25143;&#24819;&#35201;&#30340;&#12290;-&#25209;&#37327;&#21457;&#36865;&#65306;Kafka&#25903;&#25345;&#20197;&#28040;&#24687;&#38598;&#21512;&#20026;&#21333;&#20301;&#36827;&#34892;&#25209;&#37327;&#21457;&#36865;&#65292;&#20197;&#25552;&#39640;push&#25928;&#29575;&#12290;-push-and-pull: Kafka&#20013;&#30340;Producer&#21644;consumer&#37319;&#29992;&#30340;&#26159;push-and-pull&#27169;&#24335;&#65292;&#21363;Producer&#21482;&#31649;&#21521;broker push&#28040;&#24687;&#65292;consumer&#21482;&#31649;&#20174;broker pull&#28040;&#24687;&#65292;&#20004;&#32773;&#23545;&#28040;&#24687;&#30340;&#29983;&#20135;&#21644;&#28040;&#36153;&#26159;&#24322;&#27493;&#30340;&#12290;-Kafka&#38598;&#32676;&#20013;broker&#20043;&#38388;&#30340;&#20851;&#31995;&#65306;&#19981;&#26159;&#20027;&#20174;&#20851;&#31995;&#65292;&#21508;&#20010;broker&#22312;&#38598;&#32676;&#20013;&#22320;&#20301;&#19968;&#26679;&#65292;&#25105;&#20204;&#21487;&#20197;&#38543;&#24847;&#30340;&#22686;&#21152;&#25110;&#21024;&#38500;&#20219;&#20309;&#19968;&#20010;broker&#33410;&#28857;&#12290;-&#36127;&#36733;&#22343;&#34913;&#26041;&#38754;&#65306;Kafka&#25552;&#20379;&#20102;&#19968;&#20010; metadata API&#26469;&#31649;&#29702;broker&#20043;&#38388;&#30340;&#36127;&#36733;&#65288;&#23545;Kafka0.8.x&#32780;&#35328;&#65292;&#23545;&#20110;0.7.x&#20027;&#35201;&#38752;zookeeper&#26469;&#23454;&#29616;&#36127;&#36733;&#22343;&#34913;&#65289;&#12290;-&#21516;&#27493;&#24322;&#27493;&#65306;Producer&#37319;&#29992;&#24322;&#27493;push&#26041;&#24335;&#65292;&#26497;&#22823;&#25552;&#39640;Kafka&#31995;&#32479;&#30340;&#21534;&#21520;&#29575;&#65288;&#21487;&#20197;&#36890;&#36807;&#21442;&#25968;&#25511;&#21046;&#26159;&#37319;&#29992;&#21516;&#27493;&#36824;&#26159;&#24322;&#27493;&#26041;&#24335;&#65289;&#12290;-&#20998;&#21306;&#26426;&#21046;partition&#65306;Kafka&#30340;broker&#31471;&#25903;&#25345;&#28040;&#24687;&#20998;&#21306;partition&#65292;Producer&#21487;&#20197;&#20915;&#23450;&#25226;&#28040;&#24687;&#21457;&#21040;&#21738;&#20010;partition&#65292;&#22312;&#19968;&#20010;partition&#20013;message&#30340;&#39034;&#24207;&#23601;&#26159;Producer&#21457;&#36865;&#28040;&#24687;&#30340;&#39034;&#24207;&#65292;&#19968;&#20010;topic&#20013;&#21487;&#20197;&#26377;&#22810;&#20010;partition&#65292;&#20855;&#20307;partition&#30340;&#25968;&#37327;&#26159;&#21487;&#37197;&#32622;&#30340;&#12290;partition&#30340;&#27010;&#24565;&#20351;&#24471;kafka&#20316;&#20026;MQ&#21487;&#20197;&#27178;&#21521;&#25193;&#23637;&#65292;&#21534;&#21520;&#37327;&#24040;&#22823;&#12290;partition&#21487;&#20197;&#35774;&#32622;replica&#21103;&#26412;&#65292;replica&#21103;&#26412;&#23384;&#22312;&#19981;&#21516;&#30340;kafka broker&#33410;&#28857;&#19978;&#65292;&#31532;&#19968;&#20010;partition&#26159;leader,&#20854;&#20182;&#30340;&#26159;follower&#65292;message&#20808;&#20889;&#21040;partition leader&#19978;&#65292;&#20877;&#30001;partition leader push&#21040;parition follower&#19978;&#12290;&#25152;&#20197;&#35828;kafka&#21487;&#20197;&#27700;&#24179;&#25193;&#23637;&#65292;&#20063;&#23601;&#26159;&#25193;&#23637;partition&#12290;-&#31163;&#32447;&#25968;&#25454;&#35013;&#36733;&#65306;Kafka&#30001;&#20110;&#23545;&#21487;&#25299;&#23637;&#30340;&#25968;&#25454;&#25345;&#20037;&#21270;&#30340;&#25903;&#25345;&#65292;&#23427;&#20063;&#38750;&#24120;&#36866;&#21512;&#21521;Hadoop&#25110;&#32773;&#25968;&#25454;&#20179;&#24211;&#20013;&#36827;&#34892;&#25968;&#25454;&#35013;&#36733;&#12290;-&#23454;&#26102;&#25968;&#25454;&#19982;&#31163;&#32447;&#25968;&#25454;&#65306;kafka&#26082;&#25903;&#25345;&#31163;&#32447;&#25968;&#25454;&#20063;&#25903;&#25345;&#23454;&#26102;&#25968;&#25454;&#65292;&#22240;&#20026;kafka&#30340;message&#25345;&#20037;&#21270;&#21040;&#25991;&#20214;&#65292;&#24182;&#21487;&#20197;&#35774;&#32622;&#26377;&#25928;&#26399;&#65292;&#22240;&#27492;&#21487;&#20197;&#25226;kafka&#20316;&#20026;&#19968;&#20010;&#39640;&#25928;&#30340;&#23384;&#20648;&#26469;&#20351;&#29992;&#65292;&#21487;&#20197;&#20316;&#20026;&#31163;&#32447;&#25968;&#25454;&#20379;&#21518;&#38754;&#30340;&#20998;&#26512;&#12290;&#24403;&#28982;&#20316;&#20026;&#20998;&#24067;&#24335;&#23454;&#26102;&#28040;&#24687;&#31995;&#32479;&#65292;&#22823;&#22810;&#25968;&#24773;&#20917;&#19979;&#36824;&#26159;&#29992;&#20110;&#23454;&#26102;&#30340;&#25968;&#25454;&#22788;&#29702;&#30340;&#65292;&#20294;&#26159;&#24403;cosumer&#28040;&#36153;&#33021;&#21147;&#19979;&#38477;&#30340;&#26102;&#20505;&#21487;&#20197;&#36890;&#36807;message&#30340;&#25345;&#20037;&#21270;&#22312;&#28132;&#31215;&#25968;&#25454;&#22312;kafka&#12290;-&#25554;&#20214;&#25903;&#25345;&#65306;&#29616;&#22312;&#19981;&#23569;&#27963;&#36291;&#30340;&#31038;&#21306;&#24050;&#32463;&#24320;&#21457;&#20986;&#19981;&#23569;&#25554;&#20214;&#26469;&#25299;&#23637;Kafka&#30340;&#21151;&#33021;&#65292;&#22914;&#29992;&#26469;&#37197;&#21512;Storm&#12289;Hadoop&#12289;flume&#30456;&#20851;&#30340;&#25554;&#20214;&#12290;-&#35299;&#32806;: &#30456;&#24403;&#20110;&#19968;&#20010;MQ&#65292;&#20351;&#24471;Producer&#21644;Consumer&#20043;&#38388;&#24322;&#27493;&#30340;&#25805;&#20316;&#65292;&#31995;&#32479;&#20043;&#38388;&#35299;&#32806;-&#20887;&#20313;: replica&#26377;&#22810;&#20010;&#21103;&#26412;&#65292;&#20445;&#35777;&#19968;&#20010;broker node&#23445;&#26426;&#21518;&#19981;&#20250;&#24433;&#21709;&#25972;&#20010;&#26381;&#21153;-&#25193;&#23637;&#24615;: broker&#33410;&#28857;&#21487;&#20197;&#27700;&#24179;&#25193;&#23637;&#65292;partition&#20063;&#21487;&#20197;&#27700;&#24179;&#22686;&#21152;&#65292;partition replica&#20063;&#21487;&#20197;&#27700;&#24179;&#22686;&#21152;-&#23792;&#20540;: &#22312;&#35775;&#38382;&#37327;&#21095;&#22686;&#30340;&#24773;&#20917;&#19979;&#65292;kafka&#27700;&#24179;&#25193;&#23637;, &#24212;&#29992;&#20173;&#28982;&#38656;&#35201;&#32487;&#32493;&#21457;&#25381;&#20316;&#29992;-&#21487;&#24674;&#22797;&#24615;: &#31995;&#32479;&#30340;&#19968;&#37096;&#20998;&#32452;&#20214;&#22833;&#25928;&#26102;&#65292;&#30001;&#20110;&#26377;partition&#30340;replica&#21103;&#26412;&#65292;&#19981;&#20250;&#24433;&#21709;&#21040;&#25972;&#20010;&#31995;&#32479;&#12290;-&#39034;&#24207;&#20445;&#35777;&#24615;&#65306;&#30001;&#20110;kafka&#30340;producer&#30340;&#20889;message&#19982;consumer&#21435;&#35835;message&#37117;&#26159;&#39034;&#24207;&#30340;&#35835;&#20889;&#65292;&#20445;&#35777;&#20102;&#39640;&#25928;&#30340;&#24615;&#33021;&#12290;-&#32531;&#20914;&#65306;&#30001;&#20110;producer&#37027;&#38754;&#21487;&#33021;&#19994;&#21153;&#24456;&#31616;&#21333;&#65292;&#32780;&#21518;&#31471;consumer&#19994;&#21153;&#20250;&#24456;&#22797;&#26434;&#24182;&#26377;&#25968;&#25454;&#24211;&#30340;&#25805;&#20316;&#65292;&#22240;&#27492;&#32943;&#23450;&#26159;producer&#20250;&#27604;consumer&#22788;&#29702;&#36895;&#24230;&#24555;&#65292;&#22914;&#26524;&#27809;&#26377;kafka&#65292;producer&#30452;&#25509;&#35843;&#29992;consumer&#65292;&#37027;&#20040;&#23601;&#20250;&#36896;&#25104;&#25972;&#20010;&#31995;&#32479;&#30340;&#22788;&#29702;&#36895;&#24230;&#24930;&#65292;&#21152;&#19968;&#23618;kafka&#20316;&#20026;MQ&#65292;&#21487;&#20197;&#36215;&#21040;&#32531;&#20914;&#30340;&#20316;&#29992;&#12290;-&#24322;&#27493;&#36890;&#20449;&#65306;&#20316;&#20026;MQ&#65292;Producer&#19982;Consumer&#24322;&#27493;&#36890;&#20449;2.Kafka&#25991;&#20214;&#23384;&#20648;&#26426;&#21046;2.1 Kafka&#37096;&#20998;&#21517;&#35789;&#35299;&#37322;&#22914;&#19979;&#65306;Kafka &#30340;&#21457;&#24067;&#35746;&#38405;&#30340;&#23545;&#35937;&#26159;topic&#12290;&#25105;&#20204;&#21487;&#20197;&#20026;&#27599;&#31867;&#25968;&#25454;&#21019;&#24314;&#19968;&#20010;topic&#65292;&#25226;&#21521;topic&#21457;&#24067;&#28040;&#24687;&#30340;&#23458;&#25143;&#31471;&#31216;&#20316;producer&#65292;&#20174;topic&#35746;&#38405;&#28040;&#24687;&#30340;&#23458;&#25143;&#31471;&#31216;&#20316;consumer&#12290;Producers&#21644;consumers&#21487;&#20197;&#21516;&#26102;&#20174;&#22810;&#20010;topic&#35835;&#20889;&#25968;&#25454;&#12290;&#19968;&#20010;kafka&#38598;&#32676;&#30001;&#19968;&#20010;&#25110;&#22810;&#20010;broker&#26381;&#21153;&#22120;&#32452;&#25104;&#65292;&#23427;&#36127;&#36131;&#25345;&#20037;&#21270;&#21644;&#22791;&#20221;&#20855;&#20307;&#30340;kafka&#28040;&#24687;&#12290;Broker&#65306;Kafka&#33410;&#28857;&#65292;&#19968;&#20010;Kafka&#33410;&#28857;&#23601;&#26159;&#19968;&#20010;broker&#65292;&#22810;&#20010;broker&#21487;&#20197;&#32452;&#25104;&#19968;&#20010;Kafka&#38598;&#32676;&#12290;Topic&#65306;&#19968;&#31867;&#28040;&#24687;&#65292;&#28040;&#24687;&#23384;&#25918;&#30340;&#30446;&#24405;&#21363;&#20027;&#39064;&#65292;&#20363;&#22914;page view&#26085;&#24535;&#12289;click&#26085;&#24535;&#31561;&#37117;&#21487;&#20197;&#20197;topic&#30340;&#24418;&#24335;&#23384;&#22312;&#65292;Kafka&#38598;&#32676;&#33021;&#22815;&#21516;&#26102;&#36127;&#36131;&#22810;&#20010;topic&#30340;&#20998;&#21457;&#12290;Partition&#65306;topic&#29289;&#29702;&#19978;&#30340;&#20998;&#32452;&#65292;&#19968;&#20010;topic&#21487;&#20197;&#20998;&#20026;&#22810;&#20010;partition&#65292;&#27599;&#20010;partition&#26159;&#19968;&#20010;&#26377;&#24207;&#30340;&#38431;&#21015;Segment&#65306;partition&#29289;&#29702;&#19978;&#30001;&#22810;&#20010;segment&#32452;&#25104;&#65292;&#27599;&#20010;Segment&#23384;&#30528;message&#20449;&#24687;Producer: &#29983;&#20135;message&#21457;&#36865;&#21040;topicConsumer: &#35746;&#38405;topic&#28040;&#36153;message, consumer&#20316;&#20026;&#19968;&#20010;&#32447;&#31243;&#26469;&#28040;&#36153;Consumer Group&#65306;&#19968;&#20010;Consumer Group&#21253;&#21547;&#22810;&#20010;consumer, &#36825;&#20010;&#26159;&#39044;&#20808;&#22312;&#37197;&#32622;&#25991;&#20214;&#20013;&#37197;&#32622;&#22909;&#30340;&#12290;&#21508;&#20010;consumer&#65288;consumer &#32447;&#31243;&#65289;&#21487;&#20197;&#32452;&#25104;&#19968;&#20010;&#32452;&#65288;Consumer group &#65289;&#65292;partition&#20013;&#30340;&#27599;&#20010;message&#21482;&#33021;&#34987;&#32452;&#65288;Consumer group &#65289; &#20013;&#30340;&#19968;&#20010;consumer&#65288;consumer &#32447;&#31243; &#65289;&#28040;&#36153;&#65292;&#22914;&#26524;&#19968;&#20010;message&#21487;&#20197;&#34987;&#22810;&#20010;consumer&#65288;consumer &#32447;&#31243; &#65289; &#28040;&#36153;&#30340;&#35805;&#65292;&#37027;&#20040;&#36825;&#20123;consumer&#24517;&#39035;&#22312;&#19981;&#21516;&#30340;&#32452;&#12290;Kafka&#19981;&#25903;&#25345;&#19968;&#20010;partition&#20013;&#30340;message&#30001;&#20004;&#20010;&#25110;&#20004;&#20010;&#20197;&#19978;&#30340;consumer thread&#26469;&#22788;&#29702;&#65292;&#21363;&#20415;&#26159;&#26469;&#33258;&#19981;&#21516;&#30340;consumer group&#30340;&#20063;&#19981;&#34892;&#12290;&#23427;&#19981;&#33021;&#20687;AMQ&#37027;&#26679;&#21487;&#20197;&#22810;&#20010;BET&#20316;&#20026;consumer&#21435;&#22788;&#29702;message&#65292;&#36825;&#26159;&#22240;&#20026;&#22810;&#20010;BET&#21435;&#28040;&#36153;&#19968;&#20010;Queue&#20013;&#30340;&#25968;&#25454;&#30340;&#26102;&#20505;&#65292;&#30001;&#20110;&#35201;&#20445;&#35777;&#19981;&#33021;&#22810;&#20010;&#32447;&#31243;&#25343;&#21516;&#19968;&#26465;message&#65292;&#25152;&#20197;&#23601;&#38656;&#35201;&#34892;&#32423;&#21035;&#24754;&#35266;&#25152;&#65288;for update&#65289;,&#36825;&#23601;&#23548;&#33268;&#20102;consume&#30340;&#24615;&#33021;&#19979;&#38477;&#65292;&#21534;&#21520;&#37327;&#19981;&#22815;&#12290;&#32780;kafka&#20026;&#20102;&#20445;&#35777;&#21534;&#21520;&#37327;&#65292;&#21482;&#20801;&#35768;&#19968;&#20010;consumer&#32447;&#31243;&#21435;&#35775;&#38382;&#19968;&#20010;partition&#12290;&#22914;&#26524;&#35273;&#24471;&#25928;&#29575;&#19981;&#39640;&#30340;&#26102;&#20505;&#65292;&#21487;&#20197;&#21152;partition&#30340;&#25968;&#37327;&#26469;&#27178;&#21521;&#25193;&#23637;&#65292;&#37027;&#20040;&#20877;&#21152;&#26032;&#30340;consumer thread&#21435;&#28040;&#36153;&#12290;&#36825;&#26679;&#27809;&#26377;&#38145;&#31454;&#20105;&#65292;&#20805;&#20998;&#21457;&#25381;&#20102;&#27178;&#21521;&#30340;&#25193;&#23637;&#24615;&#65292;&#21534;&#21520;&#37327;&#26497;&#39640;&#12290;&#36825;&#20063;&#23601;&#24418;&#25104;&#20102;&#20998;&#24067;&#24335;&#28040;&#36153;&#30340;&#27010;&#24565;&#12290;2.2 kafka&#19968;&#20123;&#21407;&#29702;&#27010;&#24565;1.&#25345;&#20037;&#21270;kafka&#20351;&#29992;&#25991;&#20214;&#23384;&#20648;&#28040;&#24687;(append only log),&#36825;&#23601;&#30452;&#25509;&#20915;&#23450;kafka&#22312;&#24615;&#33021;&#19978;&#20005;&#37325;&#20381;&#36182;&#25991;&#20214;&#31995;&#32479;&#30340;&#26412;&#36523;&#29305;&#24615;.&#19988;&#26080;&#35770;&#20219;&#20309;OS&#19979;,&#23545;&#25991;&#20214;&#31995;&#32479;&#26412;&#36523;&#30340;&#20248;&#21270;&#26159;&#38750;&#24120;&#33392;&#38590;&#30340;.&#25991;&#20214;&#32531;&#23384;/&#30452;&#25509;&#20869;&#23384;&#26144;&#23556;&#31561;&#26159;&#24120;&#29992;&#30340;&#25163;&#27573;.&#22240;&#20026;kafka&#26159;&#23545;&#26085;&#24535;&#25991;&#20214;&#36827;&#34892;append&#25805;&#20316;,&#22240;&#27492;&#30913;&#30424;&#26816;&#32034;&#30340;&#24320;&#25903;&#26159;&#36739;&#23567;&#30340;;&#21516;&#26102;&#20026;&#20102;&#20943;&#23569;&#30913;&#30424;&#20889;&#20837;&#30340;&#27425;&#25968;,broker&#20250;&#23558;&#28040;&#24687;&#26242;&#26102;buffer&#36215;&#26469;,&#24403;&#28040;&#24687;&#30340;&#20010;&#25968;(&#25110;&#23610;&#23544;)&#36798;&#21040;&#19968;&#23450;&#38400;&#20540;&#26102;,&#20877;flush&#21040;&#30913;&#30424;,&#36825;&#26679;&#20943;&#23569;&#20102;&#30913;&#30424;IO&#35843;&#29992;&#30340;&#27425;&#25968;.&#23545;&#20110;kafka&#32780;&#35328;,&#36739;&#39640;&#24615;&#33021;&#30340;&#30913;&#30424;,&#23558;&#20250;&#24102;&#26469;&#26356;&#21152;&#30452;&#25509;&#30340;&#24615;&#33021;&#25552;&#21319;.2.&#24615;&#33021;&#38500;&#30913;&#30424;IO&#20043;&#22806;,&#25105;&#20204;&#36824;&#38656;&#35201;&#32771;&#34385;&#32593;&#32476;IO,&#36825;&#30452;&#25509;&#20851;&#31995;&#21040;kafka&#30340;&#21534;&#21520;&#37327;&#38382;&#39064;.kafka&#24182;&#27809;&#26377;&#25552;&#20379;&#22826;&#22810;&#39640;&#36229;&#30340;&#25216;&#24039;;&#23545;&#20110;producer&#31471;,&#21487;&#20197;&#23558;&#28040;&#24687;buffer&#36215;&#26469;,&#24403;&#28040;&#24687;&#30340;&#26465;&#25968;&#36798;&#21040;&#19968;&#23450;&#38400;&#20540;&#26102;,&#25209;&#37327;&#21457;&#36865;&#32473;broker;&#23545;&#20110;consumer&#31471;&#20063;&#26159;&#19968;&#26679;,&#25209;&#37327;fetch&#22810;&#26465;&#28040;&#24687;.&#19981;&#36807;&#28040;&#24687;&#37327;&#30340;&#22823;&#23567;&#21487;&#20197;&#36890;&#36807;&#37197;&#32622;&#25991;&#20214;&#26469;&#25351;&#23450;.&#23545;&#20110;kafka broker&#31471;,&#20284;&#20046;&#26377;&#20010;sendfile&#31995;&#32479;&#35843;&#29992;&#21487;&#20197;&#28508;&#22312;&#30340;&#25552;&#21319;&#32593;&#32476;IO&#30340;&#24615;&#33021;:&#23558;&#25991;&#20214;&#30340;&#25968;&#25454;&#26144;&#23556;&#21040;&#31995;&#32479;&#20869;&#23384;&#20013;,socket&#30452;&#25509;&#35835;&#21462;&#30456;&#24212;&#30340;&#20869;&#23384;&#21306;&#22495;&#21363;&#21487;,&#32780;&#26080;&#38656;&#36827;&#31243;&#20877;&#27425;copy&#21644;&#20132;&#25442;(&#36825;&#37324;&#28041;&#21450;&#21040;"&#30913;&#30424;IO&#25968;&#25454;"/"&#20869;&#26680;&#20869;&#23384;"/"&#36827;&#31243;&#20869;&#23384;"/"&#32593;&#32476;&#32531;&#20914;&#21306;",&#22810;&#32773;&#20043;&#38388;&#30340;&#25968;&#25454;copy).&#20854;&#23454;&#23545;&#20110;producer/consumer/broker&#19977;&#32773;&#32780;&#35328;,CPU&#30340;&#24320;&#25903;&#24212;&#35813;&#37117;&#19981;&#22823;,&#22240;&#27492;&#21551;&#29992;&#28040;&#24687;&#21387;&#32553;&#26426;&#21046;&#26159;&#19968;&#20010;&#33391;&#22909;&#30340;&#31574;&#30053;;&#21387;&#32553;&#38656;&#35201;&#28040;&#32791;&#23569;&#37327;&#30340;CPU&#36164;&#28304;,&#19981;&#36807;&#23545;&#20110;kafka&#32780;&#35328;,&#32593;&#32476;IO&#26356;&#24212;&#35813;&#38656;&#35201;&#32771;&#34385;.&#21487;&#20197;&#23558;&#20219;&#20309;&#22312;&#32593;&#32476;&#19978;&#20256;&#36755;&#30340;&#28040;&#24687;&#37117;&#32463;&#36807;&#21387;&#32553;.kafka&#25903;&#25345;gzip/snappy&#31561;&#22810;&#31181;&#21387;&#32553;&#26041;&#24335;.3.&#36127;&#36733;&#22343;&#34913;kafka&#38598;&#32676;&#20013;&#30340;&#20219;&#20309;&#19968;&#20010;broker,&#37117;&#21487;&#20197;&#21521;producer&#25552;&#20379;metadata&#20449;&#24687;,&#36825;&#20123;metadata&#20013;&#21253;&#21547;"&#38598;&#32676;&#20013;&#23384;&#27963;&#30340;servers&#21015;&#34920;"/"partitions leader&#21015;&#34920;"&#31561;&#20449;&#24687;(&#35831;&#21442;&#30475;zookeeper&#20013;&#30340;&#33410;&#28857;&#20449;&#24687;). &#24403;producer&#33719;&#21462;&#21040;metadata&#20449;&#24687;&#20043;&#21518;, producer&#23558;&#20250;&#21644;Topic&#19979;&#25152;&#26377;partition leader&#20445;&#25345;socket&#36830;&#25509;;&#28040;&#24687;&#30001;producer&#30452;&#25509;&#36890;&#36807;socket&#21457;&#36865;&#21040;broker,&#20013;&#38388;&#19981;&#20250;&#32463;&#36807;&#20219;&#20309;"&#36335;&#30001;&#23618;".&#24322;&#27493;&#21457;&#36865;&#65292;&#23558;&#22810;&#26465;&#28040;&#24687;&#26242;&#19988;&#22312;&#23458;&#25143;&#31471;buffer&#36215;&#26469;,&#24182;&#23558;&#20182;&#20204;&#25209;&#37327;&#21457;&#36865;&#21040;broker;&#23567;&#25968;&#25454;IO&#22826;&#22810;,&#20250;&#25302;&#24930;&#25972;&#20307;&#30340;&#32593;&#32476;&#24310;&#36831;,&#25209;&#37327;&#24310;&#36831;&#21457;&#36865;&#20107;&#23454;&#19978;&#25552;&#21319;&#20102;&#32593;&#32476;&#25928;&#29575;;&#19981;&#36807;&#36825;&#20063;&#26377;&#19968;&#23450;&#30340;&#38544;&#24739;,&#27604;&#22914;&#24403;producer&#22833;&#25928;&#26102;,&#37027;&#20123;&#23578;&#26410;&#21457;&#36865;&#30340;&#28040;&#24687;&#23558;&#20250;&#20002;&#22833;&#12290;4.Topic&#27169;&#22411;&#20854;&#20182;JMS&#23454;&#29616;,&#28040;&#24687;&#28040;&#36153;&#30340;&#20301;&#32622;&#26159;&#26377;prodiver&#20445;&#30041;,&#20197;&#20415;&#36991;&#20813;&#37325;&#22797;&#21457;&#36865;&#28040;&#24687;&#25110;&#32773;&#23558;&#27809;&#26377;&#28040;&#36153;&#25104;&#21151;&#30340;&#28040;&#24687;&#37325;&#21457;&#31561;,&#21516;&#26102;&#36824;&#35201;&#25511;&#21046;&#28040;&#24687;&#30340;&#29366;&#24577;.&#36825;&#23601;&#35201;&#27714;JMS broker&#38656;&#35201;&#22826;&#22810;&#39069;&#22806;&#30340;&#24037;&#20316;.&#22312;kafka&#20013;,partition&#20013;&#30340;&#28040;&#24687;&#21482;&#26377;&#19968;&#20010;consumer&#22312;&#28040;&#36153;,&#19988;&#19981;&#23384;&#22312;&#28040;&#24687;&#29366;&#24577;&#30340;&#25511;&#21046;,&#20063;&#27809;&#26377;&#22797;&#26434;&#30340;&#28040;&#24687;&#30830;&#35748;&#26426;&#21046;,&#21487;&#35265;kafka broker&#31471;&#26159;&#30456;&#24403;&#36731;&#37327;&#32423;&#30340;.&#24403;&#28040;&#24687;&#34987;consumer&#25509;&#25910;&#20043;&#21518;,consumer&#21487;&#20197;&#22312;&#26412;&#22320;&#20445;&#23384;&#26368;&#21518;&#28040;&#24687;&#30340;offset,&#24182;&#38388;&#27463;&#24615;&#30340;&#21521;zookeeper&#27880;&#20876;offset.&#30001;&#27492;&#21487;&#35265;,consumer&#23458;&#25143;&#31471;&#20063;&#24456;&#36731;&#37327;&#32423;&#12290;kafka&#20013;consumer&#36127;&#36131;&#32500;&#25252;&#28040;&#24687;&#30340;&#28040;&#36153;&#35760;&#24405;,&#32780;broker&#21017;&#19981;&#20851;&#24515;&#36825;&#20123;,&#36825;&#31181;&#35774;&#35745;&#19981;&#20165;&#25552;&#39640;&#20102;consumer&#31471;&#30340;&#28789;&#27963;&#24615;,&#20063;&#36866;&#24230;&#30340;&#20943;&#36731;&#20102;broker&#31471;&#35774;&#35745;&#30340;&#22797;&#26434;&#24230;;&#36825;&#26159;&#21644;&#20247;&#22810;JMS prodiver&#30340;&#21306;&#21035;.&#27492;&#22806;,kafka&#20013;&#28040;&#24687;ACK&#30340;&#35774;&#35745;&#20063;&#21644;JMS&#26377;&#24456;&#22823;&#19981;&#21516;,kafka&#20013;&#30340;&#28040;&#24687;&#26159;&#25209;&#37327;(&#36890;&#24120;&#20197;&#28040;&#24687;&#30340;&#26465;&#25968;&#25110;&#32773;chunk&#30340;&#23610;&#23544;&#20026;&#21333;&#20301;)&#21457;&#36865;&#32473;consumer,&#24403;&#28040;&#24687;&#28040;&#36153;&#25104;&#21151;&#21518;,&#21521;zookeeper&#25552;&#20132;&#28040;&#24687;&#30340;offset,&#32780;&#19981;&#20250;&#21521;broker&#20132;&#20184;ACK.&#25110;&#35768;&#20320;&#24050;&#32463;&#24847;&#35782;&#21040;,&#36825;&#31181;"&#23485;&#26494;"&#30340;&#35774;&#35745;,&#23558;&#20250;&#26377;"&#20002;&#22833;"&#28040;&#24687;/"&#28040;&#24687;&#37325;&#21457;"&#30340;&#21361;&#38505;.5.&#28040;&#24687;&#20256;&#36755;&#19968;&#33268;Kafka&#25552;&#20379;3&#31181;&#28040;&#24687;&#20256;&#36755;&#19968;&#33268;&#24615;&#35821;&#20041;&#65306;&#26368;&#22810;1&#27425;&#65292;&#26368;&#23569;1&#27425;&#65292;&#24688;&#22909;1&#27425;&#12290;&#26368;&#23569;1&#27425;&#65306;&#21487;&#33021;&#20250;&#37325;&#20256;&#25968;&#25454;&#65292;&#26377;&#21487;&#33021;&#20986;&#29616;&#25968;&#25454;&#34987;&#37325;&#22797;&#22788;&#29702;&#30340;&#24773;&#20917;;&#26368;&#22810;1&#27425;&#65306;&#21487;&#33021;&#20250;&#20986;&#29616;&#25968;&#25454;&#20002;&#22833;&#24773;&#20917;;&#24688;&#22909;1&#27425;&#65306;&#24182;&#19981;&#26159;&#25351;&#30495;&#27491;&#21482;&#20256;&#36755;1&#27425;&#65292;&#21482;&#19981;&#36807;&#26377;&#19968;&#20010;&#26426;&#21046;&#12290;&#30830;&#20445;&#19981;&#20250;&#20986;&#29616;&ldquo;&#25968;&#25454;&#34987;&#37325;&#22797;&#22788;&#29702;&rdquo;&#21644;&ldquo;&#25968;&#25454;&#20002;&#22833;&rdquo;&#30340;&#24773;&#20917;&#12290;at most once: &#28040;&#36153;&#32773;fetch&#28040;&#24687;,&#28982;&#21518;&#20445;&#23384;offset,&#28982;&#21518;&#22788;&#29702;&#28040;&#24687;;&#24403;client&#20445;&#23384;offset&#20043;&#21518;,&#20294;&#26159;&#22312;&#28040;&#24687;&#22788;&#29702;&#36807;&#31243;&#20013;consumer&#36827;&#31243;&#22833;&#25928;(crash),&#23548;&#33268;&#37096;&#20998;&#28040;&#24687;&#26410;&#33021;&#32487;&#32493;&#22788;&#29702;.&#37027;&#20040;&#27492;&#21518;&#21487;&#33021;&#20854;&#20182;consumer&#20250;&#25509;&#31649;,&#20294;&#26159;&#22240;&#20026;offset&#24050;&#32463;&#25552;&#21069;&#20445;&#23384;,&#37027;&#20040;&#26032;&#30340;consumer&#23558;&#19981;&#33021;fetch&#21040;offset&#20043;&#21069;&#30340;&#28040;&#24687;(&#23613;&#31649;&#23427;&#20204;&#23578;&#27809;&#26377;&#34987;&#22788;&#29702;),&#36825;&#23601;&#26159;"at most once".at least once: &#28040;&#36153;&#32773;fetch&#28040;&#24687;,&#28982;&#21518;&#22788;&#29702;&#28040;&#24687;,&#28982;&#21518;&#20445;&#23384;offset.&#22914;&#26524;&#28040;&#24687;&#22788;&#29702;&#25104;&#21151;&#20043;&#21518;,&#20294;&#26159;&#22312;&#20445;&#23384;offset&#38454;&#27573;zookeeper&#24322;&#24120;&#25110;&#32773;consumer&#22833;&#25928;,&#23548;&#33268;&#20445;&#23384;offset&#25805;&#20316;&#26410;&#33021;&#25191;&#34892;&#25104;&#21151;,&#36825;&#23601;&#23548;&#33268;&#25509;&#19979;&#26469;&#20877;&#27425;fetch&#26102;&#21487;&#33021;&#33719;&#24471;&#19978;&#27425;&#24050;&#32463;&#22788;&#29702;&#36807;&#30340;&#28040;&#24687;,&#36825;&#23601;&#26159;"at least once"."Kafka Cluster"&#21040;&#28040;&#36153;&#32773;&#30340;&#22330;&#26223;&#20013;&#21487;&#20197;&#37319;&#21462;&#20197;&#19979;&#26041;&#26696;&#26469;&#24471;&#21040;&ldquo;&#24688;&#22909;1&#27425;&rdquo;&#30340;&#19968;&#33268;&#24615;&#35821;&#20041;&#65306;&#26368;&#23569;1&#27425;&#65291;&#28040;&#36153;&#32773;&#30340;&#36755;&#20986;&#20013;&#39069;&#22806;&#22686;&#21152;&#24050;&#22788;&#29702;&#28040;&#24687;&#26368;&#22823;&#32534;&#21495;&#65306;&#30001;&#20110;&#24050;&#22788;&#29702;&#28040;&#24687;&#26368;&#22823;&#32534;&#21495;&#30340;&#23384;&#22312;&#65292;&#19981;&#20250;&#20986;&#29616;&#37325;&#22797;&#22788;&#29702;&#28040;&#24687;&#30340;&#24773;&#20917;&#12290;6.&#21103;&#26412;kafka&#20013;,replication&#31574;&#30053;&#26159;&#22522;&#20110;partition,&#32780;&#19981;&#26159;topic;kafka&#23558;&#27599;&#20010;partition&#25968;&#25454;&#22797;&#21046;&#21040;&#22810;&#20010;server&#19978;,&#20219;&#20309;&#19968;&#20010;partition&#26377;&#19968;&#20010;leader&#21644;&#22810;&#20010;follower(&#21487;&#20197;&#27809;&#26377;);&#22791;&#20221;&#30340;&#20010;&#25968;&#21487;&#20197;&#36890;&#36807;broker&#37197;&#32622;&#25991;&#20214;&#26469;&#35774;&#23450;&#12290;leader&#22788;&#29702;&#25152;&#26377;&#30340;read-write&#35831;&#27714;,follower&#38656;&#35201;&#21644;leader&#20445;&#25345;&#21516;&#27493;.Follower&#23601;&#20687;&#19968;&#20010;"consumer",&#28040;&#36153;&#28040;&#24687;&#24182;&#20445;&#23384;&#22312;&#26412;&#22320;&#26085;&#24535;&#20013;;leader&#36127;&#36131;&#36319;&#36394;&#25152;&#26377;&#30340;follower&#29366;&#24577;,&#22914;&#26524;follower"&#33853;&#21518;"&#22826;&#22810;&#25110;&#32773;&#22833;&#25928;,leader&#23558;&#20250;&#25226;&#23427;&#20174;replicas&#21516;&#27493;&#21015;&#34920;&#20013;&#21024;&#38500;.&#24403;&#25152;&#26377;&#30340;follower&#37117;&#23558;&#19968;&#26465;&#28040;&#24687;&#20445;&#23384;&#25104;&#21151;,&#27492;&#28040;&#24687;&#25165;&#34987;&#35748;&#20026;&#26159;"committed",&#37027;&#20040;&#27492;&#26102;consumer&#25165;&#33021;&#28040;&#36153;&#23427;,&#36825;&#31181;&#21516;&#27493;&#31574;&#30053;,&#23601;&#35201;&#27714;follower&#21644;leader&#20043;&#38388;&#24517;&#39035;&#20855;&#26377;&#33391;&#22909;&#30340;&#32593;&#32476;&#29615;&#22659;.&#21363;&#20351;&#21482;&#26377;&#19968;&#20010;replicas&#23454;&#20363;&#23384;&#27963;,&#20173;&#28982;&#21487;&#20197;&#20445;&#35777;&#28040;&#24687;&#30340;&#27491;&#24120;&#21457;&#36865;&#21644;&#25509;&#25910;,&#21482;&#35201;zookeeper&#38598;&#32676;&#23384;&#27963;&#21363;&#21487;.&#36873;&#25321;follower&#26102;&#38656;&#35201;&#20860;&#39038;&#19968;&#20010;&#38382;&#39064;,&#23601;&#26159;&#26032;leader server&#19978;&#25152;&#24050;&#32463;&#25215;&#36733;&#30340;partition leader&#30340;&#20010;&#25968;,&#22914;&#26524;&#19968;&#20010;server&#19978;&#26377;&#36807;&#22810;&#30340;partition leader,&#24847;&#21619;&#30528;&#27492;server&#23558;&#25215;&#21463;&#30528;&#26356;&#22810;&#30340;IO&#21387;&#21147;.&#22312;&#36873;&#20030;&#26032;leader,&#38656;&#35201;&#32771;&#34385;&#21040;"&#36127;&#36733;&#22343;&#34913;",partition leader&#36739;&#23569;&#30340;broker&#23558;&#20250;&#26356;&#26377;&#21487;&#33021;&#25104;&#20026;&#26032;&#30340;leader.7.log&#27599;&#20010;log entry&#26684;&#24335;&#20026;"4&#20010;&#23383;&#33410;&#30340;&#25968;&#23383;N&#34920;&#31034;&#28040;&#24687;&#30340;&#38271;&#24230;" + "N&#20010;&#23383;&#33410;&#30340;&#28040;&#24687;&#20869;&#23481;";&#27599;&#20010;&#26085;&#24535;&#37117;&#26377;&#19968;&#20010;offset&#26469;&#21807;&#19968;&#30340;&#26631;&#35760;&#19968;&#26465;&#28040;&#24687;,offset&#30340;&#20540;&#20026;8&#20010;&#23383;&#33410;&#30340;&#25968;&#23383;,&#34920;&#31034;&#27492;&#28040;&#24687;&#22312;&#27492;partition&#20013;&#25152;&#22788;&#30340;&#36215;&#22987;&#20301;&#32622;..&#27599;&#20010;partition&#22312;&#29289;&#29702;&#23384;&#20648;&#23618;&#38754;,&#26377;&#22810;&#20010;log file&#32452;&#25104;(&#31216;&#20026;segment).segment file&#30340;&#21629;&#21517;&#20026;"&#26368;&#23567;offset".kafka.&#20363;&#22914;"00000000000.kafka";&#20854;&#20013;"&#26368;&#23567;offset"&#34920;&#31034;&#27492;segment&#20013;&#36215;&#22987;&#28040;&#24687;&#30340;offset.&#33719;&#21462;&#28040;&#24687;&#26102;,&#38656;&#35201;&#25351;&#23450;offset&#21644;&#26368;&#22823;chunk&#23610;&#23544;,offset&#29992;&#26469;&#34920;&#31034;&#28040;&#24687;&#30340;&#36215;&#22987;&#20301;&#32622;,chunk size&#29992;&#26469;&#34920;&#31034;&#26368;&#22823;&#33719;&#21462;&#28040;&#24687;&#30340;&#24635;&#38271;&#24230;(&#38388;&#25509;&#30340;&#34920;&#31034;&#28040;&#24687;&#30340;&#26465;&#25968;).&#26681;&#25454;offset,&#21487;&#20197;&#25214;&#21040;&#27492;&#28040;&#24687;&#25152;&#22312;segment&#25991;&#20214;,&#28982;&#21518;&#26681;&#25454;segment&#30340;&#26368;&#23567;offset&#21462;&#24046;&#20540;,&#24471;&#21040;&#23427;&#22312;file&#20013;&#30340;&#30456;&#23545;&#20301;&#32622;,&#30452;&#25509;&#35835;&#21462;&#36755;&#20986;&#21363;&#21487;&#12290;8.&#20998;&#24067;&#24335;kafka&#20351;&#29992;zookeeper&#26469;&#23384;&#20648;&#19968;&#20123;meta&#20449;&#24687;,&#24182;&#20351;&#29992;&#20102;zookeeper watch&#26426;&#21046;&#26469;&#21457;&#29616;meta&#20449;&#24687;&#30340;&#21464;&#26356;&#24182;&#20316;&#20986;&#30456;&#24212;&#30340;&#21160;&#20316;(&#27604;&#22914;consumer&#22833;&#25928;,&#35302;&#21457;&#36127;&#36733;&#22343;&#34913;&#31561;)Broker node registry: &#24403;&#19968;&#20010;kafka broker&#21551;&#21160;&#21518;,&#39318;&#20808;&#20250;&#21521;zookeeper&#27880;&#20876;&#33258;&#24049;&#30340;&#33410;&#28857;&#20449;&#24687;(&#20020;&#26102;znode),&#21516;&#26102;&#24403;broker&#21644;zookeeper&#26029;&#24320;&#36830;&#25509;&#26102;,&#27492;znode&#20063;&#20250;&#34987;&#21024;&#38500;.Broker Topic Registry: &#24403;&#19968;&#20010;broker&#21551;&#21160;&#26102;,&#20250;&#21521;zookeeper&#27880;&#20876;&#33258;&#24049;&#25345;&#26377;&#30340;topic&#21644;partitions&#20449;&#24687;,&#20173;&#28982;&#26159;&#19968;&#20010;&#20020;&#26102;znode.Consumer and Consumer group: &#27599;&#20010;consumer&#23458;&#25143;&#31471;&#34987;&#21019;&#24314;&#26102;,&#20250;&#21521;zookeeper&#27880;&#20876;&#33258;&#24049;&#30340;&#20449;&#24687;;&#27492;&#20316;&#29992;&#20027;&#35201;&#26159;&#20026;&#20102;"&#36127;&#36733;&#22343;&#34913;".&#19968;&#20010;group&#20013;&#30340;&#22810;&#20010;consumer&#21487;&#20197;&#20132;&#38169;&#30340;&#28040;&#36153;&#19968;&#20010;topic&#30340;&#25152;&#26377;partitions;&#31616;&#32780;&#35328;&#20043;,&#20445;&#35777;&#27492;topic&#30340;&#25152;&#26377;partitions&#37117;&#33021;&#34987;&#27492;group&#25152;&#28040;&#36153;,&#19988;&#28040;&#36153;&#26102;&#20026;&#20102;&#24615;&#33021;&#32771;&#34385;,&#35753;partition&#30456;&#23545;&#22343;&#34913;&#30340;&#20998;&#25955;&#21040;&#27599;&#20010;consumer&#19978;.Consumer id Registry: &#27599;&#20010;consumer&#37117;&#26377;&#19968;&#20010;&#21807;&#19968;&#30340;ID(host:uuid,&#21487;&#20197;&#36890;&#36807;&#37197;&#32622;&#25991;&#20214;&#25351;&#23450;,&#20063;&#21487;&#20197;&#30001;&#31995;&#32479;&#29983;&#25104;),&#27492;id&#29992;&#26469;&#26631;&#35760;&#28040;&#36153;&#32773;&#20449;&#24687;.Consumer offset Tracking: &#29992;&#26469;&#36319;&#36394;&#27599;&#20010;consumer&#30446;&#21069;&#25152;&#28040;&#36153;&#30340;partition&#20013;&#26368;&#22823;&#30340;offset.&#27492;znode&#20026;&#25345;&#20037;&#33410;&#28857;,&#21487;&#20197;&#30475;&#20986;offset&#36319;group_id&#26377;&#20851;,&#20197;&#34920;&#26126;&#24403;group&#20013;&#19968;&#20010;&#28040;&#36153;&#32773;&#22833;&#25928;,&#20854;&#20182;consumer&#21487;&#20197;&#32487;&#32493;&#28040;&#36153;.Partition Owner registry: &#29992;&#26469;&#26631;&#35760;partition&#27491;&#22312;&#34987;&#21738;&#20010;consumer&#28040;&#36153;.&#20020;&#26102;znode&#12290;&#27492;&#33410;&#28857;&#34920;&#36798;&#20102;"&#19968;&#20010;partition"&#21482;&#33021;&#34987;group&#19979;&#19968;&#20010;consumer&#28040;&#36153;,&#21516;&#26102;&#24403;group&#19979;&#26576;&#20010;consumer&#22833;&#25928;,&#37027;&#20040;&#23558;&#20250;&#35302;&#21457;&#36127;&#36733;&#22343;&#34913;(&#21363;:&#35753;partitions&#22312;&#22810;&#20010;consumer&#38388;&#22343;&#34913;&#28040;&#36153;,&#25509;&#31649;&#37027;&#20123;"&#28216;&#31163;"&#30340;partitions)&#24403;consumer&#21551;&#21160;&#26102;,&#25152;&#35302;&#21457;&#30340;&#25805;&#20316;:A) &#39318;&#20808;&#36827;&#34892;"Consumer id Registry";B) &#28982;&#21518;&#22312;"Consumer id Registry"&#33410;&#28857;&#19979;&#27880;&#20876;&#19968;&#20010;watch&#29992;&#26469;&#30417;&#21548;&#24403;&#21069;group&#20013;&#20854;&#20182;consumer&#30340;"leave"&#21644;"join";&#21482;&#35201;&#27492;znode path&#19979;&#33410;&#28857;&#21015;&#34920;&#21464;&#26356;,&#37117;&#20250;&#35302;&#21457;&#27492;group&#19979;consumer&#30340;&#36127;&#36733;&#22343;&#34913;.(&#27604;&#22914;&#19968;&#20010;consumer&#22833;&#25928;,&#37027;&#20040;&#20854;&#20182;consumer&#25509;&#31649;partitions).C) &#22312;"Broker id registry"&#33410;&#28857;&#19979;,&#27880;&#20876;&#19968;&#20010;watch&#29992;&#26469;&#30417;&#21548;broker&#30340;&#23384;&#27963;&#24773;&#20917;;&#22914;&#26524;broker&#21015;&#34920;&#21464;&#26356;,&#23558;&#20250;&#35302;&#21457;&#25152;&#26377;&#30340;groups&#19979;&#30340;consumer&#37325;&#26032;balance.&#24635;&#32467;:1) Producer&#31471;&#20351;&#29992;zookeeper&#29992;&#26469;"&#21457;&#29616;"broker&#21015;&#34920;,&#20197;&#21450;&#21644;Topic&#19979;&#27599;&#20010;partition leader&#24314;&#31435;socket&#36830;&#25509;&#24182;&#21457;&#36865;&#28040;&#24687;.2) Broker&#31471;&#20351;&#29992;zookeeper&#29992;&#26469;&#27880;&#20876;broker&#20449;&#24687;,&#24050;&#32463;&#30417;&#27979;partition leader&#23384;&#27963;&#24615;.3) Consumer&#31471;&#20351;&#29992;zookeeper&#29992;&#26469;&#27880;&#20876;consumer&#20449;&#24687;,&#20854;&#20013;&#21253;&#25324;consumer&#28040;&#36153;&#30340;partition&#21015;&#34920;&#31561;,&#21516;&#26102;&#20063;&#29992;&#26469;&#21457;&#29616;broker&#21015;&#34920;,&#24182;&#21644;partition leader&#24314;&#31435;socket&#36830;&#25509;&#65292;&#24182;&#33719;&#21462;&#28040;&#24687;&#12290;9.Leader&#30340;&#36873;&#25321;Kafka&#30340;&#26680;&#24515;&#26159;&#26085;&#24535;&#25991;&#20214;&#65292;&#26085;&#24535;&#25991;&#20214;&#22312;&#38598;&#32676;&#20013;&#30340;&#21516;&#27493;&#26159;&#20998;&#24067;&#24335;&#25968;&#25454;&#31995;&#32479;&#26368;&#22522;&#30784;&#30340;&#35201;&#32032;&#12290;&#22914;&#26524;leaders&#27704;&#36828;&#19981;&#20250;down&#30340;&#35805;&#25105;&#20204;&#23601;&#19981;&#38656;&#35201;followers&#20102;&#65281;&#19968;&#26086;leader down&#25481;&#20102;&#65292;&#38656;&#35201;&#22312;followers&#20013;&#36873;&#25321;&#19968;&#20010;&#26032;&#30340;leader.&#20294;&#26159;followers&#26412;&#36523;&#26377;&#21487;&#33021;&#24310;&#26102;&#22826;&#20037;&#25110;&#32773;crash&#65292;&#25152;&#20197;&#24517;&#39035;&#36873;&#25321;&#39640;&#36136;&#37327;&#30340;follower&#20316;&#20026;leader.&#24517;&#39035;&#20445;&#35777;&#65292;&#19968;&#26086;&#19968;&#20010;&#28040;&#24687;&#34987;&#25552;&#20132;&#20102;&#65292;&#20294;&#26159;leader down&#25481;&#20102;&#65292;&#26032;&#36873;&#20986;&#30340;leader&#24517;&#39035;&#21487;&#20197;&#25552;&#20379;&#36825;&#26465;&#28040;&#24687;&#12290;&#22823;&#37096;&#20998;&#30340;&#20998;&#24067;&#24335;&#31995;&#32479;&#37319;&#29992;&#20102;&#22810;&#25968;&#25237;&#31080;&#27861;&#21017;&#36873;&#25321;&#26032;&#30340;leader,&#23545;&#20110;&#22810;&#25968;&#25237;&#31080;&#27861;&#21017;&#65292;&#23601;&#26159;&#26681;&#25454;&#25152;&#26377;&#21103;&#26412;&#33410;&#28857;&#30340;&#29366;&#20917;&#21160;&#24577;&#30340;&#36873;&#25321;&#26368;&#36866;&#21512;&#30340;&#20316;&#20026;leader.Kafka&#24182;&#19981;&#26159;&#20351;&#29992;&#36825;&#31181;&#26041;&#27861;&#12290;Kafka&#21160;&#24577;&#32500;&#25252;&#20102;&#19968;&#20010;&#21516;&#27493;&#29366;&#24577;&#30340;&#21103;&#26412;&#30340;&#38598;&#21512;&#65288;a set of in-sync replicas&#65289;&#65292;&#31616;&#31216;ISR&#65292;&#22312;&#36825;&#20010;&#38598;&#21512;&#20013;&#30340;&#33410;&#28857;&#37117;&#26159;&#21644;leader&#20445;&#25345;&#39640;&#24230;&#19968;&#33268;&#30340;&#65292;&#20219;&#20309;&#19968;&#26465;&#28040;&#24687;&#24517;&#39035;&#34987;&#36825;&#20010;&#38598;&#21512;&#20013;&#30340;&#27599;&#20010;&#33410;&#28857;&#35835;&#21462;&#24182;&#36861;&#21152;&#21040;&#26085;&#24535;&#20013;&#20102;&#65292;&#25165;&#22238;&#36890;&#30693;&#22806;&#37096;&#36825;&#20010;&#28040;&#24687;&#24050;&#32463;&#34987;&#25552;&#20132;&#20102;&#12290;&#22240;&#27492;&#36825;&#20010;&#38598;&#21512;&#20013;&#30340;&#20219;&#20309;&#19968;&#20010;&#33410;&#28857;&#38543;&#26102;&#37117;&#21487;&#20197;&#34987;&#36873;&#20026;leader.ISR&#22312;ZooKeeper&#20013;&#32500;&#25252;&#12290;ISR&#20013;&#26377;f+1&#20010;&#33410;&#28857;&#65292;&#23601;&#21487;&#20197;&#20801;&#35768;&#22312;f&#20010;&#33410;&#28857;down&#25481;&#30340;&#24773;&#20917;&#19979;&#19981;&#20250;&#20002;&#22833;&#28040;&#24687;&#24182;&#27491;&#24120;&#25552;&#20379;&#26381;&#12290;ISR&#30340;&#25104;&#21592;&#26159;&#21160;&#24577;&#30340;&#65292;&#22914;&#26524;&#19968;&#20010;&#33410;&#28857;&#34987;&#28120;&#27760;&#20102;&#65292;&#24403;&#23427;&#37325;&#26032;&#36798;&#21040;&ldquo;&#21516;&#27493;&#20013;&rdquo;&#30340;&#29366;&#24577;&#26102;&#65292;&#20182;&#21487;&#20197;&#37325;&#26032;&#21152;&#20837;ISR.&#36825;&#31181;leader&#30340;&#36873;&#25321;&#26041;&#24335;&#26159;&#38750;&#24120;&#24555;&#36895;&#30340;&#65292;&#36866;&#21512;kafka&#30340;&#24212;&#29992;&#22330;&#26223;&#12290;&#19968;&#20010;&#37034;&#24694;&#30340;&#24819;&#27861;&#65306;&#22914;&#26524;&#25152;&#26377;&#33410;&#28857;&#37117;down&#25481;&#20102;&#24590;&#20040;&#21150;&#65311;Kafka&#23545;&#20110;&#25968;&#25454;&#19981;&#20250;&#20002;&#22833;&#30340;&#20445;&#35777;&#65292;&#26159;&#22522;&#20110;&#33267;&#23569;&#19968;&#20010;&#33410;&#28857;&#26159;&#23384;&#27963;&#30340;&#65292;&#19968;&#26086;&#25152;&#26377;&#33410;&#28857;&#37117;down&#20102;&#65292;&#36825;&#20010;&#23601;&#19981;&#33021;&#20445;&#35777;&#20102;&#12290;&#23454;&#38469;&#24212;&#29992;&#20013;&#65292;&#24403;&#25152;&#26377;&#30340;&#21103;&#26412;&#37117;down&#25481;&#26102;&#65292;&#24517;&#39035;&#21450;&#26102;&#20316;&#20986;&#21453;&#24212;&#12290;&#21487;&#20197;&#26377;&#20197;&#19979;&#20004;&#31181;&#36873;&#25321;:1. &#31561;&#24453;ISR&#20013;&#30340;&#20219;&#20309;&#19968;&#20010;&#33410;&#28857;&#24674;&#22797;&#24182;&#25285;&#20219;leader&#12290;2. &#36873;&#25321;&#25152;&#26377;&#33410;&#28857;&#20013;&#65288;&#19981;&#21482;&#26159;ISR&#65289;&#31532;&#19968;&#20010;&#24674;&#22797;&#30340;&#33410;&#28857;&#20316;&#20026;leader.&#36825;&#26159;&#19968;&#20010;&#22312;&#21487;&#29992;&#24615;&#21644;&#36830;&#32493;&#24615;&#20043;&#38388;&#30340;&#26435;&#34913;&#12290;&#22914;&#26524;&#31561;&#24453;ISR&#20013;&#30340;&#33410;&#28857;&#24674;&#22797;&#65292;&#19968;&#26086;ISR&#20013;&#30340;&#33410;&#28857;&#36215;&#19981;&#36215;&#26469;&#25110;&#32773;&#25968;&#25454;&#37117;&#26159;&#20102;&#65292;&#37027;&#38598;&#32676;&#23601;&#27704;&#36828;&#24674;&#22797;&#19981;&#20102;&#20102;&#12290;&#22914;&#26524;&#31561;&#24453;ISR&#24847;&#22806;&#30340;&#33410;&#28857;&#24674;&#22797;&#65292;&#36825;&#20010;&#33410;&#28857;&#30340;&#25968;&#25454;&#23601;&#20250;&#34987;&#20316;&#20026;&#32447;&#19978;&#25968;&#25454;&#65292;&#26377;&#21487;&#33021;&#21644;&#30495;&#23454;&#30340;&#25968;&#25454;&#26377;&#25152;&#20986;&#20837;&#65292;&#22240;&#20026;&#26377;&#20123;&#25968;&#25454;&#23427;&#21487;&#33021;&#36824;&#27809;&#21516;&#27493;&#21040;&#12290;Kafka&#30446;&#21069;&#36873;&#25321;&#20102;&#31532;&#20108;&#31181;&#31574;&#30053;&#65292;&#22312;&#26410;&#26469;&#30340;&#29256;&#26412;&#20013;&#23558;&#20351;&#36825;&#20010;&#31574;&#30053;&#30340;&#36873;&#25321;&#21487;&#37197;&#32622;&#65292;&#21487;&#20197;&#26681;&#25454;&#22330;&#26223;&#28789;&#27963;&#30340;&#36873;&#25321;&#12290;&#36825;&#31181;&#31384;&#22659;&#19981;&#21482;Kafka&#20250;&#36935;&#21040;&#65292;&#20960;&#20046;&#25152;&#26377;&#30340;&#20998;&#24067;&#24335;&#25968;&#25454;&#31995;&#32479;&#37117;&#20250;&#36935;&#21040;&#12290;10.&#21103;&#26412;&#31649;&#29702;&#20197;&#19978;&#20165;&#20165;&#20197;&#19968;&#20010;topic&#19968;&#20010;&#20998;&#21306;&#20026;&#20363;&#23376;&#36827;&#34892;&#20102;&#35752;&#35770;&#65292;&#20294;&#23454;&#38469;&#19978;&#19968;&#20010;Kafka&#23558;&#20250;&#31649;&#29702;&#25104;&#21315;&#19978;&#19975;&#30340;topic&#20998;&#21306;.Kafka&#23613;&#37327;&#30340;&#20351;&#25152;&#26377;&#20998;&#21306;&#22343;&#21248;&#30340;&#20998;&#24067;&#21040;&#38598;&#32676;&#25152;&#26377;&#30340;&#33410;&#28857;&#19978;&#32780;&#19981;&#26159;&#38598;&#20013;&#22312;&#26576;&#20123;&#33410;&#28857;&#19978;&#65292;&#21478;&#22806;&#20027;&#20174;&#20851;&#31995;&#20063;&#23613;&#37327;&#22343;&#34913;&#36825;&#26679;&#27599;&#20010;&#20960;&#28857;&#37117;&#20250;&#25285;&#20219;&#19968;&#23450;&#27604;&#20363;&#30340;&#20998;&#21306;&#30340;leader.&#20248;&#21270;leader&#30340;&#36873;&#25321;&#36807;&#31243;&#20063;&#26159;&#24456;&#37325;&#35201;&#30340;&#65292;&#23427;&#20915;&#23450;&#20102;&#31995;&#32479;&#21457;&#29983;&#25925;&#38556;&#26102;&#30340;&#31354;&#31383;&#26399;&#26377;&#22810;&#20037;&#12290;Kafka&#36873;&#25321;&#19968;&#20010;&#33410;&#28857;&#20316;&#20026;&ldquo;controller&rdquo;,&#24403;&#21457;&#29616;&#26377;&#33410;&#28857;down&#25481;&#30340;&#26102;&#20505;&#23427;&#36127;&#36131;&#22312;&#28216;&#27891;&#20998;&#21306;&#30340;&#25152;&#26377;&#33410;&#28857;&#20013;&#36873;&#25321;&#26032;&#30340;leader,&#36825;&#20351;&#24471;Kafka&#21487;&#20197;&#25209;&#37327;&#30340;&#39640;&#25928;&#30340;&#31649;&#29702;&#25152;&#26377;&#20998;&#21306;&#33410;&#28857;&#30340;&#20027;&#20174;&#20851;&#31995;&#12290;&#22914;&#26524;controller down&#25481;&#20102;&#65292;&#27963;&#30528;&#30340;&#33410;&#28857;&#20013;&#30340;&#19968;&#20010;&#20250;&#22791;&#20999;&#25442;&#20026;&#26032;&#30340;controller.11.Leader&#19982;&#21103;&#26412;&#21516;&#27493;&#23545;&#20110;&#26576;&#20010;&#20998;&#21306;&#26469;&#35828;&#65292;&#20445;&#23384;&#27491;&#20998;&#21306;&#30340;"broker"&#20026;&#35813;&#20998;&#21306;&#30340;"leader"&#65292;&#20445;&#23384;&#22791;&#20221;&#20998;&#21306;&#30340;"broker"&#20026;&#35813;&#20998;&#21306;&#30340;"follower"&#12290;&#22791;&#20221;&#20998;&#21306;&#20250;&#23436;&#20840;&#22797;&#21046;&#27491;&#20998;&#21306;&#30340;&#28040;&#24687;&#65292;&#21253;&#25324;&#28040;&#24687;&#30340;&#32534;&#21495;&#31561;&#38468;&#21152;&#23646;&#24615;&#20540;&#12290;&#20026;&#20102;&#20445;&#25345;&#27491;&#20998;&#21306;&#21644;&#22791;&#20221;&#20998;&#21306;&#30340;&#20869;&#23481;&#19968;&#33268;&#65292;Kafka&#37319;&#21462;&#30340;&#26041;&#26696;&#26159;&#22312;&#20445;&#23384;&#22791;&#20221;&#20998;&#21306;&#30340;"broker"&#19978;&#24320;&#21551;&#19968;&#20010;&#28040;&#36153;&#32773;&#36827;&#31243;&#36827;&#34892;&#28040;&#36153;&#65292;&#20174;&#32780;&#20351;&#24471;&#27491;&#20998;&#21306;&#30340;&#20869;&#23481;&#19982;&#22791;&#20221;&#20998;&#21306;&#30340;&#20869;&#23481;&#20445;&#25345;&#19968;&#33268;&#12290;&#19968;&#33324;&#24773;&#20917;&#19979;&#65292;&#19968;&#20010;&#20998;&#21306;&#26377;&#19968;&#20010;&ldquo;&#27491;&#20998;&#21306;&rdquo;&#21644;&#38646;&#21040;&#22810;&#20010;&ldquo;&#22791;&#20221;&#20998;&#21306;&rdquo;&#12290;&#21487;&#20197;&#37197;&#32622;&ldquo;&#27491;&#20998;&#21306;+&#22791;&#20221;&#20998;&#21306;&rdquo;&#30340;&#24635;&#25968;&#37327;&#65292;&#20851;&#20110;&#36825;&#20010;&#37197;&#32622;&#65292;&#19981;&#21516;&#20027;&#39064;&#21487;&#20197;&#26377;&#19981;&#21516;&#30340;&#37197;&#32622;&#20540;&#12290;&#27880;&#24847;&#65292;&#29983;&#20135;&#32773;&#65292;&#28040;&#36153;&#32773;&#21482;&#19982;&#20445;&#23384;&#27491;&#20998;&#21306;&#30340;"leader"&#36827;&#34892;&#36890;&#20449;&#12290;Kafka&#20801;&#35768;topic&#30340;&#20998;&#21306;&#25317;&#26377;&#33509;&#24178;&#21103;&#26412;&#65292;&#36825;&#20010;&#25968;&#37327;&#26159;&#21487;&#20197;&#37197;&#32622;&#30340;&#65292;&#20320;&#21487;&#20197;&#20026;&#27599;&#20010;topic&#37197;&#32622;&#21103;&#26412;&#30340;&#25968;&#37327;&#12290;Kafka&#20250;&#33258;&#21160;&#22312;&#27599;&#20010;&#21103;&#26412;&#19978;&#22791;&#20221;&#25968;&#25454;&#65292;&#25152;&#20197;&#24403;&#19968;&#20010;&#33410;&#28857;down&#25481;&#26102;&#25968;&#25454;&#20381;&#28982;&#26159;&#21487;&#29992;&#30340;&#12290;Kafka&#30340;&#21103;&#26412;&#21151;&#33021;&#19981;&#26159;&#24517;&#39035;&#30340;&#65292;&#20320;&#21487;&#20197;&#37197;&#32622;&#21482;&#26377;&#19968;&#20010;&#21103;&#26412;&#65292;&#36825;&#26679;&#20854;&#23454;&#23601;&#30456;&#24403;&#20110;&#21482;&#26377;&#19968;&#20221;&#25968;&#25454;&#12290;&#21019;&#24314;&#21103;&#26412;&#30340;&#21333;&#20301;&#26159;topic&#30340;&#20998;&#21306;&#65292;&#27599;&#20010;&#20998;&#21306;&#37117;&#26377;&#19968;&#20010;leader&#21644;&#38646;&#25110;&#22810;&#20010;followers.&#25152;&#26377;&#30340;&#35835;&#20889;&#25805;&#20316;&#37117;&#30001;leader&#22788;&#29702;&#65292;&#19968;&#33324;&#20998;&#21306;&#30340;&#25968;&#37327;&#37117;&#27604;broker&#30340;&#25968;&#37327;&#22810;&#30340;&#22810;&#65292;&#21508;&#20998;&#21306;&#30340;leader&#22343;&#21248;&#30340;&#20998;&#24067;&#22312;brokers&#20013;&#12290;&#25152;&#26377;&#30340;followers&#37117;&#22797;&#21046;leader&#30340;&#26085;&#24535;&#65292;&#26085;&#24535;&#20013;&#30340;&#28040;&#24687;&#21644;&#39034;&#24207;&#37117;&#21644;leader&#20013;&#30340;&#19968;&#33268;&#12290;followers&#21521;&#26222;&#36890;&#30340;consumer&#37027;&#26679;&#20174;leader&#37027;&#37324;&#25289;&#21462;&#28040;&#24687;&#24182;&#20445;&#23384;&#22312;&#33258;&#24049;&#30340;&#26085;&#24535;&#25991;&#20214;&#20013;&#12290;&#35768;&#22810;&#20998;&#24067;&#24335;&#30340;&#28040;&#24687;&#31995;&#32479;&#33258;&#21160;&#30340;&#22788;&#29702;&#22833;&#36133;&#30340;&#35831;&#27714;&#65292;&#23427;&#20204;&#23545;&#19968;&#20010;&#33410;&#28857;&#26159;&#21542;&#30528;&#65288;alive&#65289;&rdquo;&#26377;&#30528;&#28165;&#26224;&#30340;&#23450;&#20041;&#12290;Kafka&#21028;&#26029;&#19968;&#20010;&#33410;&#28857;&#26159;&#21542;&#27963;&#30528;&#26377;&#20004;&#20010;&#26465;&#20214;&#65306;1. &#33410;&#28857;&#24517;&#39035;&#21487;&#20197;&#32500;&#25252;&#21644;ZooKeeper&#30340;&#36830;&#25509;&#65292;Zookeeper&#36890;&#36807;&#24515;&#36339;&#26426;&#21046;&#26816;&#26597;&#27599;&#20010;&#33410;&#28857;&#30340;&#36830;&#25509;&#12290;2. &#22914;&#26524;&#33410;&#28857;&#26159;&#20010;follower,&#20182;&#24517;&#39035;&#33021;&#21450;&#26102;&#30340;&#21516;&#27493;leader&#30340;&#20889;&#25805;&#20316;&#65292;&#24310;&#26102;&#19981;&#33021;&#22826;&#20037;&#12290;&#31526;&#21512;&#20197;&#19978;&#26465;&#20214;&#30340;&#33410;&#28857;&#20934;&#30830;&#30340;&#35828;&#24212;&#35813;&#26159;&ldquo;&#21516;&#27493;&#20013;&#30340;&#65288;in sync&#65289;&rdquo;&#65292;&#32780;&#19981;&#26159;&#27169;&#31946;&#30340;&#35828;&#26159;&ldquo;&#27963;&#30528;&#30340;&rdquo;&#25110;&#26159;&ldquo;&#22833;&#36133;&#30340;&rdquo;&#12290;Leader&#20250;&#36861;&#36394;&#25152;&#26377;&ldquo;&#21516;&#27493;&#20013;&rdquo;&#30340;&#33410;&#28857;&#65292;&#19968;&#26086;&#19968;&#20010;down&#25481;&#20102;&#65292;&#25110;&#26159;&#21345;&#20303;&#20102;&#65292;&#25110;&#26159;&#24310;&#26102;&#22826;&#20037;&#65292;leader&#23601;&#20250;&#25226;&#23427;&#31227;&#38500;&#12290;&#33267;&#20110;&#24310;&#26102;&#22810;&#20037;&#31639;&#26159;&ldquo;&#22826;&#20037;&rdquo;&#65292;&#26159;&#30001;&#21442;&#25968;replica.lag.max.messages&#20915;&#23450;&#30340;&#65292;&#24590;&#26679;&#31639;&#26159;&#21345;&#20303;&#20102;&#65292;&#24590;&#26159;&#30001;&#21442;&#25968;replica.lag.time.max.ms&#20915;&#23450;&#30340;&#12290;&#21482;&#26377;&#24403;&#28040;&#24687;&#34987;&#25152;&#26377;&#30340;&#21103;&#26412;&#21152;&#20837;&#21040;&#26085;&#24535;&#20013;&#26102;&#65292;&#25165;&#31639;&#26159;&ldquo;committed&rdquo;&#65292;&#21482;&#26377;committed&#30340;&#28040;&#24687;&#25165;&#20250;&#21457;&#36865;&#32473;consumer&#65292;&#36825;&#26679;&#23601;&#19981;&#29992;&#25285;&#24515;&#19968;&#26086;leader down&#25481;&#20102;&#28040;&#24687;&#20250;&#20002;&#22833;&#12290;Producer&#20063;&#21487;&#20197;&#36873;&#25321;&#26159;&#21542;&#31561;&#24453;&#28040;&#24687;&#34987;&#25552;&#20132;&#30340;&#36890;&#30693;&#65292;&#36825;&#20010;&#26159;&#30001;&#21442;&#25968;acks&#20915;&#23450;&#30340;&#12290;Kafka&#20445;&#35777;&#21482;&#35201;&#26377;&#19968;&#20010;&ldquo;&#21516;&#27493;&#20013;&rdquo;&#30340;&#33410;&#28857;&#65292;&ldquo;committed&rdquo;&#30340;&#28040;&#24687;&#23601;&#19981;&#20250;&#20002;&#22833;&#12290;2.3 kafka&#25299;&#25169;&#32467;&#26500;&#19968;&#20010;&#20856;&#22411;&#30340;Kafka&#38598;&#32676;&#20013;&#21253;&#21547;&#33509;&#24178;Producer&#65288;&#21487;&#20197;&#26159;web&#21069;&#31471;FET&#65292;&#25110;&#32773;&#26159;&#26381;&#21153;&#22120;&#26085;&#24535;&#31561;&#65289;&#65292;&#33509;&#24178;broker&#65288;Kafka&#25903;&#25345;&#27700;&#24179;&#25193;&#23637;&#65292;&#19968;&#33324;broker&#25968;&#37327;&#36234;&#22810;&#65292;&#38598;&#32676;&#21534;&#21520;&#29575;&#36234;&#39640;&#65289;&#65292;&#33509;&#24178;ConsumerGroup&#65292;&#20197;&#21450;&#19968;&#20010;Zookeeper&#38598;&#32676;&#12290;Kafka&#36890;&#36807;Zookeeper&#31649;&#29702;Kafka&#38598;&#32676;&#37197;&#32622;&#65306;&#36873;&#20030;Kafka broker&#30340;leader&#65292;&#20197;&#21450;&#22312;Consumer Group&#21457;&#29983;&#21464;&#21270;&#26102;&#36827;&#34892;rebalance&#65292;&#22240;&#20026;consumer&#28040;&#36153;kafka topic&#30340;partition&#30340;offsite&#20449;&#24687;&#26159;&#23384;&#22312;Zookeeper&#30340;&#12290;Producer&#20351;&#29992;push&#27169;&#24335;&#23558;&#28040;&#24687;&#21457;&#24067;&#21040;broker&#65292;Consumer&#20351;&#29992;pull&#27169;&#24335;&#20174;broker&#35746;&#38405;&#24182;&#28040;&#36153;&#28040;&#24687;&#12290;&#20998;&#26512;&#36807;&#31243;&#20998;&#20026;&#20197;&#19979;4&#20010;&#27493;&#39588;&#65306;topic&#20013;partition&#23384;&#20648;&#20998;&#24067;partiton&#20013;&#25991;&#20214;&#23384;&#20648;&#26041;&#24335; (partition&#22312;linux&#26381;&#21153;&#22120;&#19978;&#23601;&#26159;&#19968;&#20010;&#30446;&#24405;&#65288;&#25991;&#20214;&#22841;&#65289;)partiton&#20013;segment&#25991;&#20214;&#23384;&#20648;&#32467;&#26500;&#22312;partition&#20013;&#22914;&#20309;&#36890;&#36807;offset&#26597;&#25214;message&#36890;&#36807;&#19978;&#36848;4&#36807;&#31243;&#35814;&#32454;&#20998;&#26512;&#65292;&#25105;&#20204;&#23601;&#21487;&#20197;&#28165;&#26970;&#35748;&#35782;&#21040;kafka&#25991;&#20214;&#23384;&#20648;&#26426;&#21046;&#30340;&#22885;&#31192;&#12290;2.3 topic&#20013;partition&#23384;&#20648;&#20998;&#24067;&#20551;&#35774;&#23454;&#39564;&#29615;&#22659;&#20013;Kafka&#38598;&#32676;&#21482;&#26377;&#19968;&#20010;broker&#65292;xxx/message-folder&#20026;&#25968;&#25454;&#25991;&#20214;&#23384;&#20648;&#26681;&#30446;&#24405;&#65292;&#22312;Kafka broker&#20013;server.properties&#25991;&#20214;&#37197;&#32622;(&#21442;&#25968;log.dirs=xxx/message-folder)&#65292;&#20363;&#22914;&#21019;&#24314;2&#20010;topic&#21517; &#31216;&#20998;&#21035;&#20026;report_push&#12289;launch_info, partitions&#25968;&#37327;&#37117;&#20026;partitions=4&#23384;&#20648;&#36335;&#24452;&#21644;&#30446;&#24405;&#35268;&#21017;&#20026;&#65306;xxx/message-folder |--report_push-0 |--report_push-1 |--report_push-2 |--report_push-3 |--launch_info-0 |--launch_info-1 |--launch_info-2 |--launch_info-3&#22312;Kafka&#25991;&#20214;&#23384;&#20648;&#20013;&#65292;&#21516;&#19968;&#20010;topic&#19979;&#26377;&#22810;&#20010;&#19981;&#21516;partition&#65292;&#27599;&#20010;partition&#20026;&#19968;&#20010;&#30446;&#24405;&#65292;partiton&#21629;&#21517;&#35268;&#21017;&#20026;topic&#21517;&#31216;+&#26377;&#24207;&#24207;&#21495;&#65292;&#31532;&#19968;&#20010;partiton&#24207;&#21495;&#20174;0&#24320;&#22987;&#65292;&#24207;&#21495;&#26368;&#22823;&#20540;&#20026;partitions&#25968;&#37327;&#20943;1&#12290;&#28040;&#24687;&#21457;&#36865;&#26102;&#37117;&#34987;&#21457;&#36865;&#21040;&#19968;&#20010;topic&#65292;&#20854;&#26412;&#36136;&#23601;&#26159;&#19968;&#20010;&#30446;&#24405;&#65292;&#32780;topic&#30001;&#26159;&#30001;&#19968;&#20123;Partition&#32452;&#25104;&#65292;Partition&#26159;&#19968;&#20010;Queue&#30340;&#32467;&#26500;&#65292;&#27599;&#20010;Partition&#20013;&#30340;&#28040;&#24687;&#37117;&#26159;&#26377;&#24207;&#30340;&#65292;&#29983;&#20135;&#30340;&#28040;&#24687;&#34987;&#19981;&#26029;&#36861;&#21152;&#21040;Partition&#19978;&#65292;&#20854;&#20013;&#30340;&#27599;&#19968;&#20010;&#28040;&#24687;&#37117;&#34987;&#36171;&#20104;&#20102;&#19968;&#20010;&#21807;&#19968;&#30340;offset&#20540;&#12290;Kafka&#38598;&#32676;&#20250;&#20445;&#23384;&#25152;&#26377;&#30340;&#28040;&#24687;&#65292;&#19981;&#31649;&#28040;&#24687;&#26377;&#27809;&#26377;&#34987;&#28040;&#36153;&#65307;&#25105;&#20204;&#21487;&#20197;&#35774;&#23450;&#28040;&#24687;&#30340;&#36807;&#26399;&#26102;&#38388;&#65292;&#21482;&#26377;&#36807;&#26399;&#30340;&#25968;&#25454;&#25165;&#20250;&#34987;&#33258;&#21160;&#28165;&#38500;&#20197;&#37322;&#25918;&#30913;&#30424;&#31354;&#38388;&#12290;&#27604;&#22914;&#25105;&#20204;&#35774;&#32622;&#28040;&#24687;&#36807;&#26399;&#26102;&#38388;&#20026;2&#22825;&#65292;&#37027;&#20040;&#36825;2&#22825;&#20869;&#30340;&#25152;&#26377;&#28040;&#24687;&#37117;&#20250;&#34987;&#20445;&#23384;&#21040;&#38598;&#32676;&#20013;&#65292;&#25968;&#25454;&#21482;&#26377;&#36229;&#36807;&#20102;&#20004;&#22825;&#25165;&#20250;&#34987;&#28165;&#38500;&#12290;Kafka&#21482;&#32500;&#25252;&#22312;Partition&#20013;&#30340;offset&#20540;&#65292;&#22240;&#20026;&#36825;&#20010;offsite&#26631;&#35782;&#30528;&#36825;&#20010;partition&#30340;message&#28040;&#36153;&#21040;&#21738;&#26465;&#20102;&#12290;Consumer&#27599;&#28040;&#36153;&#19968;&#20010;&#28040;&#24687;&#65292;offset&#23601;&#20250;&#21152;1&#12290;&#20854;&#23454;&#28040;&#24687;&#30340;&#29366;&#24577;&#23436;&#20840;&#26159;&#30001;Consumer&#25511;&#21046;&#30340;&#65292;Consumer&#21487;&#20197;&#36319;&#36394;&#21644;&#37325;&#35774;&#36825;&#20010;offset&#20540;&#65292;&#36825;&#26679;&#30340;&#35805;Consumer&#23601;&#21487;&#20197;&#35835;&#21462;&#20219;&#24847;&#20301;&#32622;&#30340;&#28040;&#24687;&#12290;&#25226;&#28040;&#24687;&#26085;&#24535;&#20197;Partition&#30340;&#24418;&#24335;&#23384;&#25918;&#26377;&#22810;&#37325;&#32771;&#34385;&#65292;&#31532;&#19968;&#65292;&#26041;&#20415;&#22312;&#38598;&#32676;&#20013;&#25193;&#23637;&#65292;&#27599;&#20010;Partition&#21487;&#20197;&#36890;&#36807;&#35843;&#25972;&#20197;&#36866;&#24212;&#23427;&#25152;&#22312;&#30340;&#26426;&#22120;&#65292;&#32780;&#19968;&#20010;topic&#21448;&#21487;&#20197;&#26377;&#22810;&#20010;Partition&#32452;&#25104;&#65292;&#22240;&#27492;&#25972;&#20010;&#38598;&#32676;&#23601;&#21487;&#20197;&#36866;&#24212;&#20219;&#24847;&#22823;&#23567;&#30340;&#25968;&#25454;&#20102;&#65307;&#31532;&#20108;&#23601;&#26159;&#21487;&#20197;&#25552;&#39640;&#24182;&#21457;&#65292;&#22240;&#20026;&#21487;&#20197;&#20197;Partition&#20026;&#21333;&#20301;&#35835;&#20889;&#20102;&#12290;&#36890;&#36807;&#19978;&#38754;&#20171;&#32461;&#30340;&#25105;&#20204;&#21487;&#20197;&#30693;&#36947;&#65292;kafka&#20013;&#30340;&#25968;&#25454;&#26159;&#25345;&#20037;&#21270;&#30340;&#24182;&#19988;&#33021;&#22815;&#23481;&#38169;&#30340;&#12290;Kafka&#20801;&#35768;&#29992;&#25143;&#20026;&#27599;&#20010;topic&#35774;&#32622;&#21103;&#26412;&#25968;&#37327;&#65292;&#21103;&#26412;&#25968;&#37327;&#20915;&#23450;&#20102;&#26377;&#20960;&#20010;broker&#26469;&#23384;&#25918;&#20889;&#20837;&#30340;&#25968;&#25454;&#12290;&#22914;&#26524;&#20320;&#30340;&#21103;&#26412;&#25968;&#37327;&#35774;&#32622;&#20026;3&#65292;&#37027;&#20040;&#19968;&#20221;&#25968;&#25454;&#23601;&#20250;&#34987;&#23384;&#25918;&#22312;3&#21488;&#19981;&#21516;&#30340;&#26426;&#22120;&#19978;&#65292;&#37027;&#20040;&#23601;&#20801;&#35768;&#26377;2&#20010;&#26426;&#22120;&#22833;&#36133;&#12290;&#19968;&#33324;&#25512;&#33616;&#21103;&#26412;&#25968;&#37327;&#33267;&#23569;&#20026;2&#65292;&#36825;&#26679;&#23601;&#21487;&#20197;&#20445;&#35777;&#22686;&#20943;&#12289;&#37325;&#21551;&#26426;&#22120;&#26102;&#19981;&#20250;&#24433;&#21709;&#21040;&#25968;&#25454;&#28040;&#36153;&#12290;&#22914;&#26524;&#23545;&#25968;&#25454;&#25345;&#20037;&#21270;&#26377;&#26356;&#39640;&#30340;&#35201;&#27714;&#65292;&#21487;&#20197;&#25226;&#21103;&#26412;&#25968;&#37327;&#35774;&#32622;&#20026;3&#25110;&#32773;&#26356;&#22810;&#12290;Kafka&#20013;&#30340;topic&#26159;&#20197;partition&#30340;&#24418;&#24335;&#23384;&#25918;&#30340;&#65292;&#27599;&#19968;&#20010;topic&#37117;&#21487;&#20197;&#35774;&#32622;&#23427;&#30340;partition&#25968;&#37327;&#65292;Partition&#30340;&#25968;&#37327;&#20915;&#23450;&#20102;&#32452;&#25104;topic&#30340;message&#30340;&#25968;&#37327;&#12290;Producer&#22312;&#29983;&#20135;&#25968;&#25454;&#26102;&#65292;&#20250;&#25353;&#29031;&#19968;&#23450;&#35268;&#21017;&#65288;&#36825;&#20010;&#35268;&#21017;&#26159;&#21487;&#20197;&#33258;&#23450;&#20041;&#30340;&#65289;&#25226;&#28040;&#24687;&#21457;&#24067;&#21040;topic&#30340;&#21508;&#20010;partition&#20013;&#12290;&#19978;&#38754;&#23558;&#30340;&#21103;&#26412;&#37117;&#26159;&#20197;partition&#20026;&#21333;&#20301;&#30340;&#65292;&#19981;&#36807;&#21482;&#26377;&#19968;&#20010;partition&#30340;&#21103;&#26412;&#20250;&#34987;&#36873;&#20030;&#25104;leader&#20316;&#20026;&#35835;&#20889;&#29992;&#12290;&#20851;&#20110;&#22914;&#20309;&#35774;&#32622;partition&#20540;&#38656;&#35201;&#32771;&#34385;&#30340;&#22240;&#32032;&#12290;&#19968;&#20010;partition&#21482;&#33021;&#34987;&#19968;&#20010;&#28040;&#36153;&#32773;&#28040;&#36153;&#65288;&#19968;&#20010;&#28040;&#36153;&#32773;&#21487;&#20197;&#21516;&#26102;&#28040;&#36153;&#22810;&#20010;partition&#65289;&#65292;&#22240;&#27492;&#65292;&#22914;&#26524;&#35774;&#32622;&#30340;partition&#30340;&#25968;&#37327;&#23567;&#20110;consumer&#30340;&#25968;&#37327;&#65292;&#23601;&#20250;&#26377;&#28040;&#36153;&#32773;&#28040;&#36153;&#19981;&#21040;&#25968;&#25454;&#12290;&#25152;&#20197;&#65292;&#25512;&#33616;partition&#30340;&#25968;&#37327;&#19968;&#23450;&#35201;&#22823;&#20110;&#21516;&#26102;&#36816;&#34892;&#30340;consumer&#30340;&#25968;&#37327;&#12290;&#21478;&#22806;&#19968;&#26041;&#38754;&#65292;&#24314;&#35758;partition&#30340;&#25968;&#37327;&#22823;&#20110;&#38598;&#32676;broker&#30340;&#25968;&#37327;&#65292;&#36825;&#26679;leader partition&#23601;&#21487;&#20197;&#22343;&#21248;&#30340;&#20998;&#24067;&#22312;&#21508;&#20010;broker&#20013;&#65292;&#26368;&#32456;&#20351;&#24471;&#38598;&#32676;&#36127;&#36733;&#22343;&#34913;&#12290;&#22312;Cloudera,&#27599;&#20010;topic&#37117;&#26377;&#19978;&#30334;&#20010;partition&#12290;&#38656;&#35201;&#27880;&#24847;&#30340;&#26159;&#65292;kafka&#38656;&#35201;&#20026;&#27599;&#20010;partition&#20998;&#37197;&#19968;&#20123;&#20869;&#23384;&#26469;&#32531;&#23384;&#28040;&#24687;&#25968;&#25454;&#65292;&#22914;&#26524;partition&#25968;&#37327;&#36234;&#22823;&#65292;&#23601;&#35201;&#20026;kafka&#20998;&#37197;&#26356;&#22823;&#30340;heap space&#12290;2.4 partiton&#20013;&#25991;&#20214;&#23384;&#20648;&#26041;&#24335;&#27599;&#20010;partion(&#30446;&#24405;)&#30456;&#24403;&#20110;&#19968;&#20010;&#24040;&#22411;&#25991;&#20214;&#34987;&#24179;&#22343;&#20998;&#37197;&#21040;&#22810;&#20010;&#22823;&#23567;&#30456;&#31561;segment(&#27573;)&#25968;&#25454;&#25991;&#20214;&#20013;&#12290;&#20294;&#27599;&#20010;&#27573;segment file&#28040;&#24687;&#25968;&#37327;&#19981;&#19968;&#23450;&#30456;&#31561;&#65292;&#36825;&#31181;&#29305;&#24615;&#26041;&#20415;old segment file&#24555;&#36895;&#34987;&#21024;&#38500;&#12290;&#27599;&#20010;partiton&#21482;&#38656;&#35201;&#25903;&#25345;&#39034;&#24207;&#35835;&#20889;&#23601;&#34892;&#20102;&#65292;segment&#25991;&#20214;&#29983;&#21629;&#21608;&#26399;&#30001;&#26381;&#21153;&#31471;&#37197;&#32622;&#21442;&#25968;&#20915;&#23450;&#12290;&#36825;&#26679;&#20570;&#30340;&#22909;&#22788;&#23601;&#26159;&#33021;&#24555;&#36895;&#21024;&#38500;&#26080;&#29992;&#25991;&#20214;&#65292;&#26377;&#25928;&#25552;&#39640;&#30913;&#30424;&#21033;&#29992;&#29575;&#12290;2.5 partiton&#20013;segment&#25991;&#20214;&#23384;&#20648;&#32467;&#26500;producer&#21457;message&#21040;&#26576;&#20010;topic&#65292;message&#20250;&#34987;&#22343;&#21248;&#30340;&#20998;&#24067;&#21040;&#22810;&#20010;partition&#19978;&#65288;&#38543;&#26426;&#25110;&#26681;&#25454;&#29992;&#25143;&#25351;&#23450;&#30340;&#22238;&#35843;&#20989;&#25968;&#36827;&#34892;&#20998;&#24067;&#65289;&#65292;kafka broker&#25910;&#21040;message&#24448;&#23545;&#24212;partition&#30340;&#26368;&#21518;&#19968;&#20010;segment&#19978;&#28155;&#21152;&#35813;&#28040;&#24687;&#65292;&#24403;&#26576;&#20010;segment&#19978;&#30340;&#28040;&#24687;&#26465;&#25968;&#36798;&#21040;&#37197;&#32622;&#20540;&#25110;&#28040;&#24687;&#21457;&#24067;&#26102;&#38388;&#36229;&#36807;&#38408;&#20540;&#26102;&#65292;segment&#19978;&#30340;&#28040;&#24687;&#20250;&#34987;flush&#21040;&#30913;&#30424;&#65292;&#21482;&#26377;flush&#21040;&#30913;&#30424;&#19978;&#30340;&#28040;&#24687;consumer&#25165;&#33021;&#28040;&#36153;&#65292;segment&#36798;&#21040;&#19968;&#23450;&#30340;&#22823;&#23567;&#21518;&#23558;&#19981;&#20250;&#20877;&#24448;&#35813;segment&#20889;&#25968;&#25454;&#65292;broker&#20250;&#21019;&#24314;&#26032;&#30340;segment&#12290;&#27599;&#20010;part&#22312;&#20869;&#23384;&#20013;&#23545;&#24212;&#19968;&#20010;index&#65292;&#35760;&#24405;&#27599;&#20010;segment&#20013;&#30340;&#31532;&#19968;&#26465;&#28040;&#24687;&#20559;&#31227;&#12290;segment file&#32452;&#25104;&#65306;&#30001;2&#22823;&#37096;&#20998;&#32452;&#25104;&#65292;&#20998;&#21035;&#20026;index file&#21644;data file&#65292;&#27492;2&#20010;&#25991;&#20214;&#19968;&#19968;&#23545;&#24212;&#65292;&#25104;&#23545;&#20986;&#29616;&#65292;&#21518;&#32512;".index"&#21644;&ldquo;.log&rdquo;&#20998;&#21035;&#34920;&#31034;&#20026;segment&#32034;&#24341;&#25991;&#20214;&#12289;&#25968;&#25454;&#25991;&#20214;.segment&#25991;&#20214;&#21629;&#21517;&#35268;&#21017;&#65306;partion&#20840;&#23616;&#30340;&#31532;&#19968;&#20010;segment&#20174;0&#24320;&#22987;&#65292;&#21518;&#32493;&#27599;&#20010;segment&#25991;&#20214;&#21517;&#20026;&#19978;&#19968;&#20010;&#20840;&#23616;partion&#30340;&#26368;&#22823;offset(&#20559;&#31227;message&#25968;)&#12290;&#25968;&#20540;&#26368;&#22823;&#20026;64&#20301;long&#22823;&#23567;&#65292;19&#20301;&#25968;&#23383;&#23383;&#31526;&#38271;&#24230;&#65292;&#27809;&#26377;&#25968;&#23383;&#29992;0&#22635;&#20805;&#12290;&#27599;&#20010;segment&#20013;&#23384;&#20648;&#24456;&#22810;&#26465;&#28040;&#24687;&#65292;&#28040;&#24687;id&#30001;&#20854;&#36923;&#36753;&#20301;&#32622;&#20915;&#23450;&#65292;&#21363;&#20174;&#28040;&#24687;id&#21487;&#30452;&#25509;&#23450;&#20301;&#21040;&#28040;&#24687;&#30340;&#23384;&#20648;&#20301;&#32622;&#65292;&#36991;&#20813;id&#21040;&#20301;&#32622;&#30340;&#39069;&#22806;&#26144;&#23556;&#12290;&#19979;&#38754;&#25991;&#20214;&#21015;&#34920;&#26159;&#31508;&#32773;&#22312;Kafka broker&#19978;&#20570;&#30340;&#19968;&#20010;&#23454;&#39564;&#65292;&#21019;&#24314;&#19968;&#20010;topicXXX&#21253;&#21547;1 partition&#65292;&#35774;&#32622;&#27599;&#20010;segment&#22823;&#23567;&#20026;500MB,&#24182;&#21551;&#21160;producer&#21521;Kafka broker&#20889;&#20837;&#22823;&#37327;&#25968;&#25454;,&#22914;&#19979;&#22270;2&#25152;&#31034;segment&#25991;&#20214;&#21015;&#34920;&#24418;&#35937;&#35828;&#26126;&#20102;&#19978;&#36848;2&#20010;&#35268;&#21017;&#65306;&#20197;&#19978;&#36848;&#22270;2&#20013;&#19968;&#23545;segment file&#25991;&#20214;&#20026;&#20363;&#65292;&#35828;&#26126;segment&#20013;index<&mdash;->data file&#23545;&#24212;&#20851;&#31995;&#29289;&#29702;&#32467;&#26500;&#22914;&#19979;&#65306;&#19978;&#36848;&#22270;3&#20013;&#32034;&#24341;&#25991;&#20214;&#23384;&#20648;&#22823;&#37327;&#20803;&#25968;&#25454;&#65292;&#25968;&#25454;&#25991;&#20214;&#23384;&#20648;&#22823;&#37327;&#28040;&#24687;&#65292;&#32034;&#24341;&#25991;&#20214;&#20013;&#20803;&#25968;&#25454;&#25351;&#21521;&#23545;&#24212;&#25968;&#25454;&#25991;&#20214;&#20013;message&#30340;&#29289;&#29702;&#20559;&#31227;&#22320;&#22336;&#12290;&#20854;&#20013;&#20197;&#32034;&#24341;&#25991;&#20214;&#20013; &#20803;&#25968;&#25454;3,497&#20026;&#20363;&#65292;&#20381;&#27425;&#22312;&#25968;&#25454;&#25991;&#20214;&#20013;&#34920;&#31034;&#31532;3&#20010;message(&#22312;&#20840;&#23616;partiton&#34920;&#31034;&#31532;368772&#20010;message)&#12289;&#20197;&#21450;&#35813;&#28040;&#24687;&#30340;&#29289;&#29702;&#20559;&#31227; &#22320;&#22336;&#20026;497&#12290;&#20174;&#19978;&#36848;&#22270;3&#20102;&#35299;&#21040;segment data file&#30001;&#35768;&#22810;message&#32452;&#25104;&#65292;&#19979;&#38754;&#35814;&#32454;&#35828;&#26126;message&#29289;&#29702;&#32467;&#26500;&#22914;&#19979;&#65306;&#21442;&#25968;&#35828;&#26126;&#65306;2.6 &#22312;partition&#20013;&#22914;&#20309;&#36890;&#36807;offset&#26597;&#25214;message&#20363;&#22914;&#35835;&#21462;offset=368776&#30340;message&#65292;&#38656;&#35201;&#36890;&#36807;&#19979;&#38754;2&#20010;&#27493;&#39588;&#26597;&#25214;&#12290;&#31532;&#19968;&#27493;&#26597;&#25214;segment file&#19978;&#36848;&#22270;2&#20026;&#20363;&#65292;&#20854;&#20013;00000000000000000000.index&#34920;&#31034;&#26368;&#24320;&#22987;&#30340;&#25991;&#20214;&#65292;&#36215;&#22987;&#20559;&#31227;&#37327;(offset)&#20026;0.&#31532;&#20108;&#20010;&#25991;&#20214; 00000000000000368769.index&#30340;&#28040;&#24687;&#37327;&#36215;&#22987;&#20559;&#31227;&#37327;&#20026;368770 = 368769 + 1.&#21516;&#26679;&#65292;&#31532;&#19977;&#20010;&#25991;&#20214;00000000000000737337.index&#30340;&#36215;&#22987;&#20559;&#31227;&#37327;&#20026;737338=737337 + 1&#65292;&#20854;&#20182;&#21518;&#32493;&#25991;&#20214;&#20381;&#27425;&#31867;&#25512;&#65292;&#20197;&#36215;&#22987;&#20559;&#31227;&#37327;&#21629;&#21517;&#24182;&#25490;&#24207;&#36825;&#20123;&#25991;&#20214;&#65292;&#21482;&#35201;&#26681;&#25454;offset **&#20108;&#20998;&#26597;&#25214;**&#25991;&#20214;&#21015;&#34920;&#65292;&#23601;&#21487;&#20197;&#24555;&#36895;&#23450;&#20301;&#21040;&#20855;&#20307;&#25991;&#20214;&#12290;&#24403;offset=368776&#26102;&#23450;&#20301;&#21040;00000000000000368769.index|log&#31532;&#20108;&#27493;&#36890;&#36807;segment file&#26597;&#25214;message&#36890;&#36807;&#31532;&#19968;&#27493;&#23450;&#20301;&#21040;segment file&#65292;&#24403;offset=368776&#26102;&#65292;&#20381;&#27425;&#23450;&#20301;&#21040;00000000000000368769.index&#30340;&#20803;&#25968;&#25454;&#29289;&#29702;&#20301;&#32622;&#21644; 00000000000000368769.log&#30340;&#29289;&#29702;&#20559;&#31227;&#22320;&#22336;&#65292;&#28982;&#21518;&#20877;&#36890;&#36807;00000000000000368769.log&#39034;&#24207;&#26597;&#25214;&#30452;&#21040; offset=368776&#20026;&#27490;&#12290;segment index file&#37319;&#21462;&#31232;&#30095;&#32034;&#24341;&#23384;&#20648;&#26041;&#24335;&#65292;&#23427;&#20943;&#23569;&#32034;&#24341;&#25991;&#20214;&#22823;&#23567;&#65292;&#36890;&#36807;mmap&#21487;&#20197;&#30452;&#25509;&#20869;&#23384;&#25805;&#20316;&#65292;&#31232;&#30095;&#32034;&#24341;&#20026;&#25968;&#25454;&#25991;&#20214;&#30340;&#27599;&#20010;&#23545;&#24212;message&#35774;&#32622;&#19968;&#20010;&#20803;&#25968;&#25454;&#25351;&#38024;,&#23427; &#27604;&#31264;&#23494;&#32034;&#24341;&#33410;&#30465;&#20102;&#26356;&#22810;&#30340;&#23384;&#20648;&#31354;&#38388;&#65292;&#20294;&#26597;&#25214;&#36215;&#26469;&#38656;&#35201;&#28040;&#32791;&#26356;&#22810;&#30340;&#26102;&#38388;&#12290;kafka&#20250;&#35760;&#24405;offset&#21040;zk&#20013;&#12290;&#20294;&#26159;&#65292;zk client api&#23545;zk&#30340;&#39057;&#32321;&#20889;&#20837;&#26159;&#19968;&#20010;&#20302;&#25928;&#30340;&#25805;&#20316;&#12290;0.8.2 kafka&#24341;&#20837;&#20102;native offset storage&#65292;&#23558;offset&#31649;&#29702;&#20174;zk&#31227;&#20986;&#65292;&#24182;&#19988;&#21487;&#20197;&#20570;&#21040;&#27700;&#24179;&#25193;&#23637;&#12290;&#20854;&#21407;&#29702;&#23601;&#26159;&#21033;&#29992;&#20102;kafka&#30340;compacted topic&#65292;offset&#20197;consumer group,topic&#19982;partion&#30340;&#32452;&#21512;&#20316;&#20026;key&#30452;&#25509;&#25552;&#20132;&#21040;compacted topic&#20013;&#12290;&#21516;&#26102;Kafka&#21448;&#22312;&#20869;&#23384;&#20013;&#32500;&#25252;&#20102;&#30340;&#19977;&#20803;&#32452;&#26469;&#32500;&#25252;&#26368;&#26032;&#30340;offset&#20449;&#24687;&#65292;consumer&#26469;&#21462;&#26368;&#26032;offset&#20449;&#24687;&#30340;&#26102;&#20505;&#30452;&#25509;&#20869;&#23384;&#37324;&#25343;&#21363;&#21487;&#12290;&#24403;&#28982;&#65292;kafka&#20801;&#35768;&#20320;&#24555;&#36895;&#30340;checkpoint&#26368;&#26032;&#30340;offset&#20449;&#24687;&#21040;&#30913;&#30424;&#19978;&#12290;3.Partition Replication&#21407;&#21017;Kafka&#39640;&#25928;&#25991;&#20214;&#23384;&#20648;&#35774;&#35745;&#29305;&#28857;Kafka&#25226;topic&#20013;&#19968;&#20010;parition&#22823;&#25991;&#20214;&#20998;&#25104;&#22810;&#20010;&#23567;&#25991;&#20214;&#27573;&#65292;&#36890;&#36807;&#22810;&#20010;&#23567;&#25991;&#20214;&#27573;&#65292;&#23601;&#23481;&#26131;&#23450;&#26399;&#28165;&#38500;&#25110;&#21024;&#38500;&#24050;&#32463;&#28040;&#36153;&#23436;&#25991;&#20214;&#65292;&#20943;&#23569;&#30913;&#30424;&#21344;&#29992;&#12290;&#36890;&#36807;&#32034;&#24341;&#20449;&#24687;&#21487;&#20197;&#24555;&#36895;&#23450;&#20301;message&#21644;&#30830;&#23450;response&#30340;&#26368;&#22823;&#22823;&#23567;&#12290;&#36890;&#36807;index&#20803;&#25968;&#25454;&#20840;&#37096;&#26144;&#23556;&#21040;memory&#65292;&#21487;&#20197;&#36991;&#20813;segment file&#30340;IO&#30913;&#30424;&#25805;&#20316;&#12290;&#36890;&#36807;&#32034;&#24341;&#25991;&#20214;&#31232;&#30095;&#23384;&#20648;&#65292;&#21487;&#20197;&#22823;&#24133;&#38477;&#20302;index&#25991;&#20214;&#20803;&#25968;&#25454;&#21344;&#29992;&#31354;&#38388;&#22823;&#23567;&#12290;1. Kafka&#38598;&#32676;partition replication&#40664;&#35748;&#33258;&#21160;&#20998;&#37197;&#20998;&#26512;&#19979;&#38754;&#20197;&#19968;&#20010;Kafka&#38598;&#32676;&#20013;4&#20010;Broker&#20030;&#20363;&#65292;&#21019;&#24314;1&#20010;topic&#21253;&#21547;4&#20010;Partition&#65292;2 Replication&#65307;&#25968;&#25454;Producer&#27969;&#21160;&#22914;&#22270;&#25152;&#31034;&#65306;(1)(2)&#24403;&#38598;&#32676;&#20013;&#26032;&#22686;2&#33410;&#28857;&#65292;Partition&#22686;&#21152;&#21040;6&#20010;&#26102;&#20998;&#24067;&#24773;&#20917;&#22914;&#19979;&#65306;&#21103;&#26412;&#20998;&#37197;&#36923;&#36753;&#35268;&#21017;&#22914;&#19979;&#65306;&#22312;Kafka&#38598;&#32676;&#20013;&#65292;&#27599;&#20010;Broker&#37117;&#26377;&#22343;&#31561;&#20998;&#37197;Partition&#30340;Leader&#26426;&#20250;&#12290;&#19978;&#36848;&#22270;Broker Partition&#20013;&#65292;&#31661;&#22836;&#25351;&#21521;&#20026;&#21103;&#26412;&#65292;&#20197;Partition-0&#20026;&#20363;:broker1&#20013;parition-0&#20026;Leader&#65292;Broker2&#20013;Partition-0&#20026;&#21103;&#26412;&#12290;&#19978;&#36848;&#22270;&#31181;&#27599;&#20010;Broker(&#25353;&#29031;BrokerId&#26377;&#24207;)&#20381;&#27425;&#20998;&#37197;&#20027;Partition,&#19979;&#19968;&#20010;Broker&#20026;&#21103;&#26412;&#65292;&#22914;&#27492;&#24490;&#29615;&#36845;&#20195;&#20998;&#37197;&#65292;&#22810;&#21103;&#26412;&#37117;&#36981;&#24490;&#27492;&#35268;&#21017;&#12290;&#21103;&#26412;&#20998;&#37197;&#31639;&#27861;&#22914;&#19979;&#65306;&#23558;&#25152;&#26377;N Broker&#21644;&#24453;&#20998;&#37197;&#30340;i&#20010;Partition&#25490;&#24207;.&#23558;&#31532;i&#20010;Partition&#20998;&#37197;&#21040;&#31532;(i mod n)&#20010;Broker&#19978;.&#23558;&#31532;i&#20010;Partition&#30340;&#31532;j&#20010;&#21103;&#26412;&#20998;&#37197;&#21040;&#31532;((i + j) mod n)&#20010;Broker&#19978;.4.Kafka Broker&#19968;&#20123;&#29305;&#24615;4.1 &#26080;&#29366;&#24577;&#30340;Kafka Broker :1. Broker&#27809;&#26377;&#21103;&#26412;&#26426;&#21046;&#65292;&#19968;&#26086;broker&#23445;&#26426;&#65292;&#35813;broker&#30340;&#28040;&#24687;&#23558;&#37117;&#19981;&#21487;&#29992;&#12290;2. Broker&#19981;&#20445;&#23384;&#35746;&#38405;&#32773;&#30340;&#29366;&#24577;&#65292;&#30001;&#35746;&#38405;&#32773;&#33258;&#24049;&#20445;&#23384;&#12290;3. &#26080;&#29366;&#24577;&#23548;&#33268;&#28040;&#24687;&#30340;&#21024;&#38500;&#25104;&#20026;&#38590;&#39064;&#65288;&#21487;&#33021;&#21024;&#38500;&#30340;&#28040;&#24687;&#27491;&#22312;&#34987;&#35746;&#38405;&#65289;&#65292;kafka&#37319;&#29992;&#22522;&#20110;&#26102;&#38388;&#30340;SLA(&#26381;&#21153;&#27700;&#24179;&#20445;&#35777;)&#65292;&#28040;&#24687;&#20445;&#23384;&#19968;&#23450;&#26102;&#38388;&#65288;&#36890;&#24120;&#20026;7&#22825;&#65289;&#21518;&#20250;&#34987;&#21024;&#38500;&#12290;4. &#28040;&#24687;&#35746;&#38405;&#32773;&#21487;&#20197;rewind back&#21040;&#20219;&#24847;&#20301;&#32622;&#37325;&#26032;&#36827;&#34892;&#28040;&#36153;&#65292;&#24403;&#35746;&#38405;&#32773;&#25925;&#38556;&#26102;&#65292;&#21487;&#20197;&#36873;&#25321;&#26368;&#23567;&#30340;offset&#36827;&#34892;&#37325;&#26032;&#35835;&#21462;&#28040;&#36153;&#28040;&#24687;&#12290;4.2 message&#30340;&#20132;&#20184;&#19982;&#29983;&#21629;&#21608;&#26399; &#65306;1. &#19981;&#26159;&#20005;&#26684;&#30340;JMS&#65292; &#22240;&#27492;kafka&#23545;&#28040;&#24687;&#30340;&#37325;&#22797;&#12289;&#20002;&#22833;&#12289;&#38169;&#35823;&#20197;&#21450;&#39034;&#24207;&#22411;&#27809;&#26377;&#20005;&#26684;&#30340;&#35201;&#27714;&#12290;&#65288;&#36825;&#26159;&#19982;AMQ&#26368;&#22823;&#30340;&#21306;&#21035;&#65289;2. kafka&#25552;&#20379;at-least-once delivery,&#21363;&#24403;consumer&#23445;&#26426;&#21518;&#65292;&#26377;&#20123;&#28040;&#24687;&#21487;&#33021;&#20250;&#34987;&#37325;&#22797;delivery&#12290;3. &#22240;&#27599;&#20010;partition&#21482;&#20250;&#34987;consumer group&#20869;&#30340;&#19968;&#20010;consumer&#28040;&#36153;&#65292;&#25925;kafka&#20445;&#35777;&#27599;&#20010;partition&#20869;&#30340;&#28040;&#24687;&#20250;&#34987;&#39034;&#24207;&#30340;&#35746;&#38405;&#12290;4. Kafka&#20026;&#27599;&#26465;&#28040;&#24687;&#20026;&#27599;&#26465;&#28040;&#24687;&#35745;&#31639;CRC&#26657;&#39564;&#65292;&#29992;&#20110;&#38169;&#35823;&#26816;&#27979;&#65292;crc&#26657;&#39564;&#19981;&#36890;&#36807;&#30340;&#28040;&#24687;&#20250;&#30452;&#25509;&#34987;&#20002;&#24323;&#25481;&#12290;4.3 &#21387;&#32553;Kafka&#25903;&#25345;&#20197;&#38598;&#21512;&#65288;batch&#65289;&#20026;&#21333;&#20301;&#21457;&#36865;&#28040;&#24687;&#65292;&#22312;&#27492;&#22522;&#30784;&#19978;&#65292;Kafka&#36824;&#25903;&#25345;&#23545;&#28040;&#24687;&#38598;&#21512;&#36827;&#34892;&#21387;&#32553;&#65292;Producer&#31471;&#21487;&#20197;&#36890;&#36807;GZIP&#25110;Snappy&#26684;&#24335;&#23545;&#28040;&#24687;&#38598;&#21512;&#36827;&#34892;&#21387;&#32553;&#12290;Producer&#31471;&#36827;&#34892;&#21387;&#32553;&#20043;&#21518;&#65292;&#22312;Consumer&#31471;&#38656;&#36827;&#34892;&#35299;&#21387;&#12290;&#21387;&#32553;&#30340;&#22909;&#22788;&#23601;&#26159;&#20943;&#23569;&#20256;&#36755;&#30340;&#25968;&#25454;&#37327;&#65292;&#20943;&#36731;&#23545;&#32593;&#32476;&#20256;&#36755;&#30340;&#21387;&#21147;&#65292;&#22312;&#23545;&#22823;&#25968;&#25454;&#22788;&#29702;&#19978;&#65292;&#29942;&#39048;&#24448;&#24448;&#20307;&#29616;&#22312;&#32593;&#32476;&#19978;&#32780;&#19981;&#26159;CPU&#12290;&#37027;&#20040;&#22914;&#20309;&#21306;&#20998;&#28040;&#24687;&#26159;&#21387;&#32553;&#30340;&#36824;&#26159;&#26410;&#21387;&#32553;&#30340;&#21602;&#65292;Kafka&#22312;&#28040;&#24687;&#22836;&#37096;&#28155;&#21152;&#20102;&#19968;&#20010;&#25551;&#36848;&#21387;&#32553;&#23646;&#24615;&#23383;&#33410;&#65292;&#36825;&#20010;&#23383;&#33410;&#30340;&#21518;&#20004;&#20301;&#34920;&#31034;&#28040;&#24687;&#30340;&#21387;&#32553;&#37319;&#29992;&#30340;&#32534;&#30721;&#65292;&#22914;&#26524;&#21518;&#20004;&#20301;&#20026;0&#65292;&#21017;&#34920;&#31034;&#28040;&#24687;&#26410;&#34987;&#21387;&#32553;&#12290;4.4 &#28040;&#24687;&#21487;&#38752;&#24615;&#22312;&#28040;&#24687;&#31995;&#32479;&#20013;&#65292;&#20445;&#35777;&#28040;&#24687;&#22312;&#29983;&#20135;&#21644;&#28040;&#36153;&#36807;&#31243;&#20013;&#30340;&#21487;&#38752;&#24615;&#26159;&#21313;&#20998;&#37325;&#35201;&#30340;&#65292;&#22312;&#23454;&#38469;&#28040;&#24687;&#20256;&#36882;&#36807;&#31243;&#20013;&#65292;&#21487;&#33021;&#20250;&#20986;&#29616;&#22914;&#19979;&#19977;&#20013;&#24773;&#20917;&#65306;- &#19968;&#20010;&#28040;&#24687;&#21457;&#36865;&#22833;&#36133;- &#19968;&#20010;&#28040;&#24687;&#34987;&#21457;&#36865;&#22810;&#27425;- &#26368;&#29702;&#24819;&#30340;&#24773;&#20917;&#65306;exactly-once ,&#19968;&#20010;&#28040;&#24687;&#21457;&#36865;&#25104;&#21151;&#19988;&#20165;&#21457;&#36865;&#20102;&#19968;&#27425;&#26377;&#35768;&#22810;&#31995;&#32479;&#22768;&#31216;&#23427;&#20204;&#23454;&#29616;&#20102;exactly-once&#65292;&#20294;&#26159;&#23427;&#20204;&#20854;&#23454;&#24573;&#30053;&#20102;&#29983;&#20135;&#32773;&#25110;&#28040;&#36153;&#32773;&#22312;&#29983;&#20135;&#21644;&#28040;&#36153;&#36807;&#31243;&#20013;&#26377;&#21487;&#33021;&#22833;&#36133;&#30340;&#24773;&#20917;&#12290;&#27604;&#22914;&#34429;&#28982;&#19968;&#20010;Producer&#25104;&#21151;&#21457;&#36865;&#19968;&#20010;&#28040;&#24687;&#65292;&#20294;&#26159;&#28040;&#24687;&#22312;&#21457;&#36865;&#36884;&#20013;&#20002;&#22833;&#65292;&#25110;&#32773;&#25104;&#21151;&#21457;&#36865;&#21040;broker&#65292;&#20063;&#34987;consumer&#25104;&#21151;&#21462;&#36208;&#65292;&#20294;&#26159;&#36825;&#20010;consumer&#22312;&#22788;&#29702;&#21462;&#36807;&#26469;&#30340;&#28040;&#24687;&#26102;&#22833;&#36133;&#20102;&#12290;&#20174;Producer&#31471;&#30475;&#65306;Kafka&#26159;&#36825;&#20040;&#22788;&#29702;&#30340;&#65292;&#24403;&#19968;&#20010;&#28040;&#24687;&#34987;&#21457;&#36865;&#21518;&#65292;Producer&#20250;&#31561;&#24453;broker&#25104;&#21151;&#25509;&#25910;&#21040;&#28040;&#24687;&#30340;&#21453;&#39304;&#65288;&#21487;&#36890;&#36807;&#21442;&#25968;&#25511;&#21046;&#31561;&#24453;&#26102;&#38388;&#65289;&#65292;&#22914;&#26524;&#28040;&#24687;&#22312;&#36884;&#20013;&#20002;&#22833;&#25110;&#26159;&#20854;&#20013;&#19968;&#20010;broker&#25346;&#25481;&#65292;Producer&#20250;&#37325;&#26032;&#21457;&#36865;&#65288;&#25105;&#20204;&#30693;&#36947;Kafka&#26377;&#22791;&#20221;&#26426;&#21046;&#65292;&#21487;&#20197;&#36890;&#36807;&#21442;&#25968;&#25511;&#21046;&#26159;&#21542;&#31561;&#24453;&#25152;&#26377;&#22791;&#20221;&#33410;&#28857;&#37117;&#25910;&#21040;&#28040;&#24687;&#65289;&#12290;&#20174;Consumer&#31471;&#30475;&#65306;&#21069;&#38754;&#35762;&#21040;&#36807;partition&#65292;broker&#31471;&#35760;&#24405;&#20102;partition&#20013;&#30340;&#19968;&#20010;offset&#20540;&#65292;&#36825;&#20010;&#20540;&#25351;&#21521;Consumer&#19979;&#19968;&#20010;&#21363;&#23558;&#28040;&#36153;message&#12290;&#24403;Consumer&#25910;&#21040;&#20102;&#28040;&#24687;&#65292;&#20294;&#21364;&#22312;&#22788;&#29702;&#36807;&#31243;&#20013;&#25346;&#25481;&#65292;&#27492;&#26102;Consumer&#21487;&#20197;&#36890;&#36807;&#36825;&#20010;offset&#20540;&#37325;&#26032;&#25214;&#21040;&#19978;&#19968;&#20010;&#28040;&#24687;&#20877;&#36827;&#34892;&#22788;&#29702;&#12290;Consumer&#36824;&#26377;&#26435;&#38480;&#25511;&#21046;&#36825;&#20010;offset&#20540;&#65292;&#23545;&#25345;&#20037;&#21270;&#21040;broker&#31471;&#30340;&#28040;&#24687;&#20570;&#20219;&#24847;&#22788;&#29702;&#12290;4.5 &#22791;&#20221;&#26426;&#21046;&#22791;&#20221;&#26426;&#21046;&#26159;Kafka0.8&#29256;&#26412;&#30340;&#26032;&#29305;&#24615;&#65292;&#22791;&#20221;&#26426;&#21046;&#30340;&#20986;&#29616;&#22823;&#22823;&#25552;&#39640;&#20102;Kafka&#38598;&#32676;&#30340;&#21487;&#38752;&#24615;&#12289;&#31283;&#23450;&#24615;&#12290;&#26377;&#20102;&#22791;&#20221;&#26426;&#21046;&#21518;&#65292;Kafka&#20801;&#35768;&#38598;&#32676;&#20013;&#30340;&#33410;&#28857;&#25346;&#25481;&#21518;&#32780;&#19981;&#24433;&#21709;&#25972;&#20010;&#38598;&#32676;&#24037;&#20316;&#12290;&#19968;&#20010;&#22791;&#20221;&#25968;&#37327;&#20026;n&#30340;&#38598;&#32676;&#20801;&#35768;n-1&#20010;&#33410;&#28857;&#22833;&#36133;&#12290;&#22312;&#25152;&#26377;&#22791;&#20221;&#33410;&#28857;&#20013;&#65292;&#26377;&#19968;&#20010;&#33410;&#28857;&#20316;&#20026;lead&#33410;&#28857;&#65292;&#36825;&#20010;&#33410;&#28857;&#20445;&#23384;&#20102;&#20854;&#23427;&#22791;&#20221;&#33410;&#28857;&#21015;&#34920;&#65292;&#24182;&#32500;&#25345;&#21508;&#20010;&#22791;&#20221;&#38388;&#30340;&#29366;&#20307;&#21516;&#27493;&#12290;&#19979;&#38754;&#36825;&#24133;&#22270;&#35299;&#37322;&#20102;Kafka&#30340;&#22791;&#20221;&#26426;&#21046;&#65306;4.6 Kafka&#39640;&#25928;&#24615;&#30456;&#20851;&#35774;&#35745;4.6.1 &#28040;&#24687;&#30340;&#25345;&#20037;&#21270;Kafka&#39640;&#24230;&#20381;&#36182;&#25991;&#20214;&#31995;&#32479;&#26469;&#23384;&#20648;&#21644;&#32531;&#23384;&#28040;&#24687;(AMQ&#30340;nessage&#26159;&#25345;&#20037;&#21270;&#21040;mysql&#25968;&#25454;&#24211;&#20013;&#30340;)&#65292;&#22240;&#20026;&#19968;&#33324;&#30340;&#20154;&#35748;&#20026;&#30913;&#30424;&#26159;&#32531;&#24930;&#30340;&#65292;&#36825;&#23548;&#33268;&#20154;&#20204;&#23545;&#25345;&#20037;&#21270;&#32467;&#26500;&#20855;&#26377;&#31454;&#20105;&#24615;&#25345;&#24576;&#30097;&#24577;&#24230;&#12290;&#20854;&#23454;&#65292;&#30913;&#30424;&#30340;&#24555;&#25110;&#32773;&#24930;&#65292;&#36825;&#20915;&#23450;&#20110;&#25105;&#20204;&#22914;&#20309;&#20351;&#29992;&#30913;&#30424;&#12290;&#22240;&#20026;&#30913;&#30424;&#32447;&#24615;&#20889;&#30340;&#36895;&#24230;&#36828;&#36828;&#22823;&#20110;&#38543;&#26426;&#20889;&#12290;&#32447;&#24615;&#35835;&#20889;&#22312;&#22823;&#22810;&#25968;&#24212;&#29992;&#22330;&#26223;&#19979;&#26159;&#21487;&#20197;&#39044;&#27979;&#30340;&#12290;4.6.2 &#24120;&#25968;&#26102;&#38388;&#24615;&#33021;&#20445;&#35777;&#27599;&#20010;Topic&#30340;Partition&#30340;&#26159;&#19968;&#20010;&#22823;&#25991;&#20214;&#22841;&#65292;&#37324;&#38754;&#26377;&#26080;&#25968;&#20010;&#23567;&#25991;&#20214;&#22841;segment&#65292;&#20294;partition&#26159;&#19968;&#20010;&#38431;&#21015;&#65292;&#38431;&#21015;&#20013;&#30340;&#20803;&#32032;&#26159;segment,&#28040;&#36153;&#30340;&#26102;&#20505;&#20808;&#20174;&#31532;0&#20010;segment&#24320;&#22987;&#28040;&#36153;&#65292;&#26032;&#26469;message&#23384;&#22312;&#26368;&#21518;&#19968;&#20010;&#28040;&#24687;&#38431;&#21015;&#20013;&#12290;&#23545;&#20110;segment&#20063;&#26159;&#23545;&#38431;&#21015;&#65292;&#38431;&#21015;&#20803;&#32032;&#26159;message,&#26377;&#23545;&#24212;&#30340;offsite&#26631;&#35782;&#26159;&#21738;&#20010;message&#12290;&#28040;&#36153;&#30340;&#26102;&#20505;&#20808;&#20174;&#36825;&#20010;segment&#30340;&#31532;&#19968;&#20010;message&#24320;&#22987;&#28040;&#36153;&#65292;&#26032;&#26469;&#30340;message&#23384;&#22312;segment&#30340;&#26368;&#21518;&#12290;&#28040;&#24687;&#31995;&#32479;&#30340;&#25345;&#20037;&#21270;&#38431;&#21015;&#21487;&#20197;&#26500;&#24314;&#22312;&#23545;&#19968;&#20010;&#25991;&#20214;&#30340;&#35835;&#21644;&#36861;&#21152;&#19978;&#65292;&#23601;&#20687;&#19968;&#33324;&#24773;&#20917;&#19979;&#30340;&#26085;&#24535;&#35299;&#20915;&#26041;&#26696;&#12290;&#23427;&#26377;&#19968;&#20010;&#20248;&#28857;&#65292;&#25152;&#26377;&#30340;&#25805;&#20316;&#37117;&#26159;&#24120;&#25968;&#26102;&#38388;&#65292;&#24182;&#19988;&#35835;&#20889;&#20043;&#38388;&#19981;&#20250;&#30456;&#20114;&#38459;&#22622;&#12290;&#36825;&#31181;&#35774;&#35745;&#20855;&#26377;&#26497;&#22823;&#30340;&#24615;&#33021;&#20248;&#21183;&#65306;&#26368;&#32456;&#31995;&#32479;&#24615;&#33021;&#21644;&#25968;&#25454;&#22823;&#23567;&#23436;&#20840;&#26080;&#20851;&#65292;&#26381;&#21153;&#22120;&#21487;&#20197;&#20805;&#20998;&#21033;&#29992;&#24265;&#20215;&#30340;&#30828;&#30424;&#26469;&#25552;&#20379;&#39640;&#25928;&#30340;&#28040;&#24687;&#26381;&#21153;&#12290;&#20107;&#23454;&#19978;&#36824;&#26377;&#19968;&#28857;&#65292;&#30913;&#30424;&#31354;&#38388;&#30340;&#26080;&#38480;&#22686;&#22823;&#32780;&#19981;&#24433;&#21709;&#24615;&#33021;&#36825;&#28857;&#65292;&#24847;&#21619;&#30528;&#25105;&#20204;&#21487;&#20197;&#25552;&#20379;&#19968;&#33324;&#28040;&#24687;&#31995;&#32479;&#26080;&#27861;&#25552;&#20379;&#30340;&#29305;&#24615;&#12290;&#27604;&#22914;&#35828;&#65292;&#28040;&#24687;&#34987;&#28040;&#36153;&#21518;&#19981;&#26159;&#31435;&#39532;&#34987;&#21024;&#38500;&#65292;&#25105;&#20204;&#21487;&#20197;&#23558;&#36825;&#20123;&#28040;&#24687;&#20445;&#30041;&#19968;&#27573;&#30456;&#23545;&#27604;&#36739;&#38271;&#30340;&#26102;&#38388;&#65288;&#27604;&#22914;&#19968;&#20010;&#26143;&#26399;&#65289;&#12290;5.Kafka &#29983;&#20135;&#32773;-&#28040;&#36153;&#32773;&#28040;&#24687;&#31995;&#32479;&#36890;&#24120;&#37117;&#20250;&#30001;&#29983;&#20135;&#32773;&#65292;&#28040;&#36153;&#32773;&#65292;Broker&#19977;&#22823;&#37096;&#20998;&#32452;&#25104;&#65292;&#29983;&#20135;&#32773;&#20250;&#23558;&#28040;&#24687;&#20889;&#20837;&#21040;Broker&#65292;&#28040;&#36153;&#32773;&#20250;&#20174;Broker&#20013;&#35835;&#21462;&#20986;&#28040;&#24687;&#65292;&#19981;&#21516;&#30340;MQ&#23454;&#29616;&#30340;Broker&#23454;&#29616;&#20250;&#26377;&#25152;&#19981;&#21516;&#65292;&#19981;&#36807;Broker&#30340;&#26412;&#36136;&#37117;&#26159;&#35201;&#36127;&#36131;&#23558;&#28040;&#24687;&#33853;&#22320;&#21040;&#26381;&#21153;&#31471;&#30340;&#23384;&#20648;&#31995;&#32479;&#20013;&#12290;&#20855;&#20307;&#27493;&#39588;&#22914;&#19979;&#65306;&#29983;&#20135;&#32773;&#23458;&#25143;&#31471;&#24212;&#29992;&#31243;&#24207;&#20135;&#29983;&#28040;&#24687;&#65306;&#23458;&#25143;&#31471;&#36830;&#25509;&#23545;&#35937;&#23558;&#28040;&#24687;&#21253;&#35013;&#21040;&#35831;&#27714;&#20013;&#21457;&#36865;&#21040;&#26381;&#21153;&#31471;&#26381;&#21153;&#31471;&#30340;&#20837;&#21475;&#20063;&#26377;&#19968;&#20010;&#36830;&#25509;&#23545;&#35937;&#36127;&#36131;&#25509;&#25910;&#35831;&#27714;&#65292;&#24182;&#23558;&#28040;&#24687;&#20197;&#25991;&#20214;&#30340;&#24418;&#24335;&#23384;&#20648;&#36215;&#26469;&#26381;&#21153;&#31471;&#36820;&#22238;&#21709;&#24212;&#32467;&#26524;&#32473;&#29983;&#20135;&#32773;&#23458;&#25143;&#31471;&#28040;&#36153;&#32773;&#23458;&#25143;&#31471;&#24212;&#29992;&#31243;&#24207;&#28040;&#36153;&#28040;&#24687;&#65306;&#23458;&#25143;&#31471;&#36830;&#25509;&#23545;&#35937;&#23558;&#28040;&#36153;&#20449;&#24687;&#20063;&#21253;&#35013;&#21040;&#35831;&#27714;&#20013;&#21457;&#36865;&#32473;&#26381;&#21153;&#31471;&#26381;&#21153;&#31471;&#20174;&#25991;&#20214;&#23384;&#20648;&#31995;&#32479;&#20013;&#21462;&#20986;&#28040;&#24687;&#26381;&#21153;&#31471;&#36820;&#22238;&#21709;&#24212;&#32467;&#26524;&#32473;&#28040;&#36153;&#32773;&#23458;&#25143;&#31471;&#23458;&#25143;&#31471;&#23558;&#21709;&#24212;&#32467;&#26524;&#36824;&#21407;&#25104;&#28040;&#24687;&#24182;&#24320;&#22987;&#22788;&#29702;&#28040;&#24687;5.1 ProducersProducers&#30452;&#25509;&#21457;&#36865;&#28040;&#24687;&#21040;broker&#19978;&#30340;leader partition&#65292;&#19981;&#38656;&#35201;&#32463;&#36807;&#20219;&#20309;&#20013;&#20171;&#25110;&#20854;&#20182;&#36335;&#30001;&#36716;&#21457;&#12290;&#20026;&#20102;&#23454;&#29616;&#36825;&#20010;&#29305;&#24615;&#65292;kafka&#38598;&#32676;&#20013;&#30340;&#27599;&#20010;broker&#37117;&#21487;&#20197;&#21709;&#24212;producer&#30340;&#35831;&#27714;&#65292;&#24182;&#36820;&#22238;topic&#30340;&#19968;&#20123;&#20803;&#20449;&#24687;&#65292;&#36825;&#20123;&#20803;&#20449;&#24687;&#21253;&#25324;&#21738;&#20123;&#26426;&#22120;&#26159;&#23384;&#27963;&#30340;&#65292;topic&#30340;leader partition&#37117;&#22312;&#21738;&#65292;&#29616;&#38454;&#27573;&#21738;&#20123;leader partition&#26159;&#21487;&#20197;&#30452;&#25509;&#34987;&#35775;&#38382;&#30340;&#12290;Producer&#23458;&#25143;&#31471;&#33258;&#24049;&#25511;&#21046;&#30528;&#28040;&#24687;&#34987;&#25512;&#36865;&#21040;&#21738;&#20123;partition&#12290;&#23454;&#29616;&#30340;&#26041;&#24335;&#21487;&#20197;&#26159;&#38543;&#26426;&#20998;&#37197;&#12289;&#23454;&#29616;&#19968;&#31867;&#38543;&#26426;&#36127;&#36733;&#22343;&#34913;&#31639;&#27861;&#65292;&#25110;&#32773;&#25351;&#23450;&#19968;&#20123;&#20998;&#21306;&#31639;&#27861;&#12290;Kafka&#25552;&#20379;&#20102;&#25509;&#21475;&#20379;&#29992;&#25143;&#23454;&#29616;&#33258;&#23450;&#20041;&#30340;partition&#65292;&#29992;&#25143;&#21487;&#20197;&#20026;&#27599;&#20010;&#28040;&#24687;&#25351;&#23450;&#19968;&#20010;partitionKey&#65292;&#36890;&#36807;&#36825;&#20010;key&#26469;&#23454;&#29616;&#19968;&#20123;hash&#20998;&#21306;&#31639;&#27861;&#12290;&#27604;&#22914;&#65292;&#25226;userid&#20316;&#20026;partitionkey&#30340;&#35805;&#65292;&#30456;&#21516;userid&#30340;&#28040;&#24687;&#23558;&#20250;&#34987;&#25512;&#36865;&#21040;&#21516;&#19968;&#20010;partition&#12290;&#20197;Batch&#30340;&#26041;&#24335;&#25512;&#36865;&#25968;&#25454;&#21487;&#20197;&#26497;&#22823;&#30340;&#25552;&#39640;&#22788;&#29702;&#25928;&#29575;&#65292;kafka Producer &#21487;&#20197;&#23558;&#28040;&#24687;&#22312;&#20869;&#23384;&#20013;&#32047;&#35745;&#21040;&#19968;&#23450;&#25968;&#37327;&#21518;&#20316;&#20026;&#19968;&#20010;batch&#21457;&#36865;&#35831;&#27714;&#12290;Batch&#30340;&#25968;&#37327;&#22823;&#23567;&#21487;&#20197;&#36890;&#36807;Producer&#30340;&#21442;&#25968;&#25511;&#21046;&#65292;&#21442;&#25968;&#20540;&#21487;&#20197;&#35774;&#32622;&#20026;&#32047;&#35745;&#30340;&#28040;&#24687;&#30340;&#25968;&#37327;&#65288;&#22914;500&#26465;&#65289;&#12289;&#32047;&#35745;&#30340;&#26102;&#38388;&#38388;&#38548;&#65288;&#22914;100ms&#65289;&#25110;&#32773;&#32047;&#35745;&#30340;&#25968;&#25454;&#22823;&#23567;(64KB)&#12290;&#36890;&#36807;&#22686;&#21152;batch&#30340;&#22823;&#23567;&#65292;&#21487;&#20197;&#20943;&#23569;&#32593;&#32476;&#35831;&#27714;&#21644;&#30913;&#30424;IO&#30340;&#27425;&#25968;&#65292;&#24403;&#28982;&#20855;&#20307;&#21442;&#25968;&#35774;&#32622;&#38656;&#35201;&#22312;&#25928;&#29575;&#21644;&#26102;&#25928;&#24615;&#26041;&#38754;&#20570;&#19968;&#20010;&#26435;&#34913;&#12290;Producers&#21487;&#20197;&#24322;&#27493;&#30340;&#24182;&#34892;&#30340;&#21521;kafka&#21457;&#36865;&#28040;&#24687;&#65292;&#20294;&#26159;&#36890;&#24120;producer&#22312;&#21457;&#36865;&#23436;&#28040;&#24687;&#20043;&#21518;&#20250;&#24471;&#21040;&#19968;&#20010;future&#21709;&#24212;&#65292;&#36820;&#22238;&#30340;&#26159;offset&#20540;&#25110;&#32773;&#21457;&#36865;&#36807;&#31243;&#20013;&#36935;&#21040;&#30340;&#38169;&#35823;&#12290;&#36825;&#20854;&#20013;&#26377;&#20010;&#38750;&#24120;&#37325;&#35201;&#30340;&#21442;&#25968;&ldquo;acks&rdquo;,&#36825;&#20010;&#21442;&#25968;&#20915;&#23450;&#20102;producer&#35201;&#27714;leader partition &#25910;&#21040;&#30830;&#35748;&#30340;&#21103;&#26412;&#20010;&#25968;&#65292;&#22914;&#26524;acks&#35774;&#32622;&#25968;&#37327;&#20026;0&#65292;&#34920;&#31034;producer&#19981;&#20250;&#31561;&#24453;broker&#30340;&#21709;&#24212;&#65292;&#25152;&#20197;&#65292;producer&#26080;&#27861;&#30693;&#36947;&#28040;&#24687;&#26159;&#21542;&#21457;&#36865;&#25104;&#21151;&#65292;&#36825;&#26679;&#26377;&#21487;&#33021;&#20250;&#23548;&#33268;&#25968;&#25454;&#20002;&#22833;&#65292;&#20294;&#21516;&#26102;&#65292;acks&#20540;&#20026;0&#20250;&#24471;&#21040;&#26368;&#22823;&#30340;&#31995;&#32479;&#21534;&#21520;&#37327;&#12290;&#33509;acks&#35774;&#32622;&#20026;1&#65292;&#34920;&#31034;producer&#20250;&#22312;leader partition&#25910;&#21040;&#28040;&#24687;&#26102;&#24471;&#21040;broker&#30340;&#19968;&#20010;&#30830;&#35748;&#65292;&#36825;&#26679;&#20250;&#26377;&#26356;&#22909;&#30340;&#21487;&#38752;&#24615;&#65292;&#22240;&#20026;&#23458;&#25143;&#31471;&#20250;&#31561;&#24453;&#30452;&#21040;broker&#30830;&#35748;&#25910;&#21040;&#28040;&#24687;&#12290;&#33509;&#35774;&#32622;&#20026;-1&#65292;producer&#20250;&#22312;&#25152;&#26377;&#22791;&#20221;&#30340;partition&#25910;&#21040;&#28040;&#24687;&#26102;&#24471;&#21040;broker&#30340;&#30830;&#35748;&#65292;&#36825;&#20010;&#35774;&#32622;&#21487;&#20197;&#24471;&#21040;&#26368;&#39640;&#30340;&#21487;&#38752;&#24615;&#20445;&#35777;&#12290;Kafka &#28040;&#24687;&#26377;&#19968;&#20010;&#23450;&#38271;&#30340;header&#21644;&#21464;&#38271;&#30340;&#23383;&#33410;&#25968;&#32452;&#32452;&#25104;&#12290;&#22240;&#20026;kafka&#28040;&#24687;&#25903;&#25345;&#23383;&#33410;&#25968;&#32452;&#65292;&#20063;&#23601;&#20351;&#24471;kafka&#21487;&#20197;&#25903;&#25345;&#20219;&#20309;&#29992;&#25143;&#33258;&#23450;&#20041;&#30340;&#24207;&#21015;&#21495;&#26684;&#24335;&#25110;&#32773;&#20854;&#23427;&#24050;&#26377;&#30340;&#26684;&#24335;&#22914;Apache Avro&#12289;protobuf&#31561;&#12290;Kafka&#27809;&#26377;&#38480;&#23450;&#21333;&#20010;&#28040;&#24687;&#30340;&#22823;&#23567;&#65292;&#20294;&#25105;&#20204;&#25512;&#33616;&#28040;&#24687;&#22823;&#23567;&#19981;&#35201;&#36229;&#36807;1MB,&#36890;&#24120;&#19968;&#33324;&#28040;&#24687;&#22823;&#23567;&#37117;&#22312;1~10kB&#20043;&#21069;&#12290;&#21457;&#24067;&#28040;&#24687;&#26102;&#65292;kafka client&#20808;&#26500;&#36896;&#19968;&#26465;&#28040;&#24687;&#65292;&#23558;&#28040;&#24687;&#21152;&#20837;&#21040;&#28040;&#24687;&#38598;set&#20013;&#65288;kafka&#25903;&#25345;&#25209;&#37327;&#21457;&#24067;&#65292;&#21487;&#20197;&#24448;&#28040;&#24687;&#38598;&#21512;&#20013;&#28155;&#21152;&#22810;&#26465;&#28040;&#24687;&#65292;&#19968;&#27425;&#34892;&#21457;&#24067;&#65289;&#65292;send&#28040;&#24687;&#26102;&#65292;producer client&#38656;&#25351;&#23450;&#28040;&#24687;&#25152;&#23646;&#30340;topic&#12290;5.2 ConsumersKafka&#25552;&#20379;&#20102;&#20004;&#22871;consumer api&#65292;&#20998;&#20026;high-level api&#21644;sample-api&#12290;Sample-api &#26159;&#19968;&#20010;&#24213;&#23618;&#30340;API&#65292;&#23427;&#32500;&#25345;&#20102;&#19968;&#20010;&#21644;&#21333;&#19968;broker&#30340;&#36830;&#25509;&#65292;&#24182;&#19988;&#36825;&#20010;API&#26159;&#23436;&#20840;&#26080;&#29366;&#24577;&#30340;&#65292;&#27599;&#27425;&#35831;&#27714;&#37117;&#38656;&#35201;&#25351;&#23450;offset&#20540;&#65292;&#22240;&#27492;&#65292;&#36825;&#22871;API&#20063;&#26159;&#26368;&#28789;&#27963;&#30340;&#12290;&#22312;kafka&#20013;&#65292;&#24403;&#21069;&#35835;&#21040;&#21738;&#26465;&#28040;&#24687;&#30340;offset&#20540;&#26159;&#30001;consumer&#26469;&#32500;&#25252;&#30340;&#65292;&#22240;&#27492;&#65292;consumer&#21487;&#20197;&#33258;&#24049;&#20915;&#23450;&#22914;&#20309;&#35835;&#21462;kafka&#20013;&#30340;&#25968;&#25454;&#12290;&#27604;&#22914;&#65292;consumer&#21487;&#20197;&#36890;&#36807;&#37325;&#35774;offset&#20540;&#26469;&#37325;&#26032;&#28040;&#36153;&#24050;&#28040;&#36153;&#36807;&#30340;&#25968;&#25454;&#12290;&#19981;&#31649;&#26377;&#27809;&#26377;&#34987;&#28040;&#36153;&#65292;kafka&#20250;&#20445;&#23384;&#25968;&#25454;&#19968;&#27573;&#26102;&#38388;&#65292;&#36825;&#20010;&#26102;&#38388;&#21608;&#26399;&#26159;&#21487;&#37197;&#32622;&#30340;&#65292;&#21482;&#26377;&#21040;&#20102;&#36807;&#26399;&#26102;&#38388;&#65292;kafka&#25165;&#20250;&#21024;&#38500;&#36825;&#20123;&#25968;&#25454;&#12290;&#65288;&#36825;&#19968;&#28857;&#19982;AMQ&#19981;&#19968;&#26679;&#65292;AMQ&#30340;message&#19968;&#33324;&#26469;&#35828;&#37117;&#26159;&#25345;&#20037;&#21270;&#21040;mysql&#20013;&#30340;&#65292;&#28040;&#36153;&#23436;&#30340;message&#20250;&#34987;delete&#25481;&#65289;High-level API&#23553;&#35013;&#20102;&#23545;&#38598;&#32676;&#20013;&#19968;&#31995;&#21015;broker&#30340;&#35775;&#38382;&#65292;&#21487;&#20197;&#36879;&#26126;&#30340;&#28040;&#36153;&#19968;&#20010;topic&#12290;&#23427;&#33258;&#24049;&#32500;&#25345;&#20102;&#24050;&#28040;&#36153;&#28040;&#24687;&#30340;&#29366;&#24577;&#65292;&#21363;&#27599;&#27425;&#28040;&#36153;&#30340;&#37117;&#26159;&#19979;&#19968;&#20010;&#28040;&#24687;&#12290;High-level API&#36824;&#25903;&#25345;&#20197;&#32452;&#30340;&#24418;&#24335;&#28040;&#36153;topic&#65292;&#22914;&#26524;consumers&#26377;&#21516;&#19968;&#20010;&#32452;&#21517;&#65292;&#37027;&#20040;kafka&#23601;&#30456;&#24403;&#20110;&#19968;&#20010;&#38431;&#21015;&#28040;&#24687;&#26381;&#21153;&#65292;&#32780;&#21508;&#20010;consumer&#22343;&#34913;&#30340;&#28040;&#36153;&#30456;&#24212;partition&#20013;&#30340;&#25968;&#25454;&#12290;&#33509;consumers&#26377;&#19981;&#21516;&#30340;&#32452;&#21517;&#65292;&#37027;&#20040;&#27492;&#26102;kafka&#23601;&#30456;&#24403;&#19982;&#19968;&#20010;&#24191;&#25773;&#26381;&#21153;&#65292;&#20250;&#25226;topic&#20013;&#30340;&#25152;&#26377;&#28040;&#24687;&#24191;&#25773;&#21040;&#27599;&#20010;consumer&#12290;High level api&#21644;Low level api&#26159;&#38024;&#23545;consumer&#32780;&#35328;&#30340;&#65292;&#21644;producer&#26080;&#20851;&#12290;High level api&#26159;consumer&#35835;&#30340;partition&#30340;offsite&#26159;&#23384;&#22312;zookeeper&#19978;&#12290;High level api &#20250;&#21551;&#21160;&#21478;&#22806;&#19968;&#20010;&#32447;&#31243;&#21435;&#27599;&#38548;&#19968;&#27573;&#26102;&#38388;&#65292;offsite&#33258;&#21160;&#21516;&#27493;&#21040;zookeeper&#19978;&#12290;&#25442;&#21477;&#35805;&#35828;&#65292;&#22914;&#26524;&#20351;&#29992;&#20102;High level api&#65292; &#27599;&#20010;message&#21482;&#33021;&#34987;&#35835;&#19968;&#27425;&#65292;&#19968;&#26086;&#35835;&#20102;&#36825;&#26465;message&#20043;&#21518;&#65292;&#26080;&#35770;&#25105;consumer&#30340;&#22788;&#29702;&#26159;&#21542;ok&#12290;High level api&#30340;&#21478;&#22806;&#19968;&#20010;&#32447;&#31243;&#20250;&#33258;&#21160;&#30340;&#25226;offiste+1&#21516;&#27493;&#21040;zookeeper&#19978;&#12290;&#22914;&#26524;consumer&#35835;&#21462;&#25968;&#25454;&#20986;&#20102;&#38382;&#39064;&#65292;offsite&#20063;&#20250;&#22312;zookeeper&#19978;&#21516;&#27493;&#12290;&#22240;&#27492;&#65292;&#22914;&#26524;consumer&#22788;&#29702;&#22833;&#36133;&#20102;&#65292;&#20250;&#32487;&#32493;&#25191;&#34892;&#19979;&#19968;&#26465;&#12290;&#36825;&#24448;&#24448;&#26159;&#19981;&#23545;&#30340;&#34892;&#20026;&#12290;&#22240;&#27492;&#65292;Best Practice&#26159;&#19968;&#26086;consumer&#22788;&#29702;&#22833;&#36133;&#65292;&#30452;&#25509;&#35753;&#25972;&#20010;conusmer group&#25243;Exception&#32456;&#27490;&#65292;&#20294;&#26159;&#26368;&#21518;&#35835;&#30340;&#36825;&#19968;&#26465;&#25968;&#25454;&#26159;&#20002;&#22833;&#20102;&#65292;&#22240;&#20026;&#22312;zookeeper&#37324;&#38754;&#30340;offsite&#24050;&#32463;+1&#20102;&#12290;&#31561;&#20877;&#27425;&#21551;&#21160;conusmer group&#30340;&#26102;&#20505;&#65292;&#24050;&#32463;&#20174;&#19979;&#19968;&#26465;&#24320;&#22987;&#35835;&#21462;&#22788;&#29702;&#20102;&#12290;Low level api&#26159;consumer&#35835;&#30340;partition&#30340;offsite&#22312;consumer&#33258;&#24049;&#30340;&#31243;&#24207;&#20013;&#32500;&#25252;&#12290;&#19981;&#20250;&#21516;&#27493;&#21040;zookeeper&#19978;&#12290;&#20294;&#26159;&#20026;&#20102;kafka manager&#33021;&#22815;&#26041;&#20415;&#30340;&#30417;&#25511;&#65292;&#19968;&#33324;&#20063;&#20250;&#25163;&#21160;&#30340;&#21516;&#27493;&#21040;zookeeper&#19978;&#12290;&#36825;&#26679;&#30340;&#22909;&#22788;&#26159;&#19968;&#26086;&#35835;&#21462;&#26576;&#20010;message&#30340;consumer&#22833;&#36133;&#20102;&#65292;&#36825;&#26465;message&#30340;offsite&#25105;&#20204;&#33258;&#24049;&#32500;&#25252;&#65292;&#25105;&#20204;&#19981;&#20250;+1&#12290;&#19979;&#27425;&#20877;&#21551;&#21160;&#30340;&#26102;&#20505;&#65292;&#36824;&#20250;&#20174;&#36825;&#20010;offsite&#24320;&#22987;&#35835;&#12290;&#36825;&#26679;&#21487;&#20197;&#20570;&#21040;exactly once&#23545;&#20110;&#25968;&#25454;&#30340;&#20934;&#30830;&#24615;&#26377;&#20445;&#35777;&#12290;&#23545;&#20110;Consumer group&#65306;1. &#20801;&#35768;consumer group&#65288;&#21253;&#21547;&#22810;&#20010;consumer&#65292;&#22914;&#19968;&#20010;&#38598;&#32676;&#21516;&#26102;&#28040;&#36153;&#65289;&#23545;&#19968;&#20010;topic&#36827;&#34892;&#28040;&#36153;&#65292;&#19981;&#21516;&#30340;consumer group&#20043;&#38388;&#29420;&#31435;&#28040;&#36153;&#12290;2. &#20026;&#20102;&#23545;&#20943;&#23567;&#19968;&#20010;consumer group&#20013;&#19981;&#21516;consumer&#20043;&#38388;&#30340;&#20998;&#24067;&#24335;&#21327;&#35843;&#24320;&#38144;&#65292;&#25351;&#23450;partition&#20026;&#26368;&#23567;&#30340;&#24182;&#34892;&#28040;&#36153;&#21333;&#20301;&#65292;&#21363;&#19968;&#20010;group&#20869;&#30340;consumer&#21482;&#33021;&#28040;&#36153;&#19981;&#21516;&#30340;partition&#12290;Consumer&#19982;Partition&#30340;&#20851;&#31995;&#65306;- &#22914;&#26524;consumer&#27604;partition&#22810;&#65292;&#26159;&#28010;&#36153;&#65292;&#22240;&#20026;kafka&#30340;&#35774;&#35745;&#26159;&#22312;&#19968;&#20010;partition&#19978;&#26159;&#19981;&#20801;&#35768;&#24182;&#21457;&#30340;&#65292;&#25152;&#20197;consumer&#25968;&#19981;&#35201;&#22823;&#20110;partition&#25968;- &#22914;&#26524;consumer&#27604;partition&#23569;&#65292;&#19968;&#20010;consumer&#20250;&#23545;&#24212;&#20110;&#22810;&#20010;partitions&#65292;&#36825;&#37324;&#20027;&#35201;&#21512;&#29702;&#20998;&#37197;consumer&#25968;&#21644;partition&#25968;&#65292;&#21542;&#21017;&#20250;&#23548;&#33268;partition&#37324;&#38754;&#30340;&#25968;&#25454;&#34987;&#21462;&#30340;&#19981;&#22343;&#21248;- &#22914;&#26524;consumer&#20174;&#22810;&#20010;partition&#35835;&#21040;&#25968;&#25454;&#65292;&#19981;&#20445;&#35777;&#25968;&#25454;&#38388;&#30340;&#39034;&#24207;&#24615;&#65292;kafka&#21482;&#20445;&#35777;&#22312;&#19968;&#20010;partition&#19978;&#25968;&#25454;&#26159;&#26377;&#24207;&#30340;&#65292;&#20294;&#22810;&#20010;partition&#65292;&#26681;&#25454;&#20320;&#35835;&#30340;&#39034;&#24207;&#20250;&#26377;&#19981;&#21516;- &#22686;&#20943;consumer&#65292;broker&#65292;partition&#20250;&#23548;&#33268;rebalance&#65292;&#25152;&#20197;rebalance&#21518;consumer&#23545;&#24212;&#30340;partition&#20250;&#21457;&#29983;&#21464;&#21270;- High-level&#25509;&#21475;&#20013;&#33719;&#21462;&#19981;&#21040;&#25968;&#25454;&#30340;&#26102;&#20505;&#26159;&#20250;block&#30340;&#36127;&#36733;&#20302;&#30340;&#24773;&#20917;&#19979;&#21487;&#20197;&#27599;&#20010;&#32447;&#31243;&#28040;&#36153;&#22810;&#20010;partition&#12290;&#20294;&#36127;&#36733;&#39640;&#30340;&#24773;&#20917;&#19979;&#65292;Consumer &#32447;&#31243;&#25968;&#26368;&#22909;&#21644;Partition&#25968;&#37327;&#20445;&#25345;&#19968;&#33268;&#12290;&#22914;&#26524;&#36824;&#26159;&#28040;&#36153;&#19981;&#36807;&#26469;&#65292;&#24212;&#35813;&#20877;&#24320; Consumer &#36827;&#31243;&#65292;&#36827;&#31243;&#20869;&#32447;&#31243;&#25968;&#21516;&#26679;&#21644;&#20998;&#21306;&#25968;&#19968;&#33268;&#12290;&#28040;&#36153;&#28040;&#24687;&#26102;&#65292;kafka client&#38656;&#25351;&#23450;topic&#20197;&#21450;partition number&#65288;&#27599;&#20010;partition&#23545;&#24212;&#19968;&#20010;&#36923;&#36753;&#26085;&#24535;&#27969;&#65292;&#22914;topic&#20195;&#34920;&#26576;&#20010;&#20135;&#21697;&#32447;&#65292;partition&#20195;&#34920;&#20135;&#21697;&#32447;&#30340;&#26085;&#24535;&#25353;&#22825;&#20999;&#20998;&#30340;&#32467;&#26524;&#65289;&#65292;consumer client&#35746;&#38405;&#21518;&#65292;&#23601;&#21487;&#36845;&#20195;&#35835;&#21462;&#28040;&#24687;&#65292;&#22914;&#26524;&#27809;&#26377;&#28040;&#24687;&#65292;consumer client&#20250;&#38459;&#22622;&#30452;&#21040;&#26377;&#26032;&#30340;&#28040;&#24687;&#21457;&#24067;&#12290;consumer&#21487;&#20197;&#32047;&#31215;&#30830;&#35748;&#25509;&#25910;&#21040;&#30340;&#28040;&#24687;&#65292;&#24403;&#20854;&#30830;&#35748;&#20102;&#26576;&#20010;offset&#30340;&#28040;&#24687;&#65292;&#24847;&#21619;&#30528;&#20043;&#21069;&#30340;&#28040;&#24687;&#20063;&#37117;&#24050;&#25104;&#21151;&#25509;&#25910;&#21040;&#65292;&#27492;&#26102;broker&#20250;&#26356;&#26032;zookeeper&#19978;&#22320;offset registry&#12290;5.3 &#39640;&#25928;&#30340;&#25968;&#25454;&#20256;&#36755;1. &#21457;&#24067;&#32773;&#27599;&#27425;&#21487;&#21457;&#24067;&#22810;&#26465;&#28040;&#24687;&#65288;&#23558;&#28040;&#24687;&#21152;&#21040;&#19968;&#20010;&#28040;&#24687;&#38598;&#21512;&#20013;&#21457;&#24067;&#65289;&#65292; consumer&#27599;&#27425;&#36845;&#20195;&#28040;&#36153;&#19968;&#26465;&#28040;&#24687;&#12290;2. &#19981;&#21019;&#24314;&#21333;&#29420;&#30340;cache&#65292;&#20351;&#29992;&#31995;&#32479;&#30340;page cache&#12290;&#21457;&#24067;&#32773;&#39034;&#24207;&#21457;&#24067;&#65292;&#35746;&#38405;&#32773;&#36890;&#24120;&#27604;&#21457;&#24067;&#32773;&#28382;&#21518;&#19968;&#28857;&#28857;&#65292;&#30452;&#25509;&#20351;&#29992;linux&#30340;page cache&#25928;&#26524;&#20063;&#27604;&#36739;&#21518;&#65292;&#21516;&#26102;&#20943;&#23569;&#20102;cache&#31649;&#29702;&#21450;&#22403;&#22334;&#25910;&#38598;&#30340;&#24320;&#38144;&#12290;3. &#20351;&#29992;sendfile&#20248;&#21270;&#32593;&#32476;&#20256;&#36755;&#65292;&#20943;&#23569;&#19968;&#27425;&#20869;&#23384;&#25335;&#36125;&#12290;6.Kafka &#19982; Zookeeper6.1 Zookeeper &#21327;&#35843;&#25511;&#21046;1. &#31649;&#29702;broker&#19982;consumer&#30340;&#21160;&#24577;&#21152;&#20837;&#19982;&#31163;&#24320;&#12290;(Producer&#19981;&#38656;&#35201;&#31649;&#29702;&#65292;&#38543;&#20415;&#19968;&#21488;&#35745;&#31639;&#26426;&#37117;&#21487;&#20197;&#20316;&#20026;Producer&#21521;Kakfa Broker&#21457;&#28040;&#24687;)2. &#35302;&#21457;&#36127;&#36733;&#22343;&#34913;&#65292;&#24403;broker&#25110;consumer&#21152;&#20837;&#25110;&#31163;&#24320;&#26102;&#20250;&#35302;&#21457;&#36127;&#36733;&#22343;&#34913;&#31639;&#27861;&#65292;&#20351;&#24471;&#19968; &#20010;consumer group&#20869;&#30340;&#22810;&#20010;consumer&#30340;&#28040;&#36153;&#36127;&#36733;&#24179;&#34913;&#12290;&#65288;&#22240;&#20026;&#19968;&#20010;comsumer&#28040;&#36153;&#19968;&#20010;&#25110;&#22810;&#20010;partition&#65292;&#19968;&#20010;partition&#21482;&#33021;&#34987;&#19968;&#20010;consumer&#28040;&#36153;&#65289;3. &#32500;&#25252;&#28040;&#36153;&#20851;&#31995;&#21450;&#27599;&#20010;partition&#30340;&#28040;&#36153;&#20449;&#24687;&#12290;6.2 Zookeeper&#19978;&#30340;&#32454;&#33410;&#65306;1. &#27599;&#20010;broker&#21551;&#21160;&#21518;&#20250;&#22312;zookeeper&#19978;&#27880;&#20876;&#19968;&#20010;&#20020;&#26102;&#30340;broker registry&#65292;&#21253;&#21547;broker&#30340;ip&#22320;&#22336;&#21644;&#31471;&#21475;&#21495;&#65292;&#25152;&#23384;&#20648;&#30340;topics&#21644;partitions&#20449;&#24687;&#12290;2. &#27599;&#20010;consumer&#21551;&#21160;&#21518;&#20250;&#22312;zookeeper&#19978;&#27880;&#20876;&#19968;&#20010;&#20020;&#26102;&#30340;consumer registry&#65306;&#21253;&#21547;consumer&#25152;&#23646;&#30340;consumer group&#20197;&#21450;&#35746;&#38405;&#30340;topics&#12290;3. &#27599;&#20010;consumer group&#20851;&#32852;&#19968;&#20010;&#20020;&#26102;&#30340;owner registry&#21644;&#19968;&#20010;&#25345;&#20037;&#30340;offset registry&#12290;&#23545;&#20110;&#34987;&#35746;&#38405;&#30340;&#27599;&#20010;partition&#21253;&#21547;&#19968;&#20010;owner registry&#65292;&#20869;&#23481;&#20026;&#35746;&#38405;&#36825;&#20010;partition&#30340;consumer id&#65307;&#21516;&#26102;&#21253;&#21547;&#19968;&#20010;offset registry&#65292;&#20869;&#23481;&#20026;&#19978;&#19968;&#27425;&#35746;&#38405;&#30340;offset&#12290;
点击查看更多内容
发表于 2020.01.09 12:40,
共 1281 人浏览
本文原创发布于慕课网 ,转载请注明出处,谢谢合作
举报
为 TA 点赞
若觉得本文不错,就分享一下吧!
评论
评论
共同学习,写下你的评论
评论加载中...
展开查看更多评论
作者其他优质文章
正在加载中
小强学开发
软件工程师
手记
粉丝
获赞与收藏
37
关注作者,订阅最新文章
相关文章推荐
C语言结构体史上最详细的讲解
大数据概念:史上最全大数据解析
SSH【史上最详细整合】
SSM【史上最详细整合】
最详细的大数据学习大纲
阅读免费教程
仿社交小程序
0个小节
408
后端通用面试教程
41个小节
24633
282
网络编程入门教程
20个小节
10108
196
推荐
评论
收藏
共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得
100积分直接送
付费专栏免费学
大额优惠券免费领
立即参与
放弃机会
点击抽奖
慕课手记新用户专享福利
恭喜你,你的运气太好了,居然抽中了 100个积分!
恭喜你,抽中了价值 元的专栏 !
太棒了, 直接落到你账户里!
积分商城里的罗技鼠标、机械键盘、
Kindle 阅读器、小米平衡车
Apple iPad (10.2英寸)、大额优惠券
在等着你去兑换了噢
作者:
免费赠送
兑换码:1111222211 复制
优惠券可用于购买实战课、体系课
无门槛使用
先去看看,有什么好东西
马上兑换
我爱学习,选课去
意见反馈
分销返利
帮助中心
APP下载
官方微信
返回顶部
举报
0/150
提交
取消