使用 Chef 自动执行 Azure 虚拟机部署
Chef 是一个强大的工具,用于提供自动化和所需的状态配置。
使用我们的最新 cloud-api 版本,Chef 提供了与 Azure 的无缝集成,使得你能够通过单个命令设置和部署配置状态。
在本文中,我将向你展示如何设置你的 Chef 环境来设置 Azure 虚拟机,并引导你完成创建一个策略或“食谱”并将此指南部署到 Azure VM 的过程。
让我们开始吧!
Chef 基础知识
在开始之前,建议你首先熟悉一下 Chef 的基本概念。此处有大量资料,建议你在尝试此演练之前快速阅读一下。不过,在我们开始之前,我会扼要重述一下基础知识。
下图描绘了概要的 Chef 体系结构。

Chef 有三个主要的体系结构组件。Chef 服务器、Chef 客户端(节点)和 Chef 工作站。
Chef 服务器是我们的管理点,对于 Chef 服务器有两种选择:托管解决方案和本地解决方案。我们将使用托管解决方案。
Chef 客户端(节点)是位于你在管理的服务器上的代理。
Chef 工作站是我们的管理工作站,我们将在其中创建策略并执行管理命令。我们从 Chef 工作站运行“knife”命令来管理我们的基础结构。
我们还引入了“食谱”和“配方”的概念。它们实际上是我们定义并应用于我们的服务器的策略。
准备工作站
首先,让我们准备工作站。我使用的是标准 Windows 工作站。我们需要创建一个目录来存储我们的配置文件和食谱。
首先,创建一个名为 C:\chef 的目录。
然后,创建另一个目录 c:\chef\cookbooks
现在,我们需要下载 Azure 设置文件,以便 Chef 可以与我们的 Azure 订阅进行通信。
从此处下载你的发布设置:https://manage.windowsazure.cn/publishsettings/
将发布设置文件保存到 C:\chef 中
创建托管的 Chef 帐户
注册托管的 Chef 帐户:https://manage.chef.io/signup
在注册过程中,会要求你创建一个新组织。

在创建你的组织后,下载初学者工具包。

注意:如果你收到提示,警告你将重置你的密钥,可以继续操作,因为我们尚未配置现有基础结构。
此初学者工具包 zip 文件包含你的组织的配置文件和密钥。
配置 Chef 工作站
将 chef-starter.zip 的内容提取到 C:\chef
将 chef-starter\chef-repo.chef 下的所有文件都复制到 c:\chef 中
你的目录现在看起来应当与下图类似:

你现在应当有 4 个文件,包括位于根目录 c:\chef 中的 Azure 发布文件
PEM 文件包含你的组织和用于通信的管理私钥,而 knife.rb 文件包含你的 knife 配置。你将需要编辑 knife.rb 文件。
在你选择的编辑器中打开该文件并修改“cookbook_path”:从路径中删除 /../,使其如下所示:
cookbook_path ["#{current_dir}/cookbooks"]
另外,请添加以下行以反映你的 Azure 发布设置文件的名称。
knife[:azure_publish_settings_file] = "yourfilename.publishsettings"
你的 knife.rb 文件现在看起来应当如下所示:

这些行将确保 Knife 在执行 Azure 操作期间引用 c:\chef\cookbooks 下的 cookbooks 目录并且还使用我们的 Azure 发布设置文件。
安装 Chef 开发工具包
接下来,下载并安装 ChefDK(Chef 开发工具包)来设置你的 Chef 工作站。
http://downloads.getchef.com/chef-dk/windows

这简单明了。让其安装在默认位置 c:\opscode 中。此安装将花费大约 10 分钟时间。
确认你的 PATH 变量包含以下条目:C:\opscode\chefdk\bin;C:\opscode\chefdk\embedded\bin;c:\users\yourusername.chefdk\gem\ruby\2.0.0\bin
如果未包含,请务必添加这些路径!
请注意,该路径的顺序非常重要! 如果你的 opscode 路径未采用正确的顺序,你将会遇到问题。
在继续操作之前重新启动你的工作站。
接下来,我们将安装 Knife Azure 扩展。这将为 Knife 提供“Azure 插件”。
运行以下命令:
chef gem install knife-azure ––pre
注意:–pre 参数确保你收到 knife azure 插件的最新 RC 版本,该版本提供对最新 API 集的访问。
同时,可能还会安装许多依赖项。

若要确保所有项都已正确配置,请运行:
knife azure image list
如果所有项都已正确配置,你会看到可用 Azure 映像的列表滚动显示。
祝贺你。工作站已设置!
创建食谱
食谱由 Chef 用来定义你希望在托管客户端上执行的一组命令。创建食谱简单明了,我们将使用命令 chef generate cookbook 来生成我们的食谱模板。我将像自动部署 IIS 的策略一样调用我的食谱 Web 服务器。
在 C:\Chef 目录下运行以下命令:
chef generate cookbook webserver
这将在 C:\Chef\cookbooks\webserver 目录下生成一组文件。 现在,我们需要定义我们希望 Chef 客户端在托管 VM 上执行的一组命令。
这些命令存储在文件 default.rb 中。 在此文件中,我将定义一组命令来安装 IIS、启动 IIS 并将模板文件复制到 wwwroot 文件夹中。
修改 C:\chef\cookbooks\webserver\recipes\default.rb 并添加以下行:
powershell_script 'Install IIS' do
action :run
code 'add-windowsfeature Web-Server'
end
service 'w3svc' do
action [ :enable, :start ]
end
template 'c:\inetpub\wwwroot\Default.htm' do
source 'Default.htm.erb'
rights :read, 'Everyone'
end
在完成后,保存该文件。
创建模板
如上文提到的那样,我们需要生成一个模板文件,该文件将用作我们的 default.html 页面。
执行以下命令来生成模板:
chef generate template webserver Default.htm
现在导航到文件 C:\chef\cookbooks\webserver\templates\default\Default.htm.erb 并编辑该文件。
添加一些简单的“Hello World”html 代码并保存该文件。
将食谱上载到 Chef 服务器
在此步骤中,我们将制作我们已在本地计算机上创建的食谱的副本并将其上载到 Chef 托管服务器。上载完成后,食谱将显示在“策略”选项卡下。
knife cookbook upload webserver

使用 Knife Azure 部署虚拟机
现在,我们将部署 Azure 虚拟机并应用“Webserver”食谱,该食谱将安装我们的 IIS Web 服务和默认网页。
若要执行此操作,请使用 knife azure server create 命令。
下面是该命令的示例:
knife azure server create --azure-dns-name 'diegotest01' --azure-vm-name 'testserver01' --azure-vm-size 'Small' --azure-storage-account 'portalvhdsxxxx' --bootstrap-protocol 'cloud-api' --azure-source-image 'a699494373c04fc0bc8f2bb1389d6106__Windows-Server-2012-Datacenter-201411.01-en.us-127GB.vhd' --azure-service-location 'China North' --winrm-user azureuser --winrm-password 'myPassword123' --tcp-endpoints 80,3389 --r 'recipe[webserver]'
各个参数不言自明。替换你的特定变量并运行。
注意:通过命令行,我还通过使用 –tcp-endpoints 参数自动执行终结点网络筛选器规则。我已打开端口 80 和 3389 来提供对我的网页和 RDP 会话的访问。
在运行该命令后,访问 Azure 经典管理门户,你会看到你的计算机已开始设置。

返回到命令提示符:

在部署完成后,我们应当能够通过端口 80 连接到 web 服务,因为我们在通过 knife azure 命令设置 VM 时已打开了该端口。因为此 VM 是我的云服务中的唯一 VM,所以我将使用云服务 URL 来连接它。

如你所见,我的 html 代码富有创造性:)
不要忘记,我们还可以从 Azure 经典管理门户使用端口 3389 通过 RDP 会话进行连接。
希望这对你有所帮助! 现在就使用 Azure 开始你的基础结构即代码之旅吧!
立即访问http://market.azure.cn
使用 Chef 自动执行 Azure 虚拟机部署的更多相关文章
- 使用 CustomScript 扩展程序自动执行 Linux 虚拟机自定义任务
NingKuangWSSC WS ARD 高级项目经理 您可能已经从Windows扩展程序博客中了解了针对 Windows 虚拟机的 CustomScript扩展程序,现在的好消息是,这一扩展程序也已 ...
- Python开发入门与实战18-Windows Azure 虚拟机部署
18. 微软云虚拟机部署 上一章节我们介绍了如何在新浪云部署我们的在python django应用,本章我们来介绍如何Windows Azure上部署我们的应用. 18.1. 注册Windows Az ...
- 使用Windows Azure PowerShell远程管理Windows Azure虚拟机
对于Windows Azure,如果你还在使用windowsazure.com门户来管理虚拟机,那就显得不怎么高上大了.Windows Azure PowerShell 是一个功能强大的脚本环境,可用 ...
- Azure 虚拟机代理概述
Azure 虚拟机代理(AM 代理)是受保护的轻型过程,用于管理 VM 与 Azure 结构控制器的交互. VM 代理有一个主要角色,目的是启用和执行 Azure 虚拟机扩展. VM 扩展可用于对虚拟 ...
- (译)Windows Azure的7月更新:SQL数据库,流量管理,自动缩放,虚拟机
Windows Azure的7月更新:SQL数据库,流量管理,自动缩放,虚拟机 今早我们释出一些很棒的Windows Azure更新.这些新的提升包括:SQL数据库:支持SQL自动导出和一个新的高级层 ...
- 利用Azure虚拟机安装Dynamics 365 Customer Engagement之七:安装前端服务器及部署管理器
我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...
- 转载文章:Windows Azure 七月份更新:SQL 数据库、流量管理器、自动伸缩、虚拟机
转载文章:Windows Azure 七月份更新:SQL 数据库.流量管理器.自动伸缩.虚拟机 今天上午,我们发布了一些重大的 Windows Azure 更新.这些新的增强功能包括: · SQL 数 ...
- Azure ASM虚拟机部署“安全扩展”
Azure虚拟机,默认情况下没有安装杀毒软件.如果您有此需求可以通过Azure 扩展进行安装,有关Azure反恶意软件的官方说明请参考:https://docs.azure.cn/zh-cn/secu ...
- Azure ARM虚拟机部署反恶意软件-安全扩展
Azure虚拟机,默认情况下没有安装杀毒软件.如果您有此需求可以通过Azure 扩展进行安装,有关Azure反恶意软件的官方说明请参考:https://docs.azure.cn/zh-cn/secu ...
随机推荐
- 【JAVA】枚举
枚举(enum)类型是Java 5新增的特性,它是一种新的类型,允许用常量来表示特定的数据片断,而且全部都以类型安全的形式来表示. 1.常量的使用 在JDK1.5之前,我们定义常量都是:public ...
- 高可用Hadoop平台-实战尾声篇
1.概述 今天这篇博客就是<高可用Hadoop平台>的尾声篇了,从搭建安装到入门运行 Hadoop 版的 HelloWorld(WordCount 可以称的上是 Hadoop 版的 Hel ...
- ActiveMQ——activemq的报错见解javax.jms.JMSException: Software caused connection abort: recv failed
activeMQ出现javax.jms.JMSException: Software caused connection abort: recv failed的问题解决 一直找不到原因,原来是在本地的 ...
- 复刻smartbits的国产网络测试工具minismb-如何测试协议限速
复刻smartbits的网络性能测试工具MiniSMB,是一款专门用于测试智能路由器,网络交换机的性能和稳定性的软硬件相结合的工具.可以通过此工具测试任何ip网络设备的端口吞吐率,带宽,并发连接数和最 ...
- 二叉树的递归,非递归遍历(C++)
二叉树是一种非常重要的数据结构,很多其它数据结构都是基于二叉树的基础演变而来的.对于二叉树,有前序.中序以及后序三种遍历方法.因为树的定义本身就是递归定义,因此采用递归的方法去实现树的三种遍历不仅容易 ...
- SpringMVC之@PathVariable 映射 URL 绑定的占位符
@PathVariable 该注解可以将URL中占位符参数绑定到方法的参数上,及ULR中{xxx}可以通过@PathVariable("xxx")绑定到方法参数中. 测试类: @R ...
- MVC应用程序显示Flash(swf)视频
前段时间, Insus.NET有实现<MVC使用Flash来显示图片>http://www.cnblogs.com/insus/p/3598941.html 在演示中,它也可以显示Flas ...
- Redis 缓存设计原则
基本原则 只应将热数据放到缓存中 所有缓存信息都应设置过期时间 缓存过期时间应当分散以避免集中过期 缓存key应具备可读性 应避免不同业务出现同名缓存key 可对key进行适当的缩写以节省内存空间 选 ...
- Weex 实现文件的下载
需求:在使用weex框架时,我们使用vue文件写页面,在native端加载服务器端的js页面时由于网络状态的不确定性,我们需要在第一次加载的时候对js页面进行本地存储.也就是说我们需要把js文件下载到 ...
- Linux常用基本命令(head)
head命令 作用:显示文件的头部内容,默认显示前面10行 格式: head [option] [file] -n <行数> -c <字节> ghostwu@dev:~/lin ...