{"id":18672,"date":"2024-11-19T20:49:31","date_gmt":"2024-11-19T12:49:31","guid":{"rendered":"https:\/\/fwq.ai\/blog\/?p=18672"},"modified":"2024-11-19T20:49:31","modified_gmt":"2024-11-19T12:49:31","slug":"zookeeper%e6%98%af%e4%bb%80%e4%b9%88","status":"publish","type":"post","link":"https:\/\/fwq.ai\/blog\/18672\/","title":{"rendered":"Zookeeper\u662f\u4ec0\u4e48"},"content":{"rendered":"<p>Google\u7684\u4e09\u7bc7\u8bba\u6587\u5f71\u54cd\u4e86\u5f88\u591a\u5f88\u591a\u4eba\uff0c\u4e5f\u5f71\u54cd\u4e86\u5f88\u591a\u5f88\u591a\u7cfb\u7edf\u3002\u8fd9\u4e09\u7bc7\u8bba\u6587\u4e00\u76f4\u662f\u5206\u5e03\u5f0f\u9886\u57df\u4f20\u9605\u7684\u7ecf\u5178\u3002\u6839\u636eMapReduce\uff0c\u4e8e\u662f\u6211\u4eec\u6709\u4e86Hadoop\uff1b\u6839\u636eGFS\uff0c\u4e8e\u662f\u6211\u4eec\u6709\u4e86HDFS\uff1b\u6839\u636eBigTable\uff0c\u4e8e\u662f\u6211\u4eec\u6709\u4e86HBase\u3002\u800c\u5728\u8fd9\u4e09\u7bc7\u8bba\u6587\u91cc\u90fd\u63d0\u53caGoogle\u7684\u4e00\u4e2alock service\u2014Chubby\uff0c\u54e6\uff0c\u4e8e\u662f\u6211\u4eec\u6709\u4e86Zookeeper\u3002<\/p>\n<p>&nbsp;<\/p>\n<p>\u968f\u7740\u5927\u6570\u636e\u7684\u706b\u70ed\uff0cHxx\u4eec\u5df2\u7ecf\u53d8\u5f97\u8033\u719f\u80fd\u8be6\uff0c\u73b0\u5728\u4f5c\u4e3a\u4e00\u4e2a\u5f00\u53d1\u4eba\u5458\u5982\u679c\u90fd\u4e0d\u77e5\u9053\u8fd9\u51e0\u4e2a\u540d\u8bcd\u51fa\u95e8\u90fd\u597d\u50cf\u4e0d\u597d\u610f\u601d\u8ddf\u4eba\u6253\u62db\u547c\u3002\u4f46\u5b9e\u9645\u4e0a\u5bf9\u6211\u4eec\u8fd9\u4e9b\u975e\u5927\u6570\u636e\u5f00\u53d1\u4eba\u5458\u800c\u8a00\uff0cZookeeper\u662f\u6bd4Hxx\u4eec\u53ef\u80fd\u63a5\u89e6\u5230\u66f4\u591a\u7684\u4e00\u4e2a\u57fa\u7840\u670d\u52a1\u3002\u4f46\u662f\uff0c\u65e0\u5948\u7684\u662f\u5b83\u4e00\u76f4\u9ed8\u9ed8\u7684\u4f4d\u4e8e\u4e8c\u7ebf\uff0c\u4ece\u6765\u6ca1\u6709Hxx\u4eec\u90a3\u4e48\u8000\u773c\u3002\u90a3\u4e48\u5230\u5e95\u4ec0\u4e48\u662fZookeeper\u5462\uff1fZookeeper\u53ef\u4ee5\u7528\u6765\u5e72\u4ec0\u4e48\uff1f\u6211\u4eec\u5c06\u5982\u4f55\u4f7f\u7528Zookeeper\uff1fZookeeper\u53c8\u662f\u600e\u4e48\u5b9e\u73b0\u7684\uff1f<\/p>\n<p>\u4f34\u968f\u7740Zookeeper\u6709\u4e24\u7bc7\u8bba\u6587\uff1a\u4e00\u7bc7\u662fZab\uff0c\u5c31\u662f\u4ecb\u7ecdZookeeper\u80cc\u540e\u4f7f\u7528\u7684\u4e00\u81f4\u6027\u534f\u8bae\u7684(Zookeeper atomic broadcast protocol)\uff0c\u8fd8\u6709\u4e00\u7bc7\u5c31\u662f\u4ecb\u7ecdZookeeper\u672c\u8eab\u7684\u3002\u5728\u8fd9\u4e24\u7bc7\u8bba\u6587\u91cc\u90fd\u63d0\u5230Zookeeper\u662f\u4e00\u4e2a\u5206\u5e03\u5f0f\u534f\u8c03\u670d\u52a1(a service for coordinating processes of distributed applications)\u3002\u90a3\u5206\u5e03\u5f0f\u534f\u8c03\u670d\u52a1\u53c8\u662f\u4e2a\u4ec0\u4e48\u4e1c\u897f\u5462\uff1f\u9996\u5148\u6211\u4eec\u6765\u770b\u201c\u534f\u8c03\u201d\u662f\u4ec0\u4e48\u610f\u601d\u3002<\/p>\n<p>\u8bf4\u5230\u534f\u8c03\uff0c\u6211\u9996\u5148\u60f3\u5230\u7684\u662f\u5317\u4eac\u5f88\u591a\u5341\u5b57\u8def\u53e3\u7684\u4ea4\u901a\u534f\u7ba1\uff0c\u4ed6\u4eec\u624b\u63e1\u7740\u5c0f\u7ea2\u65d7\uff0c\u6307\u6325\u8f66\u8f86\u548c\u884c\u4eba\u662f\u4e0d\u662f\u53ef\u4ee5\u901a\u884c\u3002\u5982\u679c\u6211\u4eec\u628a\u8f66\u8f86\u548c\u884c\u4eba\u6bd4\u55bb\u6210\u8fd0\u884c\u5728\u8ba1\u7b97\u673a\u4e2d\u7684\u5355\u5143(\u7ebf\u7a0b)\uff0c\u90a3\u4e48\u8fd9\u4e2a\u534f\u7ba1\u662f\u5e72\u4ec0\u4e48\u7684\uff1f\u5f88\u591a\u4eba\u90fd\u4f1a\u60f3\u5230\uff0c\u8fd9\u4e0d\u5c31\u662f\u9501\u4e48\uff1f\u5bf9\uff0c\u5728\u4e00\u4e2a\u5e76\u53d1\u7684\u73af\u5883\u91cc\uff0c\u6211\u4eec\u4e3a\u4e86\u907f\u514d\u591a\u4e2a\u8fd0\u884c\u5355\u5143\u5bf9\u5171\u4eab\u6570\u636e\u540c\u65f6\u8fdb\u884c\u4fee\u6539\uff0c\u9020\u6210\u6570\u636e\u635f\u574f\u7684\u60c5\u51b5\u51fa\u73b0\uff0c\u6211\u4eec\u5c31\u5fc5\u987b\u4f9d\u8d56\u50cf\u9501\u8fd9\u6837\u7684\u534f\u8c03\u673a\u5236\uff0c\u8ba9\u6709\u7684\u7ebf\u7a0b\u53ef\u4ee5\u5148\u64cd\u4f5c\u8fd9\u4e9b\u8d44\u6e90\uff0c\u7136\u540e\u5176\u4ed6\u7ebf\u7a0b\u7b49\u5f85\u3002\u5bf9\u4e8e\u8fdb\u7a0b\u5185\u7684\u9501\u6765\u8bb2\uff0c\u6211\u4eec\u4f7f\u7528\u7684\u5404\u79cd\u8bed\u8a00\u5e73\u53f0\u90fd\u5df2\u7ecf\u7ed9\u6211\u4eec\u51c6\u5907\u5f88\u591a\u79cd\u9009\u62e9\u3002\u5c31\u62ffJava\u6765\u8bf4\uff0c\u6709\u6700\u666e\u901a\u4e0d\u8fc7\u7684\u540c\u6b65\u65b9\u6cd5\u6216\u540c\u6b65\u5757\uff1a<\/p>\n<pre>public synchronized void sharedMethod(){\r\n\u00a0\u00a0 \/\/\u5bf9\u5171\u4eab\u6570\u636e\u8fdb\u884c\u64cd\u4f5c\r\n}<\/pre>\n<p>\u4f7f\u7528\u4e86\u8fd9\u79cd\u65b9\u5f0f\u540e\uff0c\u591a\u4e2a\u7ebf\u7a0b\u5bf9sharedMethod\u8fdb\u884c\u64cd\u4f5c\u7684\u65f6\u5019\uff0c\u5c31\u4f1a\u534f\u8c03\u597d\u6b65\u9aa4\uff0c\u4e0d\u4f1a\u5bf9sharedMethod\u91cc\u7684\u8d44\u6e90\u8fdb\u884c\u7834\u574f\uff0c\u4ea7\u751f\u4e0d\u4e00\u81f4\u7684\u60c5\u51b5\u3002\u8fd9\u4e2a\u6700\u7b80\u5355\u7684\u534f\u8c03\u65b9\u6cd5\uff0c\u4f46\u6709\u7684\u65f6\u5019\u6211\u4eec\u53ef\u80fd\u9700\u8981\u66f4\u590d\u6742\u7684\u534f\u8c03\u3002\u6bd4\u5982\u6211\u4eec\u5e38\u5e38\u4e3a\u4e86\u63d0\u9ad8\u6027\u80fd\uff0c\u6211\u4eec\u4f7f\u7528\u8bfb\u5199\u9501\u3002\u56e0\u4e3a\u5927\u90e8\u5206\u65f6\u5019\u6211\u4eec\u5bf9\u8d44\u6e90\u662f\u8bfb\u53d6\u591a\u800c\u4fee\u6539\u5c11\uff0c\u800c\u5982\u679c\u4e0d\u7ba1\u4e09\u4e03\u4e8c\u5341\u4e00\u5168\u90e8\u4f7f\u7528\u6392\u4ed6\u7684\u5199\u9501\uff0c\u90a3\u4e48\u6027\u80fd\u6709\u53ef\u80fd\u5c31\u4f1a\u53d7\u5230\u5f71\u54cd\u3002\u8fd8\u662f\u7528java\u4e3e\u4f8b\uff1a<\/p>\n<pre>public class SharedSource{\r\n\u00a0\u00a0 private ReadWriteLock rwlock = new ReentrantReadWriteLock();\r\n\u00a0\u00a0 private Lock rlock = rwlock.readLock();\r\n\u00a0\u00a0 private Lock wlock = rwlock.writeLock();\r\n\r\n\u00a0\u00a0 public void read(){\r\n\u00a0\u00a0\u00a0\u00a0\u00a0 rlock.lock();\r\n\u00a0\u00a0\u00a0\u00a0\u00a0 try{\r\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 \/\/\u8bfb\u53d6\u8d44\u6e90\r\n\u00a0\u00a0\u00a0\u00a0\u00a0 }finally{\r\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 rlock.unlock();\r\n\u00a0\u00a0\u00a0\u00a0\u00a0 }\r\n\u00a0\u00a0 }\r\n\u00a0 \u00a0\r\n\u00a0\u00a0 public void write(){\r\n\u00a0\u00a0\u00a0\u00a0 wlock.lock();\r\n\u00a0\u00a0\u00a0\u00a0 try{\r\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 \/\/\u5199\u8d44\u6e90\r\n\u00a0\u00a0\u00a0\u00a0 }finally{\r\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 wlock.unlock();\r\n\u00a0\u00a0\u00a0\u00a0 }\r\n\u00a0\u00a0 }\r\n\r\n}<\/pre>\n<p>\u6211\u4eec\u5728\u8fdb\u7a0b\u5185\u8fd8\u6709\u5404\u79cd\u5404\u6837\u7684\u534f\u8c03\u673a\u5236(\u4e00\u822c\u6211\u4eec\u79f0\u4e4b\u4e3a\u540c\u6b65\u673a\u5236)\u3002\u73b0\u5728\u6211\u4eec\u5927\u6982\u4e86\u89e3\u4e86\u4ec0\u4e48\u662f\u534f\u8c03\u4e86\uff0c\u4f46\u662f\u4e0a\u9762\u4ecb\u7ecd\u7684\u534f\u8c03\u90fd\u662f\u5728\u8fdb\u7a0b\u5185\u8fdb\u884c\u534f\u8c03\u3002\u5728\u8fdb\u7a0b\u5185\u8fdb\u884c\u534f\u8c03\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528\u8bed\u8a00\uff0c\u5e73\u53f0\uff0c\u64cd\u4f5c\u7cfb\u7edf\u7b49\u4e3a\u6211\u4eec\u63d0\u4f9b\u7684\u673a\u5236\u3002\u90a3\u4e48\u5982\u679c\u6211\u4eec\u5728\u4e00\u4e2a\u5206\u5e03\u5f0f\u73af\u5883\u4e2d\u5462\uff1f\u4e5f\u5c31\u662f\u6211\u4eec\u7684\u7a0b\u5e8f\u8fd0\u884c\u5728\u4e0d\u540c\u7684\u673a\u5668\u4e0a\uff0c\u8fd9\u4e9b\u673a\u5668\u53ef\u80fd\u4f4d\u4e8e\u540c\u4e00\u4e2a\u673a\u67b6\uff0c\u540c\u4e00\u4e2a\u673a\u623f\u53c8\u6216\u4e0d\u540c\u7684\u6570\u636e\u4e2d\u5fc3\u3002\u5728\u8fd9\u6837\u7684\u73af\u5883\u4e2d\uff0c\u6211\u4eec\u8981\u5b9e\u73b0\u534f\u8c03\u8be5\u600e\u4e48\u529e\uff1f\u90a3\u4e48\u8fd9\u5c31\u662f\u5206\u5e03\u5f0f\u534f\u8c03\u670d\u52a1\u8981\u5e72\u7684\u4e8b\u60c5\u3002<\/p>\n<p>ok\uff0c\u53ef\u80fd\u6709\u4eba\u4f1a\u8bb2\uff0c\u8fd9\u4e2a\u597d\u50cf\u4e5f\u4e0d\u96be\u3002\u65e0\u975e\u662f\u5c06\u539f\u6765\u5728\u540c\u4e00\u4e2a\u8fdb\u7a0b\u5185\u7684\u4e00\u4e9b\u539f\u8bed\u901a\u8fc7\u7f51\u7edc\u5b9e\u73b0\u5728\u5206\u5e03\u5f0f\u73af\u5883\u4e2d\u3002\u662f\u7684\uff0c\u8868\u9762\u4e0a\u662f\u53ef\u4ee5\u8fd9\u4e48\u8bf4\u3002\u4f46\u5206\u5e03\u5f0f\u7cfb\u7edf\u4e2d\uff0c\u8bf4\u5f80\u5f80\u6bd4\u505a\u5bb9\u6613\u5f97\u591a\u3002\u5728\u5206\u5e03\u5f0f\u7cfb\u7edf\u4e2d\uff0c\u6240\u6709\u540c\u4e00\u4e2a\u8fdb\u7a0b\u5185\u7684\u4efb\u4f55\u5047\u8bbe\u90fd\u4e0d\u5b58\u5728\uff1a\u56e0\u4e3a\u7f51\u7edc\u662f\u4e0d\u53ef\u9760\u7684\u3002<\/p>\n<p>\u6bd4\u5982\uff0c\u5728\u540c\u4e00\u4e2a\u8fdb\u7a0b\u5185\uff0c\u4f60\u5bf9\u4e00\u4e2a\u65b9\u6cd5\u7684\u8c03\u7528\u5982\u679c\u6210\u529f\uff0c\u90a3\u5c31\u662f\u6210\u529f(\u5f53\u7136\uff0c\u5982\u679c\u4f60\u7684\u4ee3\u7801\u6709bug\u90a3\u5c31\u53e6\u8bf4\u4e86)\uff0c\u5982\u679c\u8c03\u7528\u5931\u8d25\uff0c\u6bd4\u5982\u629b\u51fa\u5f02\u5e38\u90a3\u5c31\u662f\u8c03\u7528\u5931\u8d25\u3002\u5728\u540c\u4e00\u4e2a\u8fdb\u7a0b\u5185\uff0c\u5982\u679c\u8fd9\u4e2a\u65b9\u6cd5\u5148\u8c03\u7528\u5148\u6267\u884c\uff0c\u90a3\u5c31\u662f\u5148\u6267\u884c\u3002\u4f46\u662f\u5728\u5206\u5e03\u5f0f\u73af\u5883\u4e2d\u5462\uff1f \u7531\u4e8e\u7f51\u7edc\u7684\u4e0d\u53ef\u9760\uff0c\u4f60\u5bf9\u4e00\u4e2a\u670d\u52a1\u7684\u8c03\u7528\u5931\u8d25\u4e86\u5e76\u4e0d\u8868\u793a\u4e00\u5b9a\u662f\u5931\u8d25\u7684\uff0c\u53ef\u80fd\u662f\u6267\u884c\u6210\u529f\u4e86\uff0c\u4f46\u662f\u54cd\u5e94\u8fd4\u56de\u7684\u65f6\u5019\u5931\u8d25\u4e86\u3002\u8fd8\u6709\uff0cA\u548cB\u90fd\u53bb\u8c03\u7528C\u670d\u52a1\uff0c\u5728\u65f6\u95f4\u4e0aA\u8fd8\u5148\u8c03\u7528\u4e00\u4e9b\uff0cB\u540e\u8c03\u7528\uff0c\u90a3\u4e48\u6700\u540e\u7684\u7ed3\u679c\u662f\u4e0d\u662f\u4e00\u5b9aA\u7684\u8bf7\u6c42\u5c31\u5148\u4e8eB\u5230\u8fbe\u5462\uff1f \u8fd9\u4e9b\u672c\u6765\u5728\u540c\u4e00\u4e2a\u8fdb\u7a0b\u5185\u7684\u79cd\u79cd\u5047\u8bbe\u6211\u4eec\u90fd\u8981\u91cd\u65b0\u601d\u8003\uff0c\u6211\u4eec\u8fd8\u8981\u601d\u8003\u8fd9\u4e9b\u95ee\u9898\u7ed9\u6211\u4eec\u7684\u8bbe\u8ba1\u548c\u7f16\u7801\u5e26\u6765\u4e86\u54ea\u4e9b\u5f71\u54cd\u3002\u8fd8\u6709\uff0c\u5728\u5206\u5e03\u5f0f\u73af\u5883\u4e2d\u4e3a\u4e86\u63d0\u5347\u53ef\u9760\u6027\uff0c\u6211\u4eec\u5f80\u5f80\u4f1a\u90e8\u7f72\u591a\u5957\u670d\u52a1\uff0c\u4f46\u662f\u5982\u4f55\u5728\u591a\u5957\u670d\u52a1\u4e2d\u8fbe\u5230\u4e00\u81f4\u6027\uff0c\u8fd9\u5728\u540c\u4e00\u4e2a\u8fdb\u7a0b\u5185\u5f88\u5bb9\u6613\u89e3\u51b3\u7684\u95ee\u9898\uff0c\u4f46\u5728\u5206\u5e03\u5f0f\u73af\u5883\u4e2d\u786e\u5b9e\u4e00\u4e2a\u5927\u96be\u9898\u3002<\/p>\n<p>\u6240\u4ee5\u5206\u5e03\u5f0f\u534f\u8c03\u8fdc\u8fdc\u6bd4\u540c\u4e00\u4e2a\u8fdb\u7a0b\u91cc\u7684\u534f\u8c03\u590d\u6742\u5f97\u591a\uff0c\u6240\u4ee5\u7c7b\u4f3cZookeeper\u8fd9\u7c7b\u57fa\u7840\u670d\u52a1\u5c31\u5e94\u8fd0\u800c\u751f\u3002\u8fd9\u4e9b\u7cfb\u7edf\u90fd\u5728\u5404\u4e2a\u7cfb\u7edf\u4e45\u7ecf\u8003\u9a8c\uff0c\u5b83\u7684\u53ef\u9760\u6027\uff0c\u53ef\u7528\u6027\u90fd\u662f\u7ecf\u8fc7\u7406\u8bba\u548c\u5b9e\u8df5\u7684\u9a8c\u8bc1\u7684\u3002\u6240\u4ee5\u6211\u4eec\u5728\u6784\u5efa\u4e00\u4e9b\u5206\u5e03\u5f0f\u7cfb\u7edf\u7684\u65f6\u5019\uff0c\u5c31\u53ef\u4ee5\u4ee5\u8fd9\u7c7b\u7cfb\u7edf\u4e3a\u8d77\u70b9\u6765\u6784\u5efa\u6211\u4eec\u7684\u7cfb\u7edf\uff0c\u8fd9\u5c06\u8282\u7701\u4e0d\u5c11\u6210\u672c\uff0c\u800c\u4e14bug\u4e5f\u5c06\u66f4\u5c11\u3002<\/p>\n<p>\u672c\u7bc7\u6587\u7ae0\u8bd5\u56fe\u4ece\u5916\u56f4\u4ecb\u7ecd\u4e00\u4e0bZookeeper\u662f\u4e00\u4e2a\u4ec0\u4e48\u6837\u5b50\u7684\u670d\u52a1\u548c\u6211\u4eec\u4e3a\u4ec0\u4e48\u9700\u8981\u8fd9\u6837\u4e00\u79cd\u670d\u52a1\u3002\u5728\u540e\u9762\u7684\u6587\u7ae0\u4e2d\u4f1a\u4ecb\u7ecdZookeeper\u5230\u5e95\u80fd\u5e72\u4e9b\u4ec0\u4e48\u3002<\/p>\n<p>&nbsp;<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Google\u7684\u4e09\u7bc7\u8bba\u6587\u5f71\u54cd\u4e86\u5f88\u591a\u5f88\u591a\u4eba\uff0c\u4e5f\u5f71\u54cd\u4e86\u5f88\u591a\u5f88\u591a\u7cfb\u7edf\u3002\u8fd9\u4e09\u7bc7\u8bba\u6587\u4e00\u76f4\u662f\u5206\u5e03\u5f0f\u9886\u57df\u4f20\u9605\u7684\u7ecf\u5178\u3002\u6839\u636eMapReduce\uff0c\u4e8e\u662f\u6211\u4eec\u6709\u4e86Hadoop\uff1b\u6839\u636eGFS\uff0c\u4e8e\u662f\u6211\u4eec\u6709\u4e86HDFS\uff1b\u6839\u636eBigTable\uff0c\u4e8e\u662f\u6211\u4eec\u6709\u4e86HBase\u3002\u800c\u5728\u8fd9\u4e09\u7bc7\u8bba\u6587\u91cc\u90fd\u63d0\u53caGoogle\u7684\u4e00\u4e2alock service\u2014Chubby\uff0c\u54e6\uff0c\u4e8e\u662f\u6211\u4eec\u6709\u4e86Zookeeper\u3002 &nbsp; \u968f\u7740\u5927\u6570\u636e\u7684\u706b\u70ed\uff0cHxx\u4eec\u5df2\u7ecf\u53d8\u5f97\u8033\u719f\u80fd\u8be6\uff0c\u73b0\u5728\u4f5c\u4e3a\u4e00\u4e2a\u5f00\u53d1\u4eba\u5458\u5982\u679c\u90fd\u4e0d\u77e5\u9053\u8fd9\u51e0\u4e2a\u540d\u8bcd\u51fa\u95e8\u90fd\u597d\u50cf\u4e0d\u597d\u610f\u601d\u8ddf\u4eba\u6253\u62db\u547c\u3002\u4f46\u5b9e\u9645\u4e0a\u5bf9\u6211\u4eec\u8fd9\u4e9b\u975e\u5927\u6570\u636e\u5f00\u53d1\u4eba\u5458\u800c\u8a00\uff0cZookeeper\u662f\u6bd4Hxx\u4eec\u53ef\u80fd\u63a5\u89e6\u5230\u66f4\u591a\u7684\u4e00\u4e2a\u57fa\u7840\u670d\u52a1\u3002\u4f46\u662f\uff0c\u65e0\u5948\u7684\u662f\u5b83\u4e00\u76f4\u9ed8\u9ed8\u7684\u4f4d\u4e8e\u4e8c\u7ebf\uff0c\u4ece\u6765\u6ca1\u6709Hxx\u4eec\u90a3\u4e48\u8000\u773c\u3002\u90a3\u4e48\u5230\u5e95\u4ec0\u4e48\u662fZookeeper\u5462\uff1fZookeeper\u53ef\u4ee5\u7528\u6765\u5e72\u4ec0\u4e48\uff1f\u6211\u4eec\u5c06\u5982\u4f55\u4f7f\u7528Zookeeper\uff1fZookeeper\u53c8\u662f\u600e\u4e48\u5b9e\u73b0\u7684\uff1f \u4f34\u968f\u7740Zookeeper\u6709\u4e24\u7bc7\u8bba\u6587\uff1a\u4e00\u7bc7\u662fZab\uff0c\u5c31\u662f\u4ecb\u7ecdZookeeper\u80cc\u540e\u4f7f\u7528\u7684\u4e00\u81f4\u6027\u534f\u8bae\u7684(Zookeeper atomic broadcast protocol)\uff0c\u8fd8\u6709\u4e00\u7bc7\u5c31\u662f\u4ecb\u7ecdZookeeper\u672c\u8eab\u7684\u3002\u5728\u8fd9\u4e24\u7bc7\u8bba\u6587\u91cc\u90fd\u63d0\u5230Zookeeper\u662f\u4e00\u4e2a\u5206\u5e03\u5f0f\u534f\u8c03\u670d\u52a1(a service for coordinating processes of distributed applications)\u3002\u90a3\u5206\u5e03\u5f0f\u534f\u8c03\u670d\u52a1\u53c8\u662f\u4e2a\u4ec0\u4e48\u4e1c\u897f\u5462\uff1f\u9996\u5148\u6211\u4eec\u6765\u770b\u201c\u534f\u8c03\u201d\u662f\u4ec0\u4e48\u610f\u601d\u3002 \u8bf4\u5230\u534f\u8c03\uff0c\u6211\u9996\u5148\u60f3\u5230\u7684\u662f\u5317\u4eac\u5f88\u591a\u5341\u5b57\u8def\u53e3\u7684\u4ea4\u901a\u534f\u7ba1\uff0c\u4ed6\u4eec\u624b\u63e1\u7740\u5c0f\u7ea2\u65d7\uff0c\u6307\u6325\u8f66\u8f86\u548c\u884c\u4eba\u662f\u4e0d\u662f\u53ef\u4ee5\u901a\u884c\u3002\u5982\u679c\u6211\u4eec\u628a\u8f66\u8f86\u548c\u884c\u4eba\u6bd4\u55bb\u6210\u8fd0\u884c\u5728\u8ba1\u7b97\u673a\u4e2d\u7684\u5355\u5143(\u7ebf\u7a0b)\uff0c\u90a3\u4e48\u8fd9\u4e2a\u534f\u7ba1\u662f\u5e72\u4ec0\u4e48\u7684\uff1f\u5f88\u591a\u4eba\u90fd\u4f1a\u60f3\u5230\uff0c\u8fd9\u4e0d\u5c31\u662f\u9501\u4e48\uff1f\u5bf9\uff0c\u5728\u4e00\u4e2a\u5e76\u53d1\u7684\u73af\u5883\u91cc\uff0c\u6211\u4eec\u4e3a\u4e86\u907f\u514d\u591a\u4e2a\u8fd0\u884c\u5355\u5143\u5bf9\u5171\u4eab\u6570\u636e\u540c\u65f6\u8fdb\u884c\u4fee\u6539\uff0c\u9020\u6210\u6570\u636e\u635f\u574f\u7684\u60c5\u51b5\u51fa\u73b0\uff0c\u6211\u4eec\u5c31\u5fc5\u987b\u4f9d\u8d56\u50cf\u9501\u8fd9\u6837\u7684\u534f\u8c03\u673a\u5236\uff0c\u8ba9\u6709\u7684\u7ebf\u7a0b\u53ef\u4ee5\u5148\u64cd\u4f5c\u8fd9\u4e9b\u8d44\u6e90\uff0c\u7136\u540e\u5176\u4ed6\u7ebf\u7a0b\u7b49\u5f85\u3002\u5bf9\u4e8e\u8fdb\u7a0b\u5185\u7684\u9501\u6765\u8bb2\uff0c\u6211\u4eec\u4f7f\u7528\u7684\u5404\u79cd\u8bed\u8a00\u5e73\u53f0\u90fd\u5df2\u7ecf\u7ed9\u6211\u4eec\u51c6\u5907\u5f88\u591a\u79cd\u9009\u62e9\u3002\u5c31\u62ffJava\u6765\u8bf4\uff0c\u6709\u6700\u666e\u901a\u4e0d\u8fc7\u7684\u540c\u6b65\u65b9\u6cd5\u6216\u540c\u6b65\u5757\uff1a public synchronized void sharedMethod(){ \u00a0\u00a0 \/\/\u5bf9\u5171\u4eab\u6570\u636e\u8fdb\u884c\u64cd\u4f5c } \u4f7f\u7528\u4e86\u8fd9\u79cd\u65b9\u5f0f\u540e\uff0c\u591a\u4e2a\u7ebf\u7a0b\u5bf9sharedMethod\u8fdb\u884c\u64cd\u4f5c\u7684\u65f6\u5019\uff0c\u5c31\u4f1a\u534f\u8c03\u597d\u6b65\u9aa4\uff0c\u4e0d\u4f1a\u5bf9sharedMethod\u91cc\u7684\u8d44\u6e90\u8fdb\u884c\u7834\u574f\uff0c\u4ea7\u751f\u4e0d\u4e00\u81f4\u7684\u60c5\u51b5\u3002\u8fd9\u4e2a\u6700\u7b80\u5355\u7684\u534f\u8c03\u65b9\u6cd5\uff0c\u4f46\u6709\u7684\u65f6\u5019\u6211\u4eec\u53ef\u80fd\u9700\u8981\u66f4\u590d\u6742\u7684\u534f\u8c03\u3002\u6bd4\u5982\u6211\u4eec\u5e38\u5e38\u4e3a\u4e86\u63d0\u9ad8\u6027\u80fd\uff0c\u6211\u4eec\u4f7f\u7528\u8bfb\u5199\u9501\u3002\u56e0\u4e3a\u5927\u90e8\u5206\u65f6\u5019\u6211\u4eec\u5bf9\u8d44\u6e90\u662f\u8bfb\u53d6\u591a\u800c\u4fee\u6539\u5c11\uff0c\u800c\u5982\u679c\u4e0d\u7ba1\u4e09\u4e03\u4e8c\u5341\u4e00\u5168\u90e8\u4f7f\u7528\u6392\u4ed6\u7684\u5199\u9501\uff0c\u90a3\u4e48\u6027\u80fd\u6709\u53ef\u80fd\u5c31\u4f1a\u53d7\u5230\u5f71\u54cd\u3002\u8fd8\u662f\u7528java\u4e3e\u4f8b\uff1a public class SharedSource{ \u00a0\u00a0 private ReadWriteLock rwlock = new ReentrantReadWriteLock(); \u00a0\u00a0 private Lock rlock = rwlock.readLock(); \u00a0\u00a0 private Lock wlock = rwlock.writeLock(); \u00a0\u00a0 public void read(){ \u00a0\u00a0\u00a0\u00a0\u00a0 rlock.lock(); \u00a0\u00a0\u00a0\u00a0\u00a0 try{ \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[8],"tags":[],"class_list":["post-18672","post","type-post","status-publish","format-standard","hentry","category-os"],"_links":{"self":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/18672","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/comments?post=18672"}],"version-history":[{"count":1,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/18672\/revisions"}],"predecessor-version":[{"id":18673,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/18672\/revisions\/18673"}],"wp:attachment":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/media?parent=18672"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/categories?post=18672"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/tags?post=18672"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}