這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
Swarmd程式支援的命令選項:
func init() { mainCmd.Flags().BoolP("version", "v", false, "Display the version and exit") mainCmd.Flags().StringP("log-level", "l", "info", "Log level (options \"debug\", \"info\", \"warn\", \"error\", \"fatal\", \"panic\")") mainCmd.Flags().StringP("state-dir", "d", "./swarmkitstate", "State directory") mainCmd.Flags().StringP("join-token", "", "", "Specifies the secret token required to join the cluster") mainCmd.Flags().String("engine-addr", "unix:///var/run/docker.sock", "Address of engine instance of agent.") mainCmd.Flags().String("hostname", "", "Override reported agent hostname") mainCmd.Flags().String("listen-remote-api", "0.0.0.0:4242", "Listen address for remote API") mainCmd.Flags().String("listen-control-api", "./swarmkitstate/swarmd.sock", "Listen socket for control API") mainCmd.Flags().String("listen-debug", "", "Bind the Go debug server on the provided address") mainCmd.Flags().String("join-addr", "", "Join cluster with a node at this address") mainCmd.Flags().Bool("force-new-cluster", false, "Force the creation of a new cluster from data directory") mainCmd.Flags().Uint32("heartbeat-tick", 1, "Defines the heartbeat interval (in seconds) for raft member health-check") mainCmd.Flags().Uint32("election-tick", 3, "Defines the amount of ticks (in seconds) needed without a Leader to trigger a new election") mainCmd.Flags().Var(&externalCAOpt, "external-ca", "Specifications of one or more certificate signing endpoints")}
(1)version,log-level和hostname最簡單,不必細說。
(2)state-dir目錄存放遠端manager以及CA認證等相關資訊:
# ls -alttotal 24drwx------ 5 root root 4096 Jul 29 02:40 .drwx------ 4 root root 4096 Jul 29 02:40 raft-rw------- 1 root root 63 Jul 29 02:40 state.jsondrwxr-xr-x 2 root root 4096 Jul 29 02:40 workerdrwxr-xr-x 2 root root 4096 Jul 29 02:40 certificatesdrwxr-xr-x 3 root root 4096 Jul 29 02:40 ..
(3)join-token是node用來加入某個cluster的token,在第一次認證請求時會被用到。
(4)engine-addr指定實際用來執行executor的engine位置,預設是使用本機Docker。
(5)listen-remote-api指定監聽一個tcp port,用來接收和處理其它node的訪問請求。
(6)listen-control-api指定一個Unix socket,用來接收和處理swarmctl程式的訪問請求。
(7)listen-debug指定監聽一個用來debug程式的連接埠。
(8)join-addr指定要加入的cluster的一個node地址,通過串連這個node來加入這個cluster。
(9)其餘force-new-cluster,heartbeat-tick,election-tick和external-ca解釋的都很清楚,不必贅述。