用docker-machine建立虛擬主機來對節點主機管理時,咱們給定虛擬主機的名稱docker-machine會把該名稱看成主機名,把節點主機的主機名更改成咱們指定的名稱;從上面的信息能夠看到docker-node01這臺主機上有nginx鏡像和n1容器;這說明咱們剛纔的操做都是發送給docker-node01上了;從上面的演示能夠看到,咱們在docker-machine上切換環境,當前shell並不能反映咱們是否切換到對應的環境了;這樣一來在主機特別多的狀況,很容易出錯;接下來咱們配置當前shell的PS1的環境變量;html
前文咱們聊了下docker容器的資源限制,回顧請參考http://www.javashuo.com/article/p-mowhfarc-nt.html;今天咱們來聊一聊docker machine;docker machine是docker 官方提供的工具,這個工具能夠在不一樣主機/不一樣系統上快速安裝、管理docker環境;docker machine 的實現原理就是經過不一樣的驅動來鏈接不一樣類型節點,來實現docker machine管理不一樣平臺上的docker環境;node
docker machine 安裝linux
一、下載二進制程序文件到本地nginx
[root@node1 ~]# 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 % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 100 638 100 638 0 0 590 0 0:00:01 0:00:01 --:--:-- 590 100 26.8M 100 26.8M 0 0 11911 0 0:39:24 0:39:24 --:--:-- 16907 [root@node1 ~]# ll /usr/local/bin/docker-machine -rwxr-xr-x 1 root root 28164576 Jun 18 11:28 /usr/local/bin/docker-machine [root@node1 ~]# docker-machine version docker-machine version 0.16.0, build 702c267f [root@node1 ~]#
提示:以上命令主要就作了三件事,下載對應系統的對應系統架構的docker-machine到本地/tmp/下,並保存爲docker-machine;而後把/tmp/docker-machine移動至/usr/local/bin/下,而後給/usr/local/bin/docker-machine添加執行權限;若是下載完咱們能夠在終端運行docker-machine version 可以看到對應的版本信息,就表示docker-machine安裝好了;docker-machine程序是安裝好了,如今咱們還不能直接使用;咱們上面說過docker-machine本質就是經過不一樣的驅動去鏈接節點,鏈接節點實際上就是經過ssh鏈到節點服務器上,而後執行安裝docker;因此爲了可以很好的使用docker-machine 咱們須要對管理的節點作免密登陸;git
二、管理節點對work節點作免密登陸github
[root@node1 ~]# ssh-keygen Generating public/private rsa key pair. Enter file in which to save the key (/root/.ssh/id_rsa): /root/.ssh/id_rsa already exists. Overwrite (y/n)? y Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /root/.ssh/id_rsa. Your public key has been saved in /root/.ssh/id_rsa.pub. The key fingerprint is: SHA256:4HrdVnoO+W/+J/ewP4A1m8HnneKWAKMKo3Ad2uExJ1k root@node1 The key's randomart image is: +---[RSA 2048]----+ | | | E | | o. . | | B... o = . | | = B. S o + B o| |. oo+. o . * = o.| |... + o . * + = | | . o . = +o+o| | +++=B| +----[SHA256]-----+ [root@node1 ~]# ssh-copy-id root@192.168.0.42 /usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub" The authenticity of host '192.168.0.42 (192.168.0.42)' can't be established. ECDSA key fingerprint is SHA256:EG9nua4JJuUeofheXlgQeL9hX5H53JynOqf2vf53mII. ECDSA key fingerprint is MD5:57:83:e6:46:2c:4b:bb:33:13:56:17:f7:fd:76:71:cc. Are you sure you want to continue connecting (yes/no)? yes /usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed /usr/bin/ssh-copy-id: INFO: 1 key(s) remain to be installed -- if you are prompted now it is to install the new keys root@192.168.0.42's password: Number of key(s) added: 1 Now try logging into the machine, with: "ssh 'root@192.168.0.42'" and check to make sure that only the key(s) you wanted were added. [root@node1 ~]# ssh-copy-id root@192.168.0.43 /usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub" The authenticity of host '192.168.0.43 (192.168.0.43)' can't be established. ECDSA key fingerprint is SHA256:EG9nua4JJuUeofheXlgQeL9hX5H53JynOqf2vf53mII. ECDSA key fingerprint is MD5:57:83:e6:46:2c:4b:bb:33:13:56:17:f7:fd:76:71:cc. Are you sure you want to continue connecting (yes/no)? yes /usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed /usr/bin/ssh-copy-id: INFO: 1 key(s) remain to be installed -- if you are prompted now it is to install the new keys root@192.168.0.43's password: Number of key(s) added: 1 Now try logging into the machine, with: "ssh 'root@192.168.0.43'" and check to make sure that only the key(s) you wanted were added. [root@node1 ~]
提示:有關免密登陸的詳細說明能夠參考本人博客http://www.javashuo.com/article/p-rjibahxc-bk.html;接下來咱們就可使用docker-machine來對節點主機進行操做了;docker
對節點主機安裝docker環境shell
提示:以上命令表示建立一個docker-machine主機,使用generic驅動,generic表示對linux主機,若是是windows須要用到--virtualbox;--generic-ip-address表示指定節點主機的ip地址;而後在給上一名稱;從上面的信息能夠看到,docker-node01這臺machine已經啓動,它告訴咱們要查看怎麼鏈接docker-node01這臺虛擬主機,請運行docker-machine env docker-node01 查看;json
查看怎麼鏈接docker-node01這臺虛擬主機windows
提示:它告訴咱們運行下面的命令能夠配置咱們的shell
提示:從上面的信息能夠看到咱們運行 eval $(docker-machine env docker-node01)這條命令就表示把環境切換到docker-node01上;接下來的操做都會發送到docker node01上;
提示:從上面的信息能夠看到,當咱們使用eval $(docker-machine env docker-node01)把當前環境切換到docker-node01後,在當前終端運行的容器和下載的鏡像,在退出當前終端從新登陸後,本地的是沒有nginx鏡像的;這意味着咱們切換環境後,運行容器的操做上發送給docker-node01上執行了;
測試:咱們登陸到docker-node01看看是否有nginx鏡像和n1容器?
提示:用docker-machine建立虛擬主機來對節點主機管理時,咱們給定虛擬主機的名稱docker-machine會把該名稱看成主機名,把節點主機的主機名更改成咱們指定的名稱;從上面的信息能夠看到docker-node01這臺主機上有nginx鏡像和n1容器;這說明咱們剛纔的操做都是發送給docker-node01上了;從上面的演示能夠看到,咱們在docker-machine上切換環境,當前shell並不能反映咱們是否切換到對應的環境了;這樣一來在主機特別多的狀況,很容易出錯;接下來咱們配置當前shell的PS1的環境變量;
下載docker-machine-wrapper.bash、docker-machine-prompt.bash和docker-machine.bash
[root@node01 ~]# cat /etc/bash_completion.d/down.bash base=https://raw.githubusercontent.com/docker/machine/v0.16.0 for i in docker-machine-prompt.bash docker-machine-wrapper.bash docker-machine.bash do sudo wget "$base/contrib/completion/bash/${i}" -P /etc/bash_completion.d done [root@node01 ~]#
提示:以上腳本主要是循環下載上面說的三個腳本;執行該腳本直接有source命令便可;
提示:咱們用source命令來執行上面的腳本,提示咱們鏈接拒絕;這是由於沒有解析到raw.githubusercontent.com的地址形成的;解決辦法在/etc/hosts文件中介入raw.githubusercontent.com的解析地址便可;https://site.ip138.com/raw.githubusercontent.com/;這個網站能夠查詢到raw.githubusercontent.com的地址;
提示:更改/etc/hosts文件後,接下在用source命令執行上面的腳本就不會提示咱們連接拒絕了;
提示:能夠看到/etc/bash_completion.d/目錄下有咱們要的腳本了;接下來咱們就須要配置當前用戶的PS1環境的值;
提示:以上信息表示導入上面的三個腳本到當前登陸用戶的終端;配置好以上.bashrc後,咱們在來切換環境,當前shell就不同了;
提示:導入了docker-machine-wrapper.bash、docker-machine-prompt.bash和docker-machine.bash這三個腳本配合如今新定義的PS1變量,咱們切換環境就很容易的辨識,咱們操做的node節點主機是那一臺;退出當前環境,直接使用exit便可;
到此docker-machine的環境就搭建好了;接下咱們再來講說docker-machine的經常使用命令使用和說明
docker-machine active:查看當前激活狀態的docker主機
[root@node01 ~]# docker-machine active docker-node01 [root@node01 ~]#
提示:所謂激活狀態的docker主機就是指的當前的DOCKER_HOST環境變量所指向的主機;
docker-machine ls:列出全部管理的主機
[root@node01 ~]# docker-machine ls NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS docker-node01 * generic Running tcp://192.168.0.42:2376 v19.03.11 docker-node02 - generic Running tcp://192.168.0.43:2376 v19.03.11 [root@node01 ~]#
docker-machine config:查看激活的docker主機的鏈接信息;
[root@node01 ~]# docker-machine config docker-node01 --tlsverify --tlscacert="/root/.docker/machine/machines/docker-node01/ca.pem" --tlscert="/root/.docker/machine/machines/docker-node01/cert.pem" --tlskey="/root/.docker/machine/machines/docker-node01/key.pem" -H=tcp://192.168.0.42:2376 [root@node01 ~]#
docker-machine inspect :以json格式輸出指定docker主機的詳細信息
[root@node01 ~]# docker-machine inspect docker-node01 { "ConfigVersion": 3, "Driver": { "IPAddress": "192.168.0.42", "MachineName": "docker-node01", "SSHUser": "root", "SSHPort": 22, "SSHKeyPath": "", "StorePath": "/root/.docker/machine", "SwarmMaster": false, "SwarmHost": "", "SwarmDiscovery": "", "EnginePort": 2376, "SSHKey": "" }, "DriverName": "generic", "HostOptions": { "Driver": "", "Memory": 0, "Disk": 0, "EngineOptions": { "ArbitraryFlags": [], "Dns": null, "GraphDir": "", "Env": [], "Ipv6": false, "InsecureRegistry": [], "Labels": [], "LogLevel": "", "StorageDriver": "", "SelinuxEnabled": false, "TlsVerify": true, "RegistryMirror": [], "InstallURL": "https://get.docker.com" }, "SwarmOptions": { "IsSwarm": false, "Address": "", "Discovery": "", "Agent": false, "Master": false, "Host": "tcp://0.0.0.0:3376", "Image": "swarm:latest", "Strategy": "spread", "Heartbeat": 0, "Overcommit": 0, "ArbitraryFlags": [], "ArbitraryJoinFlags": [], "Env": null, "IsExperimental": false }, "AuthOptions": { "CertDir": "/root/.docker/machine/certs", "CaCertPath": "/root/.docker/machine/certs/ca.pem", "CaPrivateKeyPath": "/root/.docker/machine/certs/ca-key.pem", "CaCertRemotePath": "", "ServerCertPath": "/root/.docker/machine/machines/docker-node01/server.pem", "ServerKeyPath": "/root/.docker/machine/machines/docker-node01/server-key.pem", "ClientKeyPath": "/root/.docker/machine/certs/key.pem", "ServerCertRemotePath": "", "ServerKeyRemotePath": "", "ClientCertPath": "/root/.docker/machine/certs/cert.pem", "ServerCertSANs": [], "StorePath": "/root/.docker/machine/machines/docker-node01" } }, "Name": "docker-node01" } [root@node01 ~]#
提示:以上命令也支持-f選項來指定格式,用法同docker image/container inspect 相似;
[root@node01 ~]# docker-machine inspect -f {{.HostOptions.AuthOptions.StorePath}} docker-node01 /root/.docker/machine/machines/docker-node01 [root@node01 ~]# docker-machine inspect -f {{.DriverName}} docker-node01 generic [root@node01 ~]#
docker-machine ip :獲取指定docker主機的ip地址
[root@node01 ~]# docker-machine ip docker-node01 192.168.0.42 [root@node01 ~]# docker-machine ip docker-node02 192.168.0.43 [root@node01 ~]#
docker-machine ssh :鏈接指定docker執行命令
[root@node01 ~]# docker-machine ssh docker-node01 "ip a" 1: lo:mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 inet 127.0.0.1/8 scope host lo valid_lft forever preferred_lft forever inet6 ::1/128 scope host valid_lft forever preferred_lft forever 2: ens33:mtu 1500 qdisc pfifo_fast state UP group default qlen 1000 link/ether 00:0c:29:91:99:30 brd ff:ff:ff:ff:ff:ff inet 192.168.0.42/24 brd 192.168.0.255 scope global ens33 valid_lft forever preferred_lft forever inet6 fe80::20c:29ff:fe91:9930/64 scope link valid_lft forever preferred_lft forever 4: docker0:mtu 1500 qdisc noqueue state DOWN group default link/ether 02:42:0f:e1:e0:f7 brd ff:ff:ff:ff:ff:ff inet 172.17.0.1/16 brd 172.17.255.255 scope global docker0 valid_lft forever preferred_lft forever inet6 fe80::42:fff:fee1:e0f7/64 scope link valid_lft forever preferred_lft forever [root@node01 ~]#
docker-machine scp:在docker主機間以及docker主機和本地之間經過scp命令來遠程複製文件
[root@node01 ~]# echo "this is test file" > /tmp/test.txt [root@node01 ~]# cat /tmp/test.txt this is test file [root@node01 ~]# docker-machine scp /tmp/test.txt docker-node01:/root/ test.txt 100% 18 5.4KB/s 00:00 [root@node01 ~]# docker-machine ssh docker-node01 "ls -l /root/" total 4 -rw-r--r-- 1 root root 18 Jun 19 11:26 test.txt [root@node01 ~]# docker-machine ssh docker-node01 "cat /root/test.txt" this is test file [root@node01 ~]#
提示:同scp命令用法相似;
docker-machine rm:刪除指定名稱的docker主機對應的虛擬主機;
[root@node01 ~]# docker-machine ls NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS docker-node01 * generic Running tcp://192.168.0.42:2376 v19.03.11 docker-node02 - generic Running tcp://192.168.0.43:2376 v19.03.11 [root@node01 ~]# docker-machine rm docker-node02 About to remove docker-node02 WARNING: This action will delete both local reference and remote instance. Are you sure? (y/n): y Successfully removed docker-node02 [root@node01 ~]# docker-machine ls NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS docker-node01 * generic Running tcp://192.168.0.42:2376 v19.03.11 [root@node01 ~]#
提示:docker-machine rm 只是刪除docker-machine上的虛擬主機,對於真正的物理節點上的docker環境並無刪除;實際上就切斷對指定docker主機的管控;
docker-machine upgrade:將指定主機的docker版本更新爲最新
[root@node01 ~]# docker-machine upgrade docker-node01 Waiting for SSH to be available... Detecting the provisioner... Upgrading docker... Restarting docker... [root@node01 ~]# docker-machine ls NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS docker-node01 * generic Running tcp://192.168.0.42:2376 v19.03.11 [root@node01 ~]#
提示:若是指定docker主機的版本已是最新的版本,那麼它將不會再更新;
docker-machine url:獲取指定主機監聽URL
[root@node01 ~]# docker-machine url docker-node01 tcp://192.168.0.42:2376 [root@node01 ~]#
提示:經過docker-machine安裝的docker環境,實際上就是把yum安裝的docker環境,客戶端和服務端分離了,各個節點就是各個服務端,而docker-machine就是同一的客戶端,由於客戶端和服務端再也不同一主機,因此它會把docker監聽在一個TCP端口上,方便客戶端的來鏈接管理;