DOCKER 学习笔记7 Docker Machine 建立虚拟机实战,以及错误总结
前言
通过以上6小节的学习,已经可以使用DOCKER 熟练的部署应用程序了。大家都可以发现使用 DOCKER 带来的方便之处,因为现在的话,只是在一台服务器上部署,这样部署,我们只需要一条命令,需要的NGINX MYSQL 等服务全部启动,而不是按照传统部署方式:
- 安装JDK 配置环境变量
- 安装MYSQL 启动服务
- 安装NGINX 配置文件
- 启动调试 。。。。
要是还有一台机器需要部署呢?你是不是也得按照这个顺序再来一遍,这也太麻烦了。
本节要学习的内容是DOCKER 三剑客第二 Docker Machine
Docker Machine
Docker Machine 是一个工具,可以让您在虚拟主机上安装 Docker Engine,并使用 Docker-Machine 命令管理主机。 你可以使用 Machine 在你本地的 Mac 或 Windows 机顶盒上,在你的公司网络上,在你的数据中心上,或者在像 Azure,AWS,DigitalOcean 这样的云提供商上创建 Docker 主机。
Docker Machine 使您能够在各种版本的 Linux 上提供多个远程 Docker 主机。
举个栗子
我们都使用过虚拟机 VM VirtualBOX 当然,我们在使用VM 的时候,就是在本机上建立了许多个虚拟机,可以运行好几个Centos,使用VM 来管理这些虚拟机的开机/关机/重启 等操作。
所以,现在的 Machine 就充当了这个虚拟机管理的身份。可以用它来创建多个虚拟主机,并安装 Docker Engine
我们可以使用这个 Machine 来管理这些虚拟机上面的 Docker Engine.
Docker Engine 与 Docker Machine 区别
Docker Engine
通常,我们说 Docker 的时候指的是 Docker Engine
如下面这张图一样,Docker Engine 是运行在 Linux 上的应用
- 包含服务守护进程 daemon server
- 与守护进程交互的 RestAPI
- 我们平时输入
docker run
的命令行 CLI
Docker Machine
Docker Machine 是一个用于配置和管理 Dockerized 主机(上面有 Docker Engine 的主机)的工具。
开始安装
Linux 版本
首先安装Docker Engine
## 从github 拉取最新版本 (下载特慢,推荐迅雷复制下载地址后,上传服务器)
curl -L https://github.com/docker/machine/releases/download/v0.16.2/docker-machine-`uname -s`-`uname -m` > /usr/local/bin/docker-machine
## 迅雷下载地址 (Linux/X86_64)搞清楚自己的服务器架构
https://github.com/docker/machine/releases/download/v0.16.2/docker-machine-Linux-x86_64
## 赋予读取权限
chmod +x /usr/local/bin/docker-machine
## 检查安装信息
docker-machine version
使用Docker Machine 创建虚拟主机
docker-machine create --driver xxx name
创建虚拟主机
[root@mrclinux ~]# docker-machine create --driver virtualbox default
Running pre-create checks...
Error with pre-create check: "VBoxManage not found. Make sure VirtualBox is installed and VBoxManage is in the path"
注意!!!!
因为现在我用的服务器是阿里云ECS 共享型,所以这已经是一个虚拟机,VM是不支持虚拟机嵌套虚拟机的。所以,直接到后面看,通过配置阿里云驱动后使用docker-machine 创建和购买实例。
安装VM 也无济于事!!!!
[root@mrclinux ~]# docker-machine create --driver virtualbox default
Running pre-create checks...
Error with pre-create check: "This computer doesn't have VT-X/AMD-v enabled. Enabling it in the BIOS is mandatory"
使用 aliyun 驱动
通过配置aliyun 的驱动,可以方便的创建阿里云实例,而不是创建虚拟机,其实要是在阿里云服务器创建虚拟机也不现实,毕竟内存就那么大,而且,还没有对应的IP分配给虚拟机。
GITHUB https://github.com/AliyunContainerService/docker-machine-driver-aliyunecs
## 下载驱动
curl -O https://docker-machine-aliyunecs-drivers.oss-cn-beijing.aliyuncs.com/docker-machine-driver-aliyunecs_linux-amd64.tgz
## 解压
tar -zxvf docker-machine-driver-aliyunecs_linux-amd64.tgz
## 复制到可执行目录下
cp bin/docker-machine-driver-aliyunecs.linux-amd64 /usr/local/bin/docker-machine-driver-aliyunecs
配置环境变量
## 打开环境变量文件
vi ~/.bashrc
## 加入以下内容(需要改变的地方我会说)
export ECS_ACCESS_KEY_ID='填你自己key id'
export ECS_ACCESS_KEY_SECRET='填你自己的key secret'
# 购买的镜像是1核0.5G内存的最小型实例
export ECS_INSTANCE_TYPE='ecs.t5-lc2m1.nano'
# 来个50M宽带
export ECS_INTERNET_MAX_BANDWIDTH='50'
# 购买的区域是石家庄
export ECS_REGION='cn-zhangjiakou'
# 设置的密码,一定要8~30位,有大小写字母,数字和乱七八糟的标点,不然会自动创建失败
export ECS_SSH_PASSWORD='7b6424B61c6C21~0%39F1C56'
# 磁盘只要20G
export ECS_SYSTEM_DISK_SIZE='20'
# 磁盘用便宜的高效云盘吧,任性选SSD也行
export ECS_SYSTEM_DISK_CATEGORY='cloud_efficiency'
# 选择的镜像是Ubuntu16.04
export ECS_IMAGE_ID='ubuntu_16_0402_64_20G_alibase_20180409.vhd'
# 专用网络的节点
export ECS_VPC_ID='vpc-8vbhii32tpugfcqbryqcn'
# 虚拟交换机的节点
export ECS_VSWITCH_ID='vsw-8vbweep4xrtamazp50775'
# ECS的标签
export ECS_TAGS='chen_docker'
# 安全组
export ECS_SECURITY_GROUP='sg-8vb5wwel08nyrih2lmtb'
# 石家庄a区
export ECS_ZONE='cn-zhangjiakou-a'
# 一定要是true
export ECS_IO_OPTIMIZED='true'
# Using mirrors from Aliyun
export MACHINE_DOCKER_INSTALL_URL=http://kubernetes.oss-cn-hangzhou.aliyuncs.com/docker_install.sh
export ENGINE_REGISTRY_MIRROR=https://registry.docker-cn.com
参考: https://blog.csdn.net/diyiday/article/details/93899190
配置说明
-
ECS_IMAGE_ID 镜像ID怎么选?
找到控制台,镜像列表,复制你想要的镜像即可。 -
ECS_REGION 购买区域 ?
这个若没有要求则就不需要配置,若已经有服务器在指定的区域,那就配置,比如杭州就是cn-hangzhou
这个时候注意观察地址栏的编号:https://ecs-buy.aliyun.com/wizard?/postpay/cn-hangzhou
-
ECS_VPC_ID 专用网络节点 ?
要是已经有你已经买了服务器,就可以看到这些信息,就复制填写一样的,没有则不用配置这一个
创建一个实例
注意:需要账户余额大于100 不然创建不成功!!!!
docker-machine create -d aliyunecs <name>
[root@mrclinux ~]# docker-machine create -d aliyunecs mrctest
Running pre-create checks...
Creating machine...
(mrctest) mrctest | Creating key pair for instance ...
(mrctest) mrctest | Configuring security groups instance ...
(mrctest) mrctest | Creating instance with image centos_7_06_64_20G_alibase_20190711.vhd ...
(mrctest) mrctest | Create instance i-xxxxxxxx successfully
(mrctest) mrctest | Allocating Eip address for instance i-xxxxxxxx ...
(mrctest) mrctest | Associating Eip address eip-bp1hc5mty4iz4dnlb3o9b for instance i-xxxxxxxx ...
(mrctest) mrctest | Starting instance i-xxxxxxxx ...
(mrctest) mrctest | Start instance i-xxxxxxxx successfully
(mrctest) mrctest | Waiting SSH service xxxxxxxx is ready to connect ...
(mrctest) mrctest | Uploading SSH keypair to xxxxxxxx ...
(mrctest) mrctest | Created instance i-xxxxxxxx successfully with public IP address xxxxxxxx and private IP address xxxxxxxx
Waiting for machine to be running, this may take a few minutes...
Detecting operating system of created instance...
Waiting for SSH to be available...
Detecting the provisioner...
Provisioning with centos...
Copying certs to the local machine directory...
Copying certs to the remote machine...
Setting Docker configuration on the remote daemon...
Checking connection to Docker...
Docker is up and running!
To see how to connect your Docker Client to the Docker Engine running on this virtual machine, run: docker-machine env mrctest
查看实例列表
docker-machine ls
[root@mrclinux ~]# docker-machine ls
NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS
mrctest - aliyunecs Running tcp://xxx.xxx.xxx.199:2376 v19.03.5
连接使用实例
docker-machine ssh name
通过 SSH 连接后,这就和一个普通的主机没有什么区别了。
[root@mrclinux ~]# docker-machine ssh mrctest
Last login: Tue Feb 11 18:06:17 2020 from xxxxxxxx
Welcome to Alibaba Cloud Elastic Compute Service !
[root@mrctest ~]# docker version
Client: Docker Engine - Community
Version: 19.03.5
API version: 1.40
Go version: go1.12.12
Git commit: 633a0ea
Built: Wed Nov 13 07:25:41 2019
OS/Arch: linux/amd64
Experimental: false
Server: Docker Engine - Community
Engine:
Version: 19.03.5
API version: 1.40 (minimum version 1.12)
Go version: go1.12.12
Git commit: 633a0ea
Built: Wed Nov 13 07:24:18 2019
OS/Arch: linux/amd64
Experimental: false
containerd:
Version: 1.2.10
GitCommit: b34a5c8af56e510852c35414db4c1f4fa6172339
runc:
Version: 1.0.0-rc8+dev
GitCommit: 3e425f80a8c931f88e6d94a8c831b9d5aa481657
docker-init:
Version: 0.18.0
GitCommit: fec3683
[root@mrctest ~]# exit
logout
实例销毁
docker-machine rm <name>
[root@mrclinux ~]# docker-machine rm mrctest
About to remove mrctest
WARNING: This action will delete both local reference and remote instance.
Are you sure? (y/n): y
(mrctest) mrctest | Remove instance i-bp15uqp37s1r2ei0f5z5 ...
(mrctest) mrctest | Deleting instance: i-bp15uqp37s1r2ei0f5z5
Successfully removed mrctest
WINDOWS 10 版本
安装了 docker-toolbox 后 默认带有 docker-machine
开始部署
这里遇到的问题是:部署虚拟主机我这台电脑已经启动了Hyper-V (之前安装的是docker for windows)而 virtualbox 与 Hyper-v是不能同时运行的,所以,这里有两个解决方法:
- 禁用掉 hyperv 使用virtualbox
- 直接使用 hyperv
使用 virtualbox (推荐)
hyperv 会在创建虚拟机时候存在大量问题,不推荐使用。若遇到这个问题,请参考 https://blogs.chaobei.xyz/archives/docker6 将docker for windows 换成 docker-toolbox
以下是我的采坑尝试
virtualbox 需要安装 Orcle VM Virtual BOX
PS C:\Users\17639> docker-machine create -d virtualbox vm
Running pre-create checks...
Error with pre-create check: "This computer is running Hyper-V. VirtualBox won't boot a 64bits VM when Hyper-V is activated. Either use Hyper-V as a driver, or disable the Hyper-V hypervisor. (To skip this check, use --virtualbox-no-vtx-check)"
下载boot2docker 镜像
下载这个镜像的目的是:提高首次构建的速度。下载后移动到此位置。
使用 hyperv (不推荐)
这儿坑太多了。
错误总结
PS C:\Users\17639> docker-machine create -d virtualbox --virtualbox-no-vtx-check vm
Running pre-create checks...
Creating machine...
(vm) Copying C:\Users\17639\.docker\machine\cache\boot2docker.iso to C:\Users\17639\.docker\machine\machines\vm\boot2docker.iso...
(vm) Creating VirtualBox VM...
(vm) Creating SSH key...
(vm) Starting the VM...
(vm) Check network to re-create if needed...
(vm) Windows might ask for the permission to create a network adapter. Sometimes, such confirmation window is minimized in the taskbar.
(vm) Found a new host-only adapter: "VirtualBox Host-Only Ethernet Adapter #2"
(vm) Windows might ask for the permission to configure a network adapter. Sometimes, such confirmation window is minimized in the taskbar.
(vm) Windows might ask for the permission to configure a dhcp server. Sometimes, such confirmation window is minimized in the taskbar.
Error creating machine: Error in driver during machine creation: Unable to start the VM: C:\Program Files\Oracle\VirtualBox\VBoxManage.exe startvm vm --type headless failed:
VBoxManage.exe: error: Call to WHvSetupPartition failed: ERROR_SUCCESS (Last=0xc000000d/87) (VERR_NEM_VM_CREATE_FAILED)
VBoxManage.exe: error: Details: code E_FAIL (0x80004005), component ConsoleWrap, interface IConsole
Details: 00:00:01.538449 Power up failed (vrc=VERR_NEM_VM_CREATE_FAILED, rc=E_FAIL (0X80004005))
这个是因为我使用了virtualbox 而没有禁用掉hyperv 所导致的结果
PS C:\WINDOWS\system32> docker-machine create --driver hyperv vm
Running pre-create checks...
Error with pre-create check: "no External vswitch found. A valid vswitch must be available for this command to run. Check https://docs.docker.com/machine/drivers/hyper-v/"
这里的意思是没有配置hyperv 虚拟网卡导致的!!! 这儿存在太多问题,不建议使用hyperv 请使用 docker-toolbox
小结
通过本次学习,可以学习到如何在阿里云通过 docker-machine 进行ECS的实例化以及部署DOCKER 过来使用,以及今后在本地进行DOCKER 的集群搭建的时候,要学会使用虚拟机,毕竟我们手头没有那么多主机嘛。