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 虚拟机部署的更多相关文章

  1. 使用 CustomScript 扩展程序自动执行 Linux 虚拟机自定义任务

    NingKuangWSSC WS ARD 高级项目经理 您可能已经从Windows扩展程序博客中了解了针对 Windows 虚拟机的 CustomScript扩展程序,现在的好消息是,这一扩展程序也已 ...

  2. Python开发入门与实战18-Windows Azure 虚拟机部署

    18. 微软云虚拟机部署 上一章节我们介绍了如何在新浪云部署我们的在python django应用,本章我们来介绍如何Windows Azure上部署我们的应用. 18.1. 注册Windows Az ...

  3. 使用Windows Azure PowerShell远程管理Windows Azure虚拟机

    对于Windows Azure,如果你还在使用windowsazure.com门户来管理虚拟机,那就显得不怎么高上大了.Windows Azure PowerShell 是一个功能强大的脚本环境,可用 ...

  4. Azure 虚拟机代理概述

    Azure 虚拟机代理(AM 代理)是受保护的轻型过程,用于管理 VM 与 Azure 结构控制器的交互. VM 代理有一个主要角色,目的是启用和执行 Azure 虚拟机扩展. VM 扩展可用于对虚拟 ...

  5. (译)Windows Azure的7月更新:SQL数据库,流量管理,自动缩放,虚拟机

    Windows Azure的7月更新:SQL数据库,流量管理,自动缩放,虚拟机 今早我们释出一些很棒的Windows Azure更新.这些新的提升包括:SQL数据库:支持SQL自动导出和一个新的高级层 ...

  6. 利用Azure虚拟机安装Dynamics 365 Customer Engagement之七:安装前端服务器及部署管理器

    我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...

  7. 转载文章:Windows Azure 七月份更新:SQL 数据库、流量管理器、自动伸缩、虚拟机

    转载文章:Windows Azure 七月份更新:SQL 数据库.流量管理器.自动伸缩.虚拟机 今天上午,我们发布了一些重大的 Windows Azure 更新.这些新的增强功能包括: · SQL 数 ...

  8. Azure ASM虚拟机部署“安全扩展”

    Azure虚拟机,默认情况下没有安装杀毒软件.如果您有此需求可以通过Azure 扩展进行安装,有关Azure反恶意软件的官方说明请参考:https://docs.azure.cn/zh-cn/secu ...

  9. Azure ARM虚拟机部署反恶意软件-安全扩展

    Azure虚拟机,默认情况下没有安装杀毒软件.如果您有此需求可以通过Azure 扩展进行安装,有关Azure反恶意软件的官方说明请参考:https://docs.azure.cn/zh-cn/secu ...

随机推荐

  1. Objective-C 字符串与数值互相转换

    Convert NSString to int NSString *aNumberString = @"123"; int i = [aNumberString intValue] ...

  2. Google地图开发

    配置Google API SDK 如果要想进行Google Map或者说是定位服务的开发,那么肯定需要下载一个新的SDK的支持. 1.点击Android SDK Manager,下载SDK. 2.直接 ...

  3. 分享 : 警惕MySQL运维陷阱:基于MyCat的伪分布式架构

    分布式数据库已经进入了全面快速发展阶段.这种发展是与时俱进的,与人的需求分不开,因为现在信息时代的高速发展,导致数据量和交易量越来越大.这种现象首先导致的就是存储瓶颈,因为MySQL数据库实质上还是一 ...

  4. Sublime Text shift+ctrl 妙用

    1 :按住shift+ctrl然后按←或→可快速选中一行中的某一部分,相当于双击鼠标选中. 当你想在代码末尾加注释的话,这个方法很好用 输入文字 -> 光标移到文字末尾 -> 按住shif ...

  5. 【IT笔试面试题整理】二叉搜索树转换为双向链表

    [试题描述] 将二叉搜索树转换为双向链表 对于二叉搜索树,可以将其转换为双向链表,其中,节点的左子树指针在链表中指向前一个节点,右子树指针在链表中指向后一个节点. 思路一: 采用递归思想,对于二叉搜索 ...

  6. spark work目录处理 And HDFS空间都去哪了?

    1.说在前面 过完今天就放假回家了(挺高兴),于是提前检查了下个服务集群的状况,一切良好.正在我想着回家的时候突然发现手机上一连串的告警,spark任务执行失败,spark空间不足.我的心突然颤抖了一 ...

  7. Java 使用gson 解析 Json

    json数据 { "resultcode": "200", "reason": "successed!", " ...

  8. Angular ngIf相关问题

    1.ngIf会把元素销毁,如果在页面加载时给元素注册了事件(如MouseOver),当ngIf的条件不满足时会销毁元素,再次生成元素并不会把事件注册 2.ngIf在IOS上会导致input控件无法正常 ...

  9. 用canvas画弧形进度条

    function toCanvas(id ,progress){ //canvas进度条 var canvas = document.getElementById(id), ctx = canvas. ...

  10. ASP.NET MVC应用程序播放AVI视频

    前面Insus.NET实现一系列在MVC应用程序播放SWF, FLV, WMV, RM, RMVB视频.每篇使用不同的方法方式,大同小异.这篇中,为了MVC应用程序播放AVI视频,用纯M, V, C来 ...