Docker學習—Machine

前言

 前面《Docker學習—Compose》文中介紹了Compose的使用方式;接下來繼續了解docker三劍客之一的 Machine;

一、Docker Machine簡介

 1、什麼是Docker Machine?

  Docker Machine是一個可以在虛擬主機上安裝Docker引擎,並使用Docker Machine命令管理主機的工具。您可以使用電腦在本地Mac或Windows box、公司網路、數據中心或雲提供商(如Azure、AWS)上創建Docker主機。

  Docker Machine是一個工具,可以讓您在虛擬主機上安裝Docker Engine,使用Docker Machine命令,您可以啟動、檢查、停止和重新啟動託管主機,升級Docker客戶端和守護程式,並配置Docker客戶端與主機對話。  

 2、為什麼要用Docker Machine?

  Docker Machine有這兩個廣泛的用例。

  • 在舊的桌面系統,想在Mac或Windows上運行Docker

  

   如果您主要在舊版Mac或Windows筆記型電腦電腦或桌面上工作,但不符合新的Docker desktop for Mac和Docker desktop for Windows apps的要求,則需要Docker Machine在本地運行Docker Engine。

  • 想在遠程系統上配置Docker主機

   

   Docker引擎在Linux系統上本機運行。如果您的主系統是Linux機器,並且希望運行docker命令,您只需下載並安裝docker Engine。但是,如果你想在一個網路上、雲端甚至本地提供多個Docker主機,你需要Docker Machine。

 3、Docker Engine和Docker Machine有什麼區別?

  通常說「 Docker」時,通常指的是Docker Engine,由Docker守護程式組成的客戶端-伺服器應用程式,用於指定與守護程式交互的介面的REST API和與守護程式進行對話的命令行介面(CLI)客戶端(通過REST API包裝器)。

  Docker Engine從CLI接受命令,

  例如 :docker run <image> 啟動容器運行鏡像;docker ps 列出正在運行的容器;docker image ls 列出鏡像列表等

   

   Docker Machine是用於調配和管理Docker主機(帶有Docker Engine的主機)的工具。通常,您在本地系統上安裝Docker Machine。Docker Machine有自己的命令行客戶端 docker-machine和Docker Engine客戶端docker您可以使用Machine在一個或多個虛擬系統上安裝Docker Engine。這些虛擬系統可以是本地的(如在Mac或Windows上使用Machine在VirtualBox中安裝並運行Docker Engine時),也可以是遠程的(如在Mac上使用Cloud在雲提供商上配置Docker主機時)。可以將Dockeri主機本身視為(有時也稱為託管的「機器」)。

 

  4、Docker Machine支援機器驅動程式

二、Docker Machine應用示例

 本次示例採用windows docker 中使用Docker Machine來實現虛擬環境(hyper-v)中dcoker環境 生成

 1、安裝Docker Machine:

  • MacOS中使用:
$ base=https://github.com/docker/machine/releases/download/v0.16.0 &&
  curl -L $base/docker-machine-$(uname -s)-$(uname -m) >/usr/local/bin/docker-machine &&
  chmod +x /usr/local/bin/docker-machine
  • Linux中運行:
$ base=https://github.com/docker/machine/releases/download/v0.16.0 &&
  curl -L $base/docker-machine-$(uname -s)-$(uname -m) >/tmp/docker-machine &&
  sudo mv /tmp/docker-machine /usr/local/bin/docker-machine &&
  chmod +x /usr/local/bin/docker-machine
  • Windows中使用Git BASH 執行命令:
$ base=https://github.com/docker/machine/releases/download/v0.16.0 &&
  mkdir -p "$HOME/bin" &&
  curl -L $base/docker-machine-Windows-x86_64.exe > "$HOME/bin/docker-machine.exe" &&
  chmod +x "$HOME/bin/docker-machine.exe"

 2、查看安裝版本:docker-machine version

  

  3、設置hyper-網路代理

   進入Hyper-V 管理器添加虛擬交換器如下圖:

    

 4、使用docker-machine創建docker環境:在Git BASH執行以下命令

命令:docker-machine create -d hyperv --hyperv-virtual-switch <NameOfVirtualSwitch> <nameOfNode>
示例:docker-machine create -d hyperv --hyperv-virtual-switch docker_Virtual_Switch worker1

  該命令下載安裝了Docker守護程式的輕量級Linux發行版(boot2docker)並在hyperv中創建名為<nameOfNode>的實例運行。  具體docker-machine命令還需要進一步學習

  結果如下: 則創建docker環境成功

   

  5、進入創建docker環境:

--進入worker1環境
$ eval $(
"C:\Users\cwsheng\bin\docker-machine.exe" env worker1) --查看worker1中運行容器 $ docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

三、Docker Machine命令   

Options:
  --debug, -D                                           啟用調試模式
  --storage-path, -s "C:\Users\cwsheng\.docker\machine" 配置存儲路徑 [$MACHINE_STORAGE_PATH]
  --tls-ca-cert                                         驗證遠程CA [$MACHINE_TLS_CA_CERT]
  --tls-ca-key                                          生成證書的私鑰 [$MACHINE_TLS_CA_KEY]
  --tls-client-cert                                     用於TLS的客戶端證書 [$MACHINE_TLS_CLIENT_CERT]
  --tls-client-key                                      客戶端TLS身份驗證中使用的私鑰[$MACHINE_TLS_CLIENT_KEY]
  --github-api-token                                    用於請求Github API的令牌 [$MACHINE_GITHUB_API_TOKEN]
  --native-ssh                                          使用本機(基於Go的)SSH實現 [$MACHINE_NATIVE_SSH]
  --bugsnag-api-token                                   用於崩潰報告的BugSnag API令牌 [$MACHINE_BUGSNAG_API_TOKEN]
  --help, -h                                            顯示幫助列表
  --version, -v                                         顯示版本

Commands:
  active                輸出活動狀態的機器
  config                輸出指定機器的連接配置
  create                創建一個機器
  env                   顯示docker客戶端環境設置的命令
  inspect               查看機器相關資訊
  ip                    獲取機器的IP地址
  kill                  殺死一台機器
  ls                    顯示機器列表
  provision             重現提供現有機器
  regenerate-certs      為機器重新生成TLS證書
  restart               重啟機器
  rm                    移除機器
  ssh                   在使用SSH的機器上登錄或運行命令
  scp                   在機器之間複製文件
  mount                 從具有SSHFS的電腦上裝載或卸載目錄
  start                 啟動機器
  status                獲取機器狀態
  stop                  暫停機器
  upgrade               將電腦升級到Docker的最新版本
  url                   獲取機器的URL
  version               顯示Docker Machine版本
  help                  顯示命令的幫組列表

 重點關注創建時相關參數設置:

Options:
--driver, -d "virtualbox"                                                                            Driver to create machine with. [$MACHINE_DRIVER]
--engine-env [--engine-env option --engine-env option]                                               Specify environment variables to set in the engine
--engine-insecure-registry [--engine-insecure-registry option --engine-insecure-registry option]     Specify insecure registries to allow with the created engine
--engine-install-url "//get.docker.com"                                                        Custom URL to use for engine installation [$MACHINE_DOCKER_INSTALL_URL]
--engine-label [--engine-label option --engine-label option]                                         Specify labels for the created engine
--engine-opt [--engine-opt option --engine-opt option]                                               Specify arbitrary flags to include with the created engine in the form flag=value
--engine-registry-mirror [--engine-registry-mirror option --engine-registry-mirror option]           Specify registry mirrors to use [$ENGINE_REGISTRY_MIRROR]
--engine-storage-driver                                                                              Specify a storage driver to use with the engine
--swarm                                                                                              Configure Machine to join a Swarm cluster
--swarm-addr                                                                                         addr to advertise for Swarm (default: detect and use the machine IP)
--swarm-discovery                                                                                    Discovery service to use with Swarm
--swarm-experimental                                                                                 Enable Swarm experimental features
--swarm-host "tcp://0.0.0.0:3376"                                                                    ip/socket to listen on for Swarm master
--swarm-image "swarm:latest"                                                                         Specify Docker image to use for Swarm [$MACHINE_SWARM_IMAGE]
--swarm-join-opt [--swarm-join-opt option --swarm-join-opt option]                                   Define arbitrary flags for Swarm join
--swarm-master                                                                                       Configure Machine to be a Swarm master
--swarm-opt [--swarm-opt option --swarm-opt option]                                                  Define arbitrary flags for Swarm master
--swarm-strategy "spread"                                                                            Define a default scheduling strategy for Swarm
--tls-san [--tls-san option --tls-san option]                                                        Support extra SANs for TLS certs
#####根據driver不同參數不同######
--virtualbox-boot2docker-url The URL of the boot2docker image. Defaults to the latest available version [$VIRTUALBOX_BOOT2DOCKER_URL] --virtualbox-cpu-count "1" number of CPUs for the machine (-1 to use the number of CPUs available) [$VIRTUALBOX_CPU_COUNT] --virtualbox-disk-size "20000" Size of disk for host in MB [$VIRTUALBOX_DISK_SIZE] --virtualbox-host-dns-resolver Use the host DNS resolver [$VIRTUALBOX_HOST_DNS_RESOLVER] --virtualbox-hostonly-cidr "192.168.99.1/24" Specify the Host Only CIDR [$VIRTUALBOX_HOSTONLY_CIDR] --virtualbox-hostonly-nicpromisc "deny" Specify the Host Only Network Adapter Promiscuous Mode [$VIRTUALBOX_HOSTONLY_NIC_PROMISC] --virtualbox-hostonly-nictype "82540EM" Specify the Host Only Network Adapter Type [$VIRTUALBOX_HOSTONLY_NIC_TYPE] --virtualbox-hostonly-no-dhcp Disable the Host Only DHCP Server [$VIRTUALBOX_HOSTONLY_NO_DHCP] --virtualbox-import-boot2docker-vm The name of a Boot2Docker VM to import [$VIRTUALBOX_BOOT2DOCKER_IMPORT_VM] --virtualbox-memory "1024" Size of memory for host in MB [$VIRTUALBOX_MEMORY_SIZE] --virtualbox-nat-nictype "82540EM" Specify the Network Adapter Type [$VIRTUALBOX_NAT_NICTYPE] --virtualbox-no-dns-proxy Disable proxying all DNS requests to the host [$VIRTUALBOX_NO_DNS_PROXY] --virtualbox-no-share Disable the mount of your home directory [$VIRTUALBOX_NO_SHARE] --virtualbox-no-vtx-check Disable checking for the availability of hardware virtualization before the vm is started [$VIRTUALBOX_NO_VTX_CHECK] --virtualbox-share-folder Mount the specified directory instead of the default home location. Format: dir:name [$VIRTUALBOX_SHARE_FOLDER] --virtualbox-ui-type "headless" Specify the UI Type: (gui|sdl|headless|separate) [$VIRTUALBOX_UI_TYPE]

四、參考

  machine官方說明://docs.docker.com/machine/

  hyper-v驅動使用說明://docs.docker.com/machine/drivers/hyper-v/ 

Tags: