{"id":2944,"date":"2021-06-26T02:47:30","date_gmt":"2021-06-25T18:47:30","guid":{"rendered":"\/?p=2944"},"modified":"2021-07-01T22:48:50","modified_gmt":"2021-07-01T14:48:50","slug":"5_1-rmq%e7%9a%84%e6%b6%88%e6%81%af%e5%ad%98%e5%82%a8%e7%ae%80%e4%bb%8b%e5%8f%8a%e6%a6%82%e8%a7%88-docx","status":"publish","type":"post","link":"http:\/\/xinblog.ltd\/?p=2944","title":{"rendered":"5_1 RMQ\u7684\u6d88\u606f\u5b58\u50a8\u7b80\u4ecb\u53ca\u6982\u89c8.docx"},"content":{"rendered":"<p>\u672c\u7ae0\u4e3b\u8981\u8bf4\u7684\u662fRMQ\u7684\u6d88\u606f\u5b58\u50a8,\u4e00\u822c\u6765\u8bf4,MQ\u90fd\u662f\u9700\u8981\u8fdb\u884c\u6301\u4e45\u5316\u5b58\u50a8\u7684,\u6bd4\u5982ActiveMQ RabbitMQ Kafka,<\/p>\n<p>\u4ece\u5177\u4f53\u7684\u5b58\u50a8\u89d2\u5ea6\u6765\u8bf4,\u76f4\u63a5\u501f\u7528\u6587\u4ef6\u7cfb\u7edf\u8fdb\u884c\u5b58\u50a8\u662f\u4e00\u79cd\u5f88\u9ad8\u6548\u7684\u65b9\u5f0f\u548c\u624b\u6bb5,\u76f8\u6bd4\u4f7f\u7528\u6570\u636e\u5e93,KV\u5b58\u50a8,\u66f4\u52a0\u76f4\u63a5,\u66f4\u52a0\u5e95\u5c42,\u6bd4\u5982Unix\u7cfb\u7edf\u4e2d\u7684 VFS &#8211; &gt; \u901a\u7528\u5757\u5c42\u7684\u6982\u5ff5,\u4f46\u662f\u53ef\u9760\u6027\u548c\u6027\u80fd\u5f80\u5f80\u6210\u53cd\u6bd4,\u6240\u4ee5\u6211\u4eec\u5c31\u9700\u8981\u4e86\u89e3RMQ\u5982\u4f55\u8fdb\u884c\u53d6\u820d\u7684<\/p>\n<p>\u4ece\u4ee5\u4e0b\u51e0\u4e2a\u65b9\u9762\u8fdb\u884c\u76f8\u5173\u7684\u4ecb\u7ecd<\/p>\n<p>RMQ\u5b58\u50a8\u6982\u89c8<\/p>\n<p>\u6d88\u606f\u53d1\u9001\u5b58\u50a8\u6d41\u7a0b<\/p>\n<p>\u5b58\u50a8\u6587\u4ef6\u7ec4\u7ec7\u548c\u5185\u5b58\u6620\u5c04\u673a\u5236<\/p>\n<p>RMQ\u5b58\u50a8\u6587\u4ef6\u683c\u5f0f<\/p>\n<p>\u6d88\u606f\u6d88\u8d39\u961f\u5217,\u7d22\u5f15\u6587\u4ef6\u6784\u5efa\u673a\u5236<\/p>\n<p>RMQ\u7684\u6062\u590d\u673a\u5236<\/p>\n<p>RMQ\u5237\u76d8\u673a\u5236<\/p>\n<p>RMQ\u7684\u6587\u4ef6\u5220\u9664\u673a\u5236<\/p>\n<p>\u672c\u7ae0\u6211\u4eec\u4f1a\u8bb2\u8ff0\u4e00\u4e0bRMQ\u7684\u5b58\u50a8\u6982\u89c8<\/p>\n<p>RMQ\u7684\u6587\u4ef6\u5b58\u50a8\u4e3b\u8981\u5728\u4e8eCommitlog ConsumeQueue IndexFile\u4e09\u4e2a\u6587\u4ef6\u4e0a\u9762<\/p>\n<p>RMQ\u5c06\u6240\u6709\u4e3b\u9898\u7684\u6d88\u606f\u5b58\u50a8\u5728\u540c\u4e00\u4e2a\u6587\u4ef6\u4e0b,\u800c\u4e0d\u662f\u5206\u4e3a\u591a\u4e2a\u6587\u4ef6\u5b58\u50a8<\/p>\n<p>\u8fd9\u6837\u5c31\u53ef\u4ee5\u4fdd\u8bc1\u987a\u5e8f\u7684\u5199\u6587\u4ef6,\u6700\u5927\u53ef\u80fd\u6027\u4fdd\u8bc1\u6d88\u606f\u53d1\u9001\u7684\u9ad8\u6027\u80fd\u548c\u9ad8\u541e\u5410<\/p>\n<p>\u4f46\u662f\u6d88\u606f\u4e2d\u95f4\u4ef6\u57fa\u672c\u4e0a\u90fd\u662f\u57fa\u4e8etopic\u8fdb\u884c\u4ea4\u6d41\u7684,\u6240\u4ee5\u8fd9\u6837\u5bf9\u4e8e\u6309\u7167\u6d88\u606f\u4e3b\u9898\u68c0\u7d22\u6d88\u606f\u5e26\u6765\u4e86\u6781\u5927\u7684\u4e0d\u4fbf,\u603b\u7ed3\u4e00\u4e0b\u4e0a\u9762\u7684\u8bf4\u6cd5,\u6240\u6709\u6d88\u606f\u5b58\u50a8\u4e8eCommitlog\u4e2d,\u4f46\u662f\u6240\u6709\u90fd\u5b58\u50a8\u5e26\u6765\u4e86\u68c0\u7d22\u7684\u4e0d\u4fbf<\/p>\n<p>\u4e8e\u662f\u5f15\u51fa\u4e86\u65b0\u7684\u4e00\u4e2a\u6587\u4ef6 ConsumeQueue\u6587\u4ef6,\u65b9\u4fbf\u901a\u8fc7topic\u68c0\u7d22\u5bf9\u5e94\u7684\u6d88\u606f,<\/p>\n<p>\u800c\u4e14\u6bcf\u4e2a\u4e3b\u9898\u5bf9\u5e94\u7740\u591a\u4e2a\u6d88\u8d39\u961f\u5217,\u6bcf\u4e2a\u6d88\u8d39\u961f\u5217\u90fd\u6709\u81ea\u5df1\u7684\u6d88\u606f\u6587\u4ef6,\u5c31\u662fIndexFile\u6587\u4ef6<\/p>\n<p>IndexFile And ConsumeQueue\u7684\u8bbe\u8ba1\u7406\u5ff5\u5c31\u662f\u5feb\u901f\u7684\u4eceCommitLog\u4e2d\u68c0\u7d22\u51fa\u6d88\u606f<\/p>\n<p>\u6574\u4f53\u7684\u7ed3\u6784\u5982\u4e0b<\/p>\n<p><img decoding=\"async\" loading=\"lazy\" width=\"938\" height=\"477\" src=\"\/wp-content\/uploads\/2021\/07\/unnamed-file.png\" class=\"wp-image-2945\" alt=\"\u56fe\u7247\" srcset=\"http:\/\/xinblog.ltd\/wp-content\/uploads\/2021\/07\/unnamed-file.png 938w, http:\/\/xinblog.ltd\/wp-content\/uploads\/2021\/07\/unnamed-file-300x153.png 300w, http:\/\/xinblog.ltd\/wp-content\/uploads\/2021\/07\/unnamed-file-768x391.png 768w\" sizes=\"(max-width: 938px) 100vw, 938px\" \/><\/p>\n<p>\u603b\u7ed3\u4e00\u4e0b<\/p>\n<p>RMQ\u7684\u6587\u4ef6\u5206\u4e3a\u4e09\u79cd<\/p>\n<p>1.CommitLog:\u6d88\u606f\u5b58\u50a8\u6587\u4ef6,\u6240\u6709\u6d88\u606f\u90fd\u5b58\u4e8e\u6b64<\/p>\n<p>2.ConsumeQueue: \u6d88\u606f\u6d88\u8d39\u961f\u5217,\u6d88\u606f\u5230\u8fbeCommitLog\u4e4b\u540e,\u5f02\u6b65\u8f6c\u53d1\u5230\u6d88\u606f\u6d88\u8d39\u961f\u5217,\u4f9b\u6d88\u8d39<\/p>\n<p>3.\u6d88\u606f\u7d22\u5f15\u6587\u4ef6,\u5b58\u50a8Key\u548cOffset\u5bf9\u5e94\u7684\u5173\u7cfb<\/p>\n<p>4.\u4e8b\u52a1\u7684\u72b6\u6001<\/p>\n<p>5.\u5b9a\u65f6\u6d88\u606f\u670d\u52a1 \u5ef6\u8fdf\u6d88\u606f\u5bf9\u5e94\u7684\u6d88\u606f\u6d88\u8d39\u961f\u5217,\u5b58\u50a8\u5ef6\u8fdf\u961f\u5217\u7684\u6d88\u606f\u62c9\u53d6\u8fdb\u5ea6(\u5f88\u5feb\u5c31\u8bb2)<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u672c\u7ae0\u4e3b\u8981\u8bf4\u7684\u662fRMQ\u7684\u6d88\u606f\u5b58\u50a8 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[19],"tags":[],"_links":{"self":[{"href":"http:\/\/xinblog.ltd\/index.php?rest_route=\/wp\/v2\/posts\/2944"}],"collection":[{"href":"http:\/\/xinblog.ltd\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/xinblog.ltd\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/xinblog.ltd\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/xinblog.ltd\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=2944"}],"version-history":[{"count":0,"href":"http:\/\/xinblog.ltd\/index.php?rest_route=\/wp\/v2\/posts\/2944\/revisions"}],"wp:attachment":[{"href":"http:\/\/xinblog.ltd\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=2944"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/xinblog.ltd\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=2944"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/xinblog.ltd\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=2944"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}