{"id":15492,"date":"2024-11-18T18:28:12","date_gmt":"2024-11-18T10:28:12","guid":{"rendered":"https:\/\/fwq.ai\/blog\/?p=15492"},"modified":"2024-11-18T18:28:12","modified_gmt":"2024-11-18T10:28:12","slug":"docker%e7%9a%84%e5%91%bd%e4%bb%a4%e4%b9%8b%e9%9b%86%e7%be%a4%e7%ae%a1%e7%90%86-swarm","status":"publish","type":"post","link":"https:\/\/fwq.ai\/blog\/15492\/","title":{"rendered":"Docker\u7684\u547d\u4ee4\u4e4b\u96c6\u7fa4\u7ba1\u7406 swarm"},"content":{"rendered":"<p class=\"p1\"><span class=\"s1\">Swarm \u662f\u63d0\u4f9b Docker \u5bb9\u5668\u96c6\u7fa4\u670d\u52a1\uff0c\u662f Docker \u5b98\u65b9\u5bf9\u5bb9\u5668\u4e91\u751f\u6001\u8fdb\u884c\u652f\u6301\u7684\u6838\u5fc3\u65b9\u6848\u3002<\/span>\u4f7f\u7528\u5b83\uff0c\u7528\u6237\u53ef\u4ee5\u5c06\u591a\u4e2a Docker \u4e3b\u673a\u5c01\u88c5\u4e3a\u5355\u4e2a\u5927\u578b\u7684\u865a\u62df Docker \u4e3b\u673a\uff0c\u5feb\u901f\u6253\u9020\u4e00\u5957\u5bb9\u5668\u4e91\u5e73\u53f0\u3002<\/p>\n<p class=\"p1\"><span class=\"s1\">\u4f5c\u4e3a\u5bb9\u5668\u96c6\u7fa4\u7ba1\u7406\u5668\uff0cSwarm \u6700\u5927\u7684\u4f18\u52bf\u4e4b\u4e00\u5c31\u662f 100% \u652f\u6301\u6807\u51c6\u7684 Docker API\u3002\u5404\u79cd\u57fa\u4e8e\u6807\u51c6 API \u7684\u5de5\u5177\u6bd4\u5982 Compose\u3001docker-py\u3001\u5404\u79cd\u7ba1\u7406\u8f6f\u4ef6\uff0c\u751a\u81f3 Docker \u672c\u8eab\u7b49\u90fd\u53ef\u4ee5\u5f88\u5bb9\u6613\u7684\u4e0e Swarm \u8fdb\u884c\u96c6\u6210\u3002\u8fd9\u5927\u5927\u65b9\u4fbf\u4e86\u7528\u6237\u5c06\u539f\u5148\u57fa\u4e8e\u5355\u8282\u70b9\u7684\u7cfb\u7edf\u79fb\u690d\u5230 Swarm \u4e0a\u3002\u540c\u65f6 Swarm \u5185\u7f6e\u4e86\u5bf9 Docker \u7f51\u7edc\u63d2\u4ef6\u7684\u652f\u6301\uff0c\u7528\u6237\u53ef\u4ee5\u5f88\u5bb9\u6613\u5730\u90e8\u7f72\u8de8\u4e3b\u673a\u7684\u5bb9\u5668\u96c6\u7fa4\u670d\u52a1\u3002<\/span><\/p>\n<p class=\"p1\">\n<p class=\"p1\"><span class=\"s1\">\u901a\u8fc7\u4f7f\u7528 Swarm\uff0c\u7528\u6237\u53ef\u4ee5\u5c06\u82e5\u5e72 Docker \u4e3b\u673a\u8282\u70b9\u7ec4\u6210\u7684\u96c6\u7fa4\u5f53\u4f5c\u4e00\u4e2a\u5927\u7684\u865a\u62df Docker \u4e3b\u673a\u4f7f\u7528\u3002\u5e76\u4e14\uff0c\u539f\u5148\u57fa\u4e8e\u5355\u673a\u7684 Docker \u5e94\u7528\uff0c\u53ef\u4ee5\u65e0\u7f1d\u7684\u8fc1\u79fb\u5230 Swarm \u4e0a\u6765\u3002<\/span><\/p>\n<p class=\"p1\"><span class=\"s1\">\u5b9e\u73b0\u8fd9\u4e9b\u529f\u80fd\u7684\u524d\u63d0\u662f\u670d\u52a1\u81ea\u52a8\u53d1\u73b0\u80fd\u529b\u3002\u5728\u73b0\u4ee3\u5206\u5e03\u5f0f\u7cfb\u7edf\u4e2d\uff0c\u670d\u52a1\u7684\u81ea\u52a8\u53d1\u73b0\u3001\u6ce8\u518c\u3001\u66f4\u65b0\u7b49\u80fd\u529b\u5c06\u6210\u4e3a\u7cfb\u7edf\u7684\u57fa\u672c\u4fdd\u969c\u548c\u91cd\u8981\u57fa\u7840\u3002<\/span><\/p>\n<p class=\"p1\"><span class=\"s1\">\u5728\u751f\u4ea7\u73af\u5883\u4e2d\uff0cSwarm \u7684\u7ba1\u7406\u8282\u70b9\u548c\u53d1\u73b0\u670d\u52a1\u540e\u7aef\u8981\u91c7\u7528\u9ad8\u53ef\u7528\u6027\u4e0a\u7684\u4fdd\u62a4\uff0c\u53ef\u4ee5\u91c7\u7528\u96c6\u7fa4\u6a21\u5f0f\u3002<\/span><\/p>\n<p class=\"p1\"><span class=\"s1\">\u503c\u5f97\u4e00\u63d0\u7684\u662f\uff0cSwarm V2 \u529f\u80fd\u5df2\u7ecf\u88ab\u65e0\u7f1d\u5d4c\u5165\u5230\u4e86 Docker 1.12+ \u7248\u672c\u4e2d\uff0c\u7528\u6237\u4eca\u540e\u53ef\u4ee5\u76f4\u63a5\u4f7f\u7528 Docker \u547d\u4ee4\u6765\u5b8c\u6210\u76f8\u5173\u529f\u80fd\u7684\u914d\u7f6e\uff0c\u8fd9\u5c06\u4f7f\u5f97\u96c6\u7fa4\u529f\u80fd\u7684\u7ba1\u7406\u66f4\u52a0\u7b80\u4fbf\u3002<\/span><\/p>\n<pre class=\"p1\"><strong>Usage: docker swarm COMMAND<\/strong>\r\n\r\n<strong>Manage Swarm<\/strong>\r\n\r\n<strong>Options:<\/strong>\r\n\u00a0 \u00a0--help \u00a0 Print usage\r\n\r\n<strong>Commands:<\/strong>\r\n\u00a0<strong> init<\/strong>\u00a0 \u00a0 \u00a0 \u00a0 Initialize a swarm\r\n<strong>\u00a0 join\u00a0<\/strong> \u00a0 \u00a0 \u00a0 Join a swarm as a node and\/or manager\r\n<strong>\u00a0 join-token<\/strong>\u00a0 Manage join tokens\r\n<strong>\u00a0 leave<\/strong> \u00a0 \u00a0 \u00a0 Leave the swarm\r\n<strong>\u00a0 unlock<\/strong>\u00a0 \u00a0 \u00a0 Unlock swarm\r\n<strong>\u00a0 unlock-key<\/strong>\u00a0 Manage the unlock key\u00a0\r\n<strong>\u00a0 update\u00a0<\/strong> \u00a0 \u00a0 Update the swarm\r\n\r\nRun 'docker swarm COMMAND --help' for more information on a command.\r\n# \u53ef\u4ee5\u4f7f\u7528 docker swarm COMMAND --help \uff0c\u7ee7\u7eed\u67e5\u770b\u4f7f\u7528\u8bf4\u660e\u3002<\/pre>\n<h3>\u4e00\u3001\u8be6\u7ec6\u4ecb\u7ecd<\/h3>\n<table cellspacing=\"5\" cellpadding=\"5\">\n<tbody>\n<tr>\n<td valign=\"top\" width=\"22%\">init<\/td>\n<td valign=\"top\">\u521b\u5efa\uff0c\u521d\u59cb\u5316\u4e00\u4e2adocker\u7fa4\u96c6<br \/>\n\u683c\u5f0f\uff1adocker swarm init [OPTIONS]<br \/>\n\u5e38\u7528\u9009\u9879\uff1a<br \/>\n\u2013advertise-addr\u00a0string #\u6307\u5b9a\u64ad\u53d1\u5730\u5740\uff0c\u683c\u5f0f\uff1a&lt;ip | interface&gt;[:port] ,\u9ed8\u8ba4\u7aef\u53e3 2377<br \/>\n\u2013dispatcher-heartbeat\u00a0duration \uff03\u65b0\u8df3\u68c0\u67e5\uff0c\u9ed8\u8ba45S\u4f8b\u5982\uff1adocker swarm init \u2013advertise-addr enp0s8<br \/>\n\u4f8b\u5982\uff1adocker swarm init \u2013advertise-addr=192.168.80.121:2377 \u2013listen-addr=192.168.80.121:2377Tips 1\uff1a\u5173\u4e8eadvertise-addr \u548c listen-addr\u7684\u533a\u522b\uff0c\u5f85\u8865\u5145..\u76ee\u524d\u90fd\u8bbe\u7f6e\u6210\u4e00\u6837\u7684IP\u548c\u7aef\u53e3<\/td>\n<\/tr>\n<tr>\n<td valign=\"top\">join-token<\/td>\n<td valign=\"top\">\u67e5\u770bdocker\u96c6\u7fa4\u4e2dmanager\u548cwork\u7684token\u4fe1\u606f.<br \/>\n\u683c\u5f0f\uff1adocker swarm join-token [OPTIONS] (worker|manager)<br \/>\n-q, \u2013quiet\u00a0#\u4ec5\u663e\u793atoken\uff0c\u5426\u5219\u5c06\u663e\u793a\u5b8c\u6574Join swarm\u7684\u5b8c\u6574\u6307\u4ee4\u3002<br \/>\n\u4f8b\u5982\uff1adocker swarm join-token worker<br \/>\n\u4f8b\u5982\uff1adocker swarm join-token manager<br \/>\n\u4f8b\u5982\uff1adocker swarm join-token -q manager<\/td>\n<\/tr>\n<tr>\n<td valign=\"top\">leave<\/td>\n<td valign=\"top\">\u79bb\u5f00\u7fa4\u96c6\uff0c\u8282\u70b9\u79bb\u5f00\u96c6\u7fa4\u540e\uff0c\u72b6\u6001\u66f4\u6539\u4e3aDown\uff0c\u5982\u679c\u8be5\u8282\u70b9\u662fmaster\uff0c\u5219\u5220\u9664\u6574\u4e2a\u96c6\u7fa4\u3002<br \/>\n\u4f8b\u5982\uff1adocker swarm leave<br \/>\n\u4f8b\u5982\uff1adocker swarm leave\u00a0 -f<\/td>\n<\/tr>\n<tr>\n<td valign=\"top\">join<\/td>\n<td valign=\"top\">\u52a0\u5165\u96c6\u7fa4<br \/>\n\u683c\u5f0f\uff1adocker swarm join [OPTIONS] HOST:PORT<\/td>\n<\/tr>\n<tr>\n<td valign=\"top\">update<\/td>\n<td valign=\"top\">\u66f4\u6539swarm\u4fe1\u606f\uff0c\u4f8b\u5982\u5fc3\u8df3\u68c0\u6d4b\u7b49\u3002<\/td>\n<\/tr>\n<tr>\n<td valign=\"top\">unlock<\/td>\n<td valign=\"top\">\u89e3\u9501\u7fa4\u96c6<\/td>\n<\/tr>\n<tr>\n<td valign=\"top\">unlock-key<\/td>\n<td valign=\"top\">\u83b7\u53d6\u89e3\u9501\u7fa4\u96c6\u7684Key<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n","protected":false},"excerpt":{"rendered":"<p>Swarm \u662f\u63d0\u4f9b Docker \u5bb9\u5668\u96c6\u7fa4\u670d\u52a1\uff0c\u662f Docker \u5b98\u65b9\u5bf9\u5bb9\u5668\u4e91\u751f\u6001\u8fdb\u884c\u652f\u6301\u7684\u6838\u5fc3\u65b9\u6848\u3002\u4f7f\u7528\u5b83\uff0c\u7528\u6237\u53ef\u4ee5\u5c06\u591a\u4e2a Docker \u4e3b\u673a\u5c01\u88c5\u4e3a\u5355\u4e2a\u5927\u578b\u7684\u865a\u62df Docker \u4e3b\u673a\uff0c\u5feb\u901f\u6253\u9020\u4e00\u5957\u5bb9\u5668\u4e91\u5e73\u53f0\u3002 \u4f5c\u4e3a\u5bb9\u5668\u96c6\u7fa4\u7ba1\u7406\u5668\uff0cSwarm \u6700\u5927\u7684\u4f18\u52bf\u4e4b\u4e00\u5c31\u662f 100% \u652f\u6301\u6807\u51c6\u7684 Docker API\u3002\u5404\u79cd\u57fa\u4e8e\u6807\u51c6 API \u7684\u5de5\u5177\u6bd4\u5982 Compose\u3001docker-py\u3001\u5404\u79cd\u7ba1\u7406\u8f6f\u4ef6\uff0c\u751a\u81f3 Docker \u672c\u8eab\u7b49\u90fd\u53ef\u4ee5\u5f88\u5bb9\u6613\u7684\u4e0e Swarm \u8fdb\u884c\u96c6\u6210\u3002\u8fd9\u5927\u5927\u65b9\u4fbf\u4e86\u7528\u6237\u5c06\u539f\u5148\u57fa\u4e8e\u5355\u8282\u70b9\u7684\u7cfb\u7edf\u79fb\u690d\u5230 Swarm \u4e0a\u3002\u540c\u65f6 Swarm \u5185\u7f6e\u4e86\u5bf9 Docker \u7f51\u7edc\u63d2\u4ef6\u7684\u652f\u6301\uff0c\u7528\u6237\u53ef\u4ee5\u5f88\u5bb9\u6613\u5730\u90e8\u7f72\u8de8\u4e3b\u673a\u7684\u5bb9\u5668\u96c6\u7fa4\u670d\u52a1\u3002 \u901a\u8fc7\u4f7f\u7528 Swarm\uff0c\u7528\u6237\u53ef\u4ee5\u5c06\u82e5\u5e72 Docker \u4e3b\u673a\u8282\u70b9\u7ec4\u6210\u7684\u96c6\u7fa4\u5f53\u4f5c\u4e00\u4e2a\u5927\u7684\u865a\u62df Docker \u4e3b\u673a\u4f7f\u7528\u3002\u5e76\u4e14\uff0c\u539f\u5148\u57fa\u4e8e\u5355\u673a\u7684 Docker \u5e94\u7528\uff0c\u53ef\u4ee5\u65e0\u7f1d\u7684\u8fc1\u79fb\u5230 Swarm \u4e0a\u6765\u3002 \u5b9e\u73b0\u8fd9\u4e9b\u529f\u80fd\u7684\u524d\u63d0\u662f\u670d\u52a1\u81ea\u52a8\u53d1\u73b0\u80fd\u529b\u3002\u5728\u73b0\u4ee3\u5206\u5e03\u5f0f\u7cfb\u7edf\u4e2d\uff0c\u670d\u52a1\u7684\u81ea\u52a8\u53d1\u73b0\u3001\u6ce8\u518c\u3001\u66f4\u65b0\u7b49\u80fd\u529b\u5c06\u6210\u4e3a\u7cfb\u7edf\u7684\u57fa\u672c\u4fdd\u969c\u548c\u91cd\u8981\u57fa\u7840\u3002 \u5728\u751f\u4ea7\u73af\u5883\u4e2d\uff0cSwarm \u7684\u7ba1\u7406\u8282\u70b9\u548c\u53d1\u73b0\u670d\u52a1\u540e\u7aef\u8981\u91c7\u7528\u9ad8\u53ef\u7528\u6027\u4e0a\u7684\u4fdd\u62a4\uff0c\u53ef\u4ee5\u91c7\u7528\u96c6\u7fa4\u6a21\u5f0f\u3002 \u503c\u5f97\u4e00\u63d0\u7684\u662f\uff0cSwarm V2 \u529f\u80fd\u5df2\u7ecf\u88ab\u65e0\u7f1d\u5d4c\u5165\u5230\u4e86 Docker 1.12+ \u7248\u672c\u4e2d\uff0c\u7528\u6237\u4eca\u540e\u53ef\u4ee5\u76f4\u63a5\u4f7f\u7528 Docker \u547d\u4ee4\u6765\u5b8c\u6210\u76f8\u5173\u529f\u80fd\u7684\u914d\u7f6e\uff0c\u8fd9\u5c06\u4f7f\u5f97\u96c6\u7fa4\u529f\u80fd\u7684\u7ba1\u7406\u66f4\u52a0\u7b80\u4fbf\u3002 Usage: docker swarm COMMAND Manage [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[17],"tags":[],"class_list":["post-15492","post","type-post","status-publish","format-standard","hentry","category-docker"],"_links":{"self":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/15492","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=15492"}],"version-history":[{"count":2,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/15492\/revisions"}],"predecessor-version":[{"id":15494,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/15492\/revisions\/15494"}],"wp:attachment":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/media?parent=15492"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/categories?post=15492"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/tags?post=15492"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}