德州seo整站优化,石家庄网站制作建设,花都区水务建设管理中心官方网站,wordpress搬家菜单搭建环境向来是一个重复造轮子的过程#xff0c;Docker Machine 则把用户搭建 Docker 环境的各种方案汇集在了一起。笔者在《Docker Machine 简介》一文中演示了使用 Docker Machine 在本地的 vSphere 主机中安装 Docker 环境。但是在云计算大爆炸的今天#xff0c;真正让我们…搭建环境向来是一个重复造轮子的过程Docker Machine 则把用户搭建 Docker 环境的各种方案汇集在了一起。笔者在《Docker Machine 简介》一文中演示了使用 Docker Machine 在本地的 vSphere 主机中安装 Docker 环境。但是在云计算大爆炸的今天真正让我们头疼的可能是五花八门的 IaaS 平台这才是 Docker Machine 真正发挥威力的地方。Docker Machine 把与平台相关的部分封装到了不同的驱动中。只要为某个 IaaS 平台提供了驱动程序Docker Machine 就能够支持该平台上的操作。像 Azure、AWS、GCE、DigitalOcean 等大的厂商早已被支持。本文将以 Azure 为例介绍使用 Docker Machine 在 IaaS 上创建并管理 Docker 虚拟主机。
如果您还不了解 Docker Machine 请先移步笔者的前两篇文章补充相关知识《Docker Machine 简介》、《Docker Machine 详解》。
准备
我们的目标是通过 Docker Machine 在 Azure 上面创建一台安装了 Docker 的虚拟主机。因为 Azure 上的所有资源都必须通过订阅账号才能授权使用所以我们首先得准备一个 Azure 的订阅账号。国内的 Azure 一直在搞一元试用的活动赶快去申请一个吧
Azure 建议我们把资源通过 resource group 组织起来。为了演示方便我们新创建一个名为 nickcontainer 的 resource group 存放将要创建的虚机 此时 resource group 中还没有任何内容。
创建云端虚机
使用 Docker Machine一个 create 命令就能搞定 docker-machine create \--driver azure \--azure-environment AzurePublicCloud \--azure-subscription-id xxxxxxxxxxxxxxxxxxxxxxxxxx \--azure-location East Asia \--azure-size Standard_A0 \--azure-image canonical:UbuntuServer:16.04.0-LTS:latest \--azure-ssh-user nick \--azure-resource-group nickcontainer \--azure-availability-set testvmtiggeras \testvmtigger 使用国内 Azure 的用户请把参数 --azure-environment AzurePublicCloud 修改为 --azure-environment AzureChinaCloud。执行上面的命令首先会验证我们是否有权限访问 Azure 进行操作 这时执行流程停住了上图的输出中说的很明确需要在浏览器中访问 https://aka.ms/devicelogin然后输入一个验证码 填入验证码并继续 在此处输入你的订阅账号和密码就可以进完成身份验证了 此时身份认证过程已经完成可以关掉浏览器了。回到刚才的命令行发现又接着往下执行了。整个过程大概需要几分钟直到输出下面的内容 让我们看看虚机 testvmtigger 的状态 已经处于 Runing 状态连上 Docker daemon 试试 可以看到服务器端的版本是 17.05.0-ce远高于本地客户端的版本。
再让我们回到 Azure 的 portal 上看看 resource group 中新创建了哪些内容 一看吓一跳怎么这么多东西其实玩过 Azure 虚机的同学都知道当我们创建一台虚机的同时会创建这台虚机依赖的所有资源比如存储、虚拟网络、网络安全组、可用性集合、网卡、公有IP地址等等。这里我们只关心两点(上图中的红框框)就足够了第一虚机被成功创建了第二所有资源的区域都在东亚。
经过一轮检查我们可以确定 create 命令很好的完成了任务在 Azure 上创建了虚机并且安装了 Docker 环境。下面我们解释一下 create 命令中主要的几个参数。
参数详解
--driver azuredriver 参数告诉 Docker Machine 我们操作的对象在 Azure 云上需要使用 Azure 相关的接口来进行操作。
--azure-environment AzurePublicCloud其实存在多套相互独立的 Azure 云环境比如国内的。所以需要用这个参数来指定具体的 Azure 云环境。默认值是 AzurePublicCloud指向我们说的 Azure 国际版。连接国内版需要指定为 AzureChinaCloud。
--azure-subscription-id xxxxxxxxxxxxxxxxxxxxxxxxxx这个是与你账号关联的订阅 IDAzure 内部的操作都是依赖于这个 ID 的。
--azure-location East Asia Azure 在全球各地部署了很多的数据中心我们可以通过 location 指定创建的资源所在的位置。这个位置当然是越靠近用户越好国内的国际版用户选择东亚稍微好一点。
--azure-size Standard_A0 Azuer 根据不同的 size(其实就是配置)对虚拟机进行收费demo 中选择的 Standard_A0 大概是这个样子 虽然配置不高但作为 demo 来说已经足够用了。MS 提供了非常丰富的 size 可供选择如果你要创建生产环境的虚机实例可能需要选择每个月几十到几百美金的实例。
--azure-image canonical:UbuntuServer:16.04.0-LTS:latest对于生产环境来说虚机的镜像是至关重要的。Demo 中使用了 ubuntu server 16.04 的镜像当然我们可以在这里指定 Azure 支持的任何虚拟机镜像。这点可比只能使用 boot2docker 的驱动强多了
--azure-ssh-user nick 可以通过 SSH 登录到虚拟机中的用户让我们试一下 直接以用户 nick 登录成功了其实 Docker Machine 已经为这个用户配置了通过秘钥登录的相关信息。
--azure-resource-group nickcontainer新创建的资源所属的 resource group。
清除资源
Docker Machine 不仅可以创建虚机还可以管理虚机。所谓的管理仅仅是能够 stop、start 和 restart 吗答案是可以有更多的功能但是需要相关驱动的支持。比如 rm 命令对于 azure 驱动来说它是可以把刚才创建那一坨东西几乎全部干掉的执行下面的命令
$ docker-machine rm testvmtigger
这是一个很危险的操作所以会有一个确认执行的步骤然后就真的把 Azure 上的资源给干掉了(除了存储部分) 虽然笔者觉得这真的是一个很强很酷的功能但还是要警告自己和同学们一定要慎用
总结
云服务为我们打开了一扇新的大门当然对运维人员来说也带来了诸多的挑战。如何选择对云端操作友好的工具就成了我们提升效率的重要途径。就 Docker 操作来说Docker Machine 在这个方向上做了很好的尝试。真心的希望这个工具能够不断的完善成为运维人员手中的一把利剑。 相关文章
Docker Machine 简介容器,Docker和Azure Container Service基于VS2017的Docker Support体检ASP.NET Core站点的Docker部署Docker-Compose 一键部署Ningx.Net CoreRedis集群
原文地址http://www.cnblogs.com/sparkdev/p/7077333.html .NET社区新闻深度好文微信中搜索dotNET跨平台或扫描二维码关注