在Azure DevOps管道中如何从文件共享获取依赖项

53次阅读
没有评论

问题描述

正在尝试为构建多个Docker容器并将其部署到容器注册表的CI管道进行设置。他们的代码、Docker和配置文件都存储在Azure git存储库中,并且构建这些容器工作正常。

然而,他们需要构建一个基于tomcat应用程序的容器,但该应用程序只有一个大小约为20MB的.war文件。他们不想将此文件提交到存储库中(他们不确定使用git LFS是否能解决问题,因为在其他项目中有过不好的经验),而是将其保存在Azure存储帐户(blob或文件共享存储)中。

当我想在构建管道中包含一个任务来下载此文件时,问题就开始了。使用powershell或bash脚本从公开访问的文件中获取文件很容易。但是,要从存储帐户下载文件,您首先需要进行身份验证,而我找不到一个好的方法来实现这一点。

解决方案

请注意以下操作注意版本差异及修改前做好备份。

方案1

根据这篇文章描述的步骤,您可以使用Azure PowerShell下载文件:How To Download Azure BLOB Storage Using Azure PowerShell。根据这篇文章,您需要使用来自访问密钥页面的连接字符串。您可以创建自定义的密钥变量(Variables)并将连接字符串保存在新变量中。然后,在您的ps脚本中,您可以使用”$env:VARIABLE_NAME”引用连接字符串(存储在变量中)。

以下是使用Azure PowerShell下载Azure BLOB存储的步骤:
1. 在Azure DevOps中打开您的构建管道。
2. 添加一个新的任务,选择PowerShell作为任务类型。
3. 在脚本框中,使用以下脚本来下载BLOB存储中的文件:

# 获取连接字符串
$connectionString = $env:VARIABLE_NAME

# 创建存储帐户上下文
$storageAccountContext = New-AzStorageContext -ConnectionString $connectionString

# 下载文件
Get-AzStorageBlobContent -Container "your_container_name" -Blob "your_blob_name" -Destination "your_destination_path" -Context $storageAccountContext

请确保将上述脚本中的VARIABLE_NAME替换为您在Azure DevOps中创建的自定义密钥变量的名称。另外,将your_container_name替换为存储帐户中包含要下载的文件的容器的名称,将your_blob_name替换为要下载的文件的名称,将your_destination_path替换为要将文件下载到的目标路径。

方案2

使用脚本或工具来管理容器的启动顺序可能会增加复杂性,并且需要确保容器A和容器B之间的依赖关系正确设置。
另一种方法是编写脚本或使用工具来控制容器的运行顺序。你可以使用docker run命令来手动控制容器的启动顺序,或者使用一些第三方工具来管理容器的依赖关系。

示例:

以下是一个简单的bash脚本示例,可以在容器A启动后启动容器B:

#!/bin/bash
# 启动容器A
docker run -d --name container_a your_image_a
# 等待容器A完全启动
while ! docker exec container_a echo "Container A is ready"; do
  sleep 1
done
# 启动容器B
docker run -d --name container_b your_image_b

在这个示例中,我们首先使用docker run命令启动容器A,并将其命名为container_a。然后,使用一个循环来等待容器A完全启动(这里是通过在容器内运行echo命令来测试)。一旦容器A就绪,我们再使用docker run命令启动容器B,并将其命名为container_b

请注意,这只是一个示例,您可能需要根据您的具体情况进行调整和修改。

正文完