教程:使用 Jenkins 和 Azure DevOps Services 部署到 Linux 虚拟机

持续集成 (CI) 和持续部署 (CD) 可形成一个管道,用于生成、发布和部署代码。 Azure DevOps Services 针对到 Azure 的部署提供了一组完整的功能完备的 CI/CD 自动化工具。 Jenkins 是一款常用的基于服务器的第三方 CI/CD 工具,也提供 CI/CD 自动化。 你可以结合使用 Azure DevOps Services 和 Jenkins 来自定义交付云应用或服务的方式。

在本教程中,将使用 Jenkins 生成 Node.js Web 应用。 然后,使用 Azure DevOps 将其部署到

包含 Linux 虚拟机 (VM) 的部署组。 学习如何:

  • 获取示例应用。
  • 配置 Jenkins 插件。
  • 为 Node.js 配置 Jenkins 自由风格项目。
  • 为 Azure DevOps Services 集成配置 Jenkins。
  • 创建 Jenkins 服务终结点。
  • 为 Azure 虚拟机创建部署组。
  • 创建 Azure Pipelines 发布管道。
  • 执行手动和 CI 触发的部署。

先决条件

  • Azure 订阅:如果还没有 Azure 订阅,可以在开始前创建一个免费 Azure 帐户

  • Jenkins 服务器:如果没有安装 Jenkins 服务器,请在 Azure 上创建 Jenkins 服务器。

    注意

    有关详细信息,请参阅连接到 Azure DevOps Services

获取示例应用

你需要一个待部署的应用,并存储在 Git 存储库中。 对于本教程,我们建议你使用从 GitHub 获得的此示例应用。 本教程包含用于安装 Node.js 和应用程序的示例脚本。 要使用自己的存储库,请配置一个类似的示例。

创建此应用的一个分支并记下位置 (URL) 以便在本教程的后续步骤中使用。 有关详细信息,请参阅分支存储库

注意

应用是通过 Yeoman 生成的。 它使用 Express、bower 和 grunt。 它还有一些 npm 包作为依赖项。 示例还包含一个用来设置 Nginx 并部署应用的脚本。 它在虚拟机上执行。 具体而言,脚本将执行以下操作:

  1. 安装 Node、Nginx 和 PM2。
  2. 配置 Nginx 和 PM2。
  3. 启动 Node 应用。

配置 Jenkins 插件

首先,必须配置两个 Jenkins 插件:NodeJS 和 VS Team Services 持续部署

  1. 打开你的 Jenkins 帐户,并选择“管理 Jenkins”
  2. 在“管理 Jenkins”页面上,选择“管理插件”
  3. 筛选列表以查找“NodeJS”插件,然后选择“安装而不重启”选项。 Adding the NodeJS plug-in to Jenkins
  4. 筛选列表以查找“VS Team Services 持续部署”插件,然后选择“安装而不重启”选项。
  5. 返回 Jenkins 仪表板,然后选择“管理 Jenkins”
  6. 选择“全局工具配置”。 查找“NodeJS”,然后选择“NodeJS 安装”
  7. 选择“自动安装”选项,然后输入“名称”值。
  8. 选择“保存”。

为 Node.js 配置 Jenkins 自由风格项目

  1. 选择“新建项”。 输入一个项名称。
  2. 选择“自由风格项目”。 选择“确定”
  3. 在“源代码管理”选项卡上,选择“Git”并输入包含应用代码的存储库和分支的详细信息。
    Add a repo to your build
  4. 在“生成触发器”选项卡上,选择“轮询 SCM”并输入计划 H/03 * * * *,以便每三分钟轮询一次 Git 存储库中的更改。
  5. “生成环境 ”选项卡上,选择“ 提供节点和 npm bin/”文件夹路径 ,然后选择 NodeJS 安装 值。 使“npmrc 文件”设置为“用户系统默认值”
  6. 在“生成”选项卡上,选择“执行 shell”,然后输入命令 npm install,以确保更新所有依赖项。

为 Azure DevOps Services 集成配置 Jenkins

注意

确保你用于以下步骤的个人访问令牌 (PAT) 包含 Azure DevOps Services 中的“发布”(读取、写入、执行和管理)权限。

  1. 如果尚没有 PAT,请在你的 Azure DevOps Services 组织中创建一个 PAT。 Jenkins 需要使用此信息来访问你的 Azure DevOps Services 组织。 确保存储令牌信息以用于本部分后面的步骤。

    若要了解如何生成令牌,请阅读如何为 Azure DevOps Services 创建个人访问令牌?

  2. 在“生成后操作”选项卡中,选择“添加生成后操作”。 选择“存档项目”

  3. 对于“要存档的文件”,输入 **/* 以包括所有文件

  4. 若要创建其他操作,请选择“添加生成后操作”

  5. 选择“在 TFS/Team Services 中触发发布” 。 输入你的 Azure DevOps Services 组织的 URI,例如 https://{your-organization-name}.visualstudio.com

  6. 输入项目名称

  7. 为发布管道选择一个名称。 (稍后你将在 Azure DevOps Services 中创建此发布管道。)

  8. 选择用于连接到 Azure DevOps Services 或 Azure DevOps Server 环境的凭据:

    • 如果你正在使用 Azure DevOps Services,请将“用户名”留空。
    • 如果使用的是本地版本的 Azure DevOps Server,请输入用户名和密码。
      Configuring Jenkins post-build actions
  9. 保存 Jenkins 项目。

创建 Jenkins 服务终结点

服务终结点允许 Azure DevOps Services 连接到 Jenkins。

  1. 在 Azure DevOps Services 中打开“服务”页面,打开“新服务终结点”列表,然后选择“Jenkins”Add a Jenkins endpoint
  2. 输入连接的名称。
  3. 输入 Jenkins 服务器的 URL,然后选择“接受不受信任的 SSL 证书”选项。 示例 URL 为 http://{YourJenkinsURL}.westcentralus.cloudapp.azure.com
  4. 输入 Jenkins 帐户的用户名和密码。
  5. 选择“验证连接”确认信息是否正确。
  6. 选择“确定”,创建服务终结点。

为 Azure 虚拟机创建部署组。

你需要部署组以注册 Azure DevOps Services 代理,以便可以将发布管道部署到虚拟机。 通过部署组,可以方便地定义目标计算机的逻辑组,以进行部署,并在每台计算机上安装所需的代理。

注意

在以下过程中,确保安装先决条件,且不使用 sudo 权限运行脚本

  1. 打开“生成”和“发布”中心的“发布”选项卡,打开“部署组”,然后选择“+ 新建”。
  2. 为部署组输入名称和可选说明。 然后选择“创建”。
  3. 为部署目标虚拟机选择操作系统。 例如,选择“Ubuntu 16.04+”
  4. 选择“使用脚本中的个人访问令牌进行身份验证”
  5. 选择“系统必备组件”链接。 为操作系统安装必备组件。
  6. 选择“将脚本复制到剪贴板”以复制脚本。
  7. 登录到部署目标虚拟机并运行脚本。 不要使用 sudo 权限运行脚本。
  8. 完成安装后,系统将提示你部署组标记。 接受默认值。
  9. 在 Azure DevOps Services 中,在“部署组”下的“目标”中检查新注册的虚拟机。

创建 Azure Pipelines 发布管道

发布管道指定了 Azure Pipelines 用来部署应用的流程。 在此示例中,你将执行一个 shell 脚本。

若要在 Azure Pipelines 中创建发布管道,请执行以下操作:

  1. 打开“生成和发布”中心的“发布”选项卡,然后选择“创建发布管道”。
  2. 通过选择以“空进程”开始,选择“空”模板。
  3. 在“项目”部分,选择“+ 添加项目”,然后在“源类型”中选择“Jenkins”。 选择你的 Jenkins 服务终结点连接。 然后选择 Jenkins 源作业,并选择“添加”
  4. 选择“环境 1”旁边的省略号。 选择“添加部署组阶段”
  5. 选择部署组。
  6. 选择“”+,向“部署组阶段”中添加任务
  7. 选择“Shell 脚本”任务,并选择“添加”。 “Shell 脚本”任务为要在每个服务器上运行的脚本提供配置,以安装 Node.js 并启动应用。
  8. 对于“脚本路径”,请输入“$(System.DefaultWorkingDirectory)/Fabrikam-Node/deployscript.sh”
  9. 选择“高级”,然后启用“指定工作目录”
  10. 对于“工作目录”,请输入“$(System.DefaultWorkingDirectory)/Fabrikam-Node”
  11. 将发布管道的名称编辑为你在 Jenkins 内部版本的“生成后操作”选项卡上指定的名称。 必须提供此名称,Jenkins 才能在源项目更新时触发新的发布。
  12. 选择“保存”,然后选择“确定”以保存发布管道。

执行手动和 CI 触发的部署

  1. 选择“+ 发布”,然后选择“创建发布”
  2. 选择在突出显示的下拉列表中完成的内部版本,然后选择“队列”
  3. 在弹出消息中选择发布链接。 例如:“发布 Release-1 已创建。”
  4. 打开“日志”选项卡以查看发布控制台输出。
  5. 在浏览器中,打开已添加到部署组的其中一个服务器的 URL。 例如,输入 http://{your-server-ip-address}
  6. 转到源 Git 存储库,使用某些已更改的文本来修改文件 app/views/index.jade 中 h1 标题的内容
  7. 提交更改。
  8. 几分钟后,可以在 Azure DevOps 的“发布”页面中看到新创建的发布。 打开此发布可以看到部署正在进行。 祝贺你!

排查 Jenkins 插件问题

如果 Jenkins 插件出现任何 bug,请在 Jenkins JIRA 中提出特定组件的问题。

后续步骤

在本教程中,你通过使用 Jenkins 进行生成并使用 Azure DevOps Services 进行发布,自动将一个应用部署到 Azure。 你已了解如何:

  • 在 Jenkins 中生成应用。
  • 为 Azure DevOps Services 集成配置 Jenkins。
  • 为 Azure 虚拟机创建部署组。
  • 创建配置 VM 并部署应用的 Azure Pipelines。

若要了解如何将 Azure Pipelines 用于生成和发布步骤,请参阅此文

若要了解如何编写基于 YAML 的 CI/CD 管道并将其部署到 VM,请参阅下一篇教程。