在 Azure 容器实例中装载 gitRepo 卷

了解如何在容器实例中装载 gitRepo 卷以克隆 Git 存储库。

注意

当前只有 Linux 容器能装载 gitRepo 卷。 虽然我们正致力于为 Windows 容器提供全部功能,但你可在概述中了解当前的平台差异。

gitRepo 卷

在容器创建期间,gitRepo 卷会装载目录并将指定的 Git 存储库克隆到该目录。 在容器实例中使用 gitRepo 卷,可避免在应用程序中为执行此操作添加代码。

装载 gitRepo 卷时,可以设置三个属性以对卷进行配置:

属性 必选 说明
repository 要克隆的 Git 存储库的完整 URL,包括 http://https://
directory 存储库应克隆到的目录。 路径不得包含“..”,也不能以其开头。 如果指定“.”,存储库将克隆到卷的目录。 否则,Git 存储库将克隆到卷目录中给定名称的子目录。
revision 要克隆的修订的提交哈希。 如果未指定,则克隆 HEAD 修订。

装载 gitRepo 卷:Azure CLI

在使用 Azure CLI 部署容器实例时若要装载 gitRepo 卷,请在 az container create 命令中提供 --gitrepo-url--gitrepo-mount-path 参数。 还可以指定要将卷克隆到其中的目录 (--gitrepo-dir) 和要克隆的修订版的提交哈希 (--gitrepo-revision)。

此示例命令将 Microsoft aci-helloworld 示例应用程序克隆到容器实例中的 /mnt/aci-helloworld

az container create \
    --resource-group myResourceGroup \
    --name hellogitrepo \
    --image mcr.microsoft.com/azuredocs/aci-helloworld \
    --dns-name-label aci-demo \
    --ports 80 \
    --gitrepo-url https://github.com/Azure-Samples/aci-helloworld \
    --gitrepo-mount-path /mnt/aci-helloworld

若要验证 gitRepo 卷是否已装载,请使用 az container exec 在该容器中启动 shell 并列出目录:

az container exec --resource-group myResourceGroup --name hellogitrepo --exec-command /bin/sh
/usr/src/app # ls -l /mnt/aci-helloworld/
total 16
-rw-r--r--    1 root     root           144 Apr 16 16:35 Dockerfile
-rw-r--r--    1 root     root          1162 Apr 16 16:35 LICENSE
-rw-r--r--    1 root     root          1237 Apr 16 16:35 README.md
drwxr-xr-x    2 root     root          4096 Apr 16 16:35 app

装载 gitRepo 卷:资源管理器

在使用 Azure 资源管理器模板部署容器实例时若要装载 gitRepo 卷,请首先填充模板的容器组 properties 节中的 volumes 数组。 然后,针对容器组中希望装载 gitRepo 卷的每个容器,在容器定义的 properties 节中填充 volumeMounts 数组。

例如,以下资源管理器模板创建了一个包含单个容器的容器组。 该容器克隆由 gitRepo 卷块指定的两个 GitHub 存储库。 第二个卷包括其他属性以指定要克隆到的目录和要克隆的特定修订的提交哈希。

{
  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
  "contentVersion": "1.0.0.0",
  "variables": {
    "container1name": "aci-tutorial-app",
    "container1image": "mcr.microsoft.com/azuredocs/aci-helloworld"
  },
  "resources": [
    {
      "type": "Microsoft.ContainerInstance/containerGroups",
      "apiVersion": "2021-03-01",
      "name": "volume-demo-gitrepo",
      "location": "[resourceGroup().location]",
      "properties": {
        "containers": [
          {
            "name": "[variables('container1name')]",
            "properties": {
              "image": "[variables('container1image')]",
              "resources": {
                "requests": {
                  "cpu": 1,
                  "memoryInGb": 1.5
                }
              },
              "ports": [
                {
                  "port": 80
                }
              ],
              "volumeMounts": [
                {
                  "name": "gitrepo1",
                  "mountPath": "/mnt/repo1"
                },
                {
                  "name": "gitrepo2",
                  "mountPath": "/mnt/repo2"
                }
              ]
            }
          }
        ],
        "osType": "Linux",
        "ipAddress": {
          "type": "Public",
          "ports": [
            {
              "protocol": "tcp",
              "port": "80"
            }
          ]
        },
        "volumes": [
          {
            "name": "gitrepo1",
            "gitRepo": {
              "repository": "https://github.com/Azure-Samples/aci-helloworld"
            }
          },
          {
            "name": "gitrepo2",
            "gitRepo": {
              "directory": "my-custom-clone-directory",
              "repository": "https://github.com/Azure-Samples/aci-helloworld",
              "revision": "d5ccfcedc0d81f7ca5e3dbe6e5a7705b579101f1"
            }
          }
        ]
      }
    }
  ]
}

前面的模板中定义的两个克隆存储库的生成目录结构如下:

/mnt/repo1/aci-helloworld
/mnt/repo2/my-custom-clone-directory

若要查看使用 Azure 资源管理器模板进行的容器实例部署示例,请参阅在 Azure 容器实例中部署多容器组

专用 Git 存储库身份验证

若要为专用 Git 存储库装载 gitRepo 卷,请在存储库 URL 中指定凭据。 通常,凭据采用用户名和个人访问令牌 (PAT) 的形式,授予对存储库的范围访问权限。

例如,专用 GitHub 存储库的 Azure CLI --gitrepo-url 参数将类似于以下内容(其中“gituser”是 GitHub 用户名,“abcdef1234fdsa4321abcdef”是用户的个人访问令牌):

--gitrepo-url https://gituser:abcdef1234fdsa4321abcdef@github.com/GitUser/some-private-repository

对于 Azure Repos Git 存储库,请指定任何用户名(可以使用“azurereposuser”,如下例所示)并结合有效的 PAT:

--gitrepo-url https://azurereposuser:abcdef1234fdsa4321abcdef@dev.azure.com/your-org/_git/some-private-repository

有关 GitHub 和 Azure Repos 的个人访问令牌的详细信息,请参阅以下内容:

GitHub:创建命令行的个人访问令牌

后续步骤

了解如何在 Azure 容器实例中装载其他卷类型: