랩에 아티팩트 리포지토리 추가
이 문서에서는 Azure DevTest Labs의 랩에 아티팩트 리포지토리를 추가하는 방법을 설명합니다. 아티팩트는 VM(가상 머신)에 설치할 도구 또는 애플리케이션입니다. GitHub 또는 Azure Repos Git 리포지토리에서 로드하는 JSON 파일에서 아티팩트를 정의합니다.
퍼블릭 DevTest Labs GitHub 아티팩트 리포지토리는 Windows 및 Linux에 대한 많은 일반적인 아티팩트를 제공합니다. 이 퍼블릭 리포지토리의 아티팩트는 DevTest Labs에서 기본적으로 사용할 수 있습니다. 아티팩트를 VM에 추가하는 방법에 관한 내용은 DevTest Labs VM에 아티팩트 추가를 참조하세요.
퍼블릭 아티팩트 리포지토리에서 사용할 수 없는 사용자 지정 아티팩트를 만들 수도 있습니다. 사용자 지정 아티팩트를 만드는 방법에 대한 자세한 내용은 사용자 지정 아티팩트 만들기를 참조하세요. 사용자 지정 아티팩트를 고유한 아티팩트 리포지토리에 추가하고, 모든 랩 사용자가 아티팩트를 사용할 수 있도록 리포지토리를 랩에 추가할 수 있습니다.
이 문서에서는 Azure Portal, ARM(Azure Resource Management) 템플릿 또는 Azure PowerShell을 사용하여 아티팩트 리포지토리를 랩에 추가하는 방법을 보여 줍니다. Azure PowerShell 또는 Azure CLI 스크립트를 사용하여 아티팩트 리포지토리를 랩에 추가하는 작업을 자동화할 수도 있습니다.
참고 항목
Azure Az PowerShell 모듈을 사용하여 Azure와 상호 작용하는 것이 좋습니다. 시작하려면 Azure PowerShell 설치를 참조하세요. Az PowerShell 모듈로 마이그레이션하는 방법에 대한 자세한 내용은 Azure PowerShell을 AzureRM에서 Azure로 마이그레이션을 참조하세요.
아티팩트 리포지토리 추가
Azure 리포지토리 또는 GitHub 리포지토리에서 아티팩트 리포지토리를 추가할 수 있습니다. 관리 ID에 권한을 할당하거나, GitHub 앱 인증을 사용하거나, PAT를 사용하여 인증하도록 선택할 수 있습니다. 관리 ID에 대한 자세한 내용은 Azure 리소스에 대한 관리 ID란?을 참조하세요.
사용하려는 리포지토리 및 인증 유형에 대한 탭을 선택합니다.
- MSI를 사용한 Azure Repos 리포지토리
- PAT가 포함된 Azure Repos 리포지토리
- GitHub 리포지토리 DevCenter 앱
- PAT를 사용한 GitHub 리포지토리
아티팩트 리포지토리를 추가하려면 다음 작업을 완료합니다.
- 관리 ID에 대해 Azure Repos에서 권한을 할당합니다.
- 아티팩트 리포지토리를 추가합니다.
관리 ID에 대해 Azure Repos에서 권한 할당
Azure Repos의 리포지토리에 관리 ID 권한을 부여해야 합니다.
Azure DevOps 조직에 로그인합니다.
참고 항목
Azure DevOps 조직은 랩을 포함하는 Azure 구독과 동일한 디렉터리에 있어야 합니다.
조직 설정을 선택합니다.
개요 페이지에서 사용자를 선택합니다.
사용자 페이지에서 사용자 추가를 선택합니다.
다음 정보를 입력하거나 선택하여 새 사용자 추가를 완료한 다음, 추가를 선택합니다.
속성 값 사용자 또는 서비스 주체 랩의 이름을 입력합니다.
시스템 할당 MSI를 사용하는 경우 관리되는 계정의 개체 ID가 아닌 랩의 이름을 지정합니다. 사용자 할당 MSI를 사용하는 경우 관리되는 계정의 이름을 사용합니다.액세스 수준 기본을 선택합니다. 프로젝트에 추가 리포지토리가 포함된 프로젝트를 선택합니다. Azure DevOps 그룹 프로젝트 Readers를 선택합니다. 이메일 초대 보내기(사용자에게만) 확인란의 선택을 취소합니다.
Azure Portal의 랩에 Azure DevOps 아티팩트 리포지토리 추가
랩의 개요 페이지에 있는 왼쪽 탐색 영역에서 구성 및 정책을 선택합니다.
구성 및 정책 페이지 왼쪽 탐색 영역의 외부 리소스에서 리포지토리를 선택합니다.
리포지토리 페이지에서 퍼블릭 아티팩트 리포지토리가 자동으로 표시되고 DevTest Labs 퍼블릭 GitHub 리포지토리에 연결됩니다. 이 리포지토리가 랩에서 사용되지 않는 경우 퍼블릭 아티팩트 리포지토리 옆의 확인란을 선택한 다음, 위쪽 메뉴 모음에서 사용을 선택하여 사용하도록 설정할 수 있습니다.
아티팩트 리포지토리를 랩에 추가하려면 위쪽 메뉴 모음에서 추가를 선택합니다.
리포지토리 창에서 다음 정보를 입력합니다.
- 이름: 랩에서 사용할 리포지토리 이름입니다.
- Git 복제 URL: Azure Repos의 Git HTTPS 복제 URL입니다.
- 분기(선택 사항): 아티팩트 정의가 있는 분기입니다.
- 폴더 경로: Git 복제 URL을 기준으로 한 ARM 템플릿 정의 폴더입니다. 폴더 경로의 첫 부분에 슬래시를 포함해야 합니다.
- 관리 ID: 이 옵션을 사용하여 인증에 관리 ID를 활용합니다.
저장을 선택합니다.
이제 리포지토리가 랩의 리포지토리 목록에 표시됩니다.
ARM 템플릿을 사용하여 아티팩트 리포지토리 추가
ARM 템플릿은 만들 Azure 리소스를 설명하는 JSON 파일입니다. ARM 템플릿에 관한 자세한 내용은 ARM 템플릿의 구조 및 구문 이해를 참조하세요.
다음 ARM 템플릿은 아티팩트 리포지토리를 랩에 추가합니다. 랩이 아직 없으면 템플릿이 랩을 만듭니다.
ARM 템플릿 검토
샘플 템플릿은 매개 변수에서 다음 정보를 수집합니다. 일부 매개 변수에는 기본값이 있지만 배포 명령은 랩 이름, 아티팩트 리포지토리 URI, 리포지토리 유형, 리포지토리 개인용 액세스 토큰을 지정해야 합니다.
- 랩 이름
- DevTest Labs에서 아티팩트 리포지토리의 표시 이름입니다. 기본값은
Team Repository
입니다. - 이전에 복사한 아티팩트 리포지토리의 URI입니다.
- 아티팩트가 포함된 리포지토리 분기입니다. 기본값은
main
입니다. - 아티팩트를 포함하는 폴더의 이름입니다. 기본값은
/Artifacts
입니다. - 리포지토리 유형입니다. 허용되는 값은
VsoGit
(Azure Repos) 또는GitHub
입니다. - 이전에 복사한 리포지토리의 개인용 액세스 토큰입니다.
{
"$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"labName": {
"type": "string"
},
"artifactRepositoryDisplayName": {
"type": "string",
"defaultValue": "Team Repository"
},
"artifactRepoUri": {
"type": "string"
},
"artifactRepoBranch": {
"type": "string",
"defaultValue": "main"
},
"artifactRepoFolder": {
"type": "string",
"defaultValue": "/Artifacts"
},
"artifactRepoType": {
"type": "string",
"allowedValues": ["VsoGit", "GitHub"]
},
"artifactRepoSecurityToken": {
"type": "securestring"
}
},
"variables": {
"artifactRepositoryName": "[concat('Repo-', uniqueString(subscription().subscriptionId))]"
},
"resources": [{
"apiVersion": "2016-05-15",
"type": "Microsoft.DevTestLab/labs",
"name": "[parameters('labName')]",
"location": "[resourceGroup().location]",
"resources": [
{
"apiVersion": "2016-05-15",
"name": "[variables('artifactRepositoryName')]",
"type": "artifactSources",
"dependsOn": [
"[resourceId('Microsoft.DevTestLab/labs', parameters('labName'))]"
],
"properties": {
"uri": "[parameters('artifactRepoUri')]",
"folderPath": "[parameters('artifactRepoFolder')]",
"branchRef": "[parameters('artifactRepoBranch')]",
"displayName": "[parameters('artifactRepositoryDisplayName')]",
"securityToken": "[parameters('artifactRepoSecurityToken')]",
"sourceType": "[parameters('artifactRepoType')]",
"status": "Enabled"
}
}
]
}
]
}
템플릿 배포
ARM 템플릿을 배포하여 Azure 리소스를 만들거나 업데이트하는 방법에는 여러 가지가 있습니다. 정보와 지침은 다음 문서를 참조하세요.
- ARM 템플릿 및 Azure PowerShell을 사용하여 리소스 배포
- ARM 템플릿 및 Azure CLI를 사용하여 리소스 배포
- Azure Portal에서 ARM 템플릿을 사용하여 리소스 배포
- ARM 템플릿 및 Resource Manager REST API를 사용하여 리소스 배포
이 예제에서는 Azure PowerShell을 사용하여 템플릿을 배포합니다.
참고 항목
템플릿을 배포하는 cmdlet은 컨텍스트에 따라 다르므로 현재 테넌트와 구독을 사용합니다. 컨텍스트를 변경해야 하는 경우 템플릿을 배포하기 전에 Set-AzContext를 사용합니다.
New-AzResourceGroup을 사용하여 리소스 그룹을 만듭니다. 사용하려는 리소스 그룹이 이미 있는 경우 이 단계를 건너뜁니다.
New-AzResourceGroup -Name MyLabResourceGroup1 -Location westus
New-AzResourceGroupDeployment를 사용하여 리소스 그룹에 대한 배포를 만듭니다. 동일한 리소스 그룹에 대한 여러 리소스 배포를 만들 수 있습니다. 동일한 리소스 그룹에 여러 번 배포하는 경우 각 배포 이름이 고유해야 합니다.
New-AzResourceGroupDeployment ` -Name MyLabResourceGroup-Deployment1 ` -ResourceGroupName MyLabResourceGroup1 ` -TemplateFile azuredeploy.json ` -TemplateParameterFile azuredeploy.parameters.json
New-AzResourceGroupDeployment
가 성공적으로 실행된 후 출력에는 프로비저닝 상태(succeeded
이어야 함), 템플릿의 모든 출력 등의 중요한 정보가 표시됩니다.
Azure PowerShell을 사용하여 아티팩트 리포지토리 추가
다음 샘플 PowerShell 스크립트 New-DevTestLabArtifactRepository.ps1은 아티팩트 리포지토리를 랩에 추가합니다. 전체 스크립트에는 몇 가지 자세한 메시지와 설명이 포함됩니다.
<#
.SYNOPSIS
This script creates a new custom repository and adds it to an existing DevTest Lab.
.PARAMETER LabName
The name of the lab.
.PARAMETER LabResourceGroupName
The name of the resource group that contains the lab.
.PARAMETER ArtifactRepositoryName
Name for the new artifact repository. The script creates a random name for the repository if not specified.
.PARAMETER ArtifactRepositoryDisplayName
Display name for the artifact repository.
This name appears in the list of artifact repositories for a lab.
.PARAMETER RepositoryUri
Uri to the artifact repository.
.PARAMETER RepositoryBranch
Branch that contains the artifact files. Defaults to 'main'.
.PARAMETER FolderPath
Folder that contains the artifact files. Defaults to '/Artifacts'
.PARAMETER PersonalAccessToken
Personal access token for the GitHub or Azure Repos repository.
.PARAMETER SourceType
Whether the artifact repository is a VSOGit (Azure Repos) or GitHub repository.
.EXAMPLE
Set-AzContext -SubscriptionId aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e
.\New-DevTestLabArtifactRepository.ps1 -LabName "mydevtestlab" -LabResourceGroupName "mydtlrg" -ArtifactRepositoryName "MyTeam Repository" -RepositoryUri "https://github.com/<myteam>/<nameofrepo>.git" -PersonalAccessToken "1111...." -SourceType "GitHub"
.NOTES
The script uses the current Azure context. To set the context, use Set-AzContext.
#>
[CmdletBinding()]
Param(
[Parameter(Mandatory=$true)]
$LabName,
[Parameter(Mandatory=$true)]
$LabResourceGroupName,
$ArtifactRepositoryName,
$ArtifactRepositoryDisplayName = 'Team Artifact Repository',
[Parameter(Mandatory=$true)]
$RepositoryUri,
$RepositoryBranch = 'main',
$FolderPath = '/Artifacts',
[Parameter(Mandatory=$true)]
$PersonalAccessToken ,
[Parameter(Mandatory=$true)]
[ValidateSet('VsoGit', 'GitHub')]
$SourceType
)
# Set artifact repository internal name if not specified.
if ($ArtifactRepositoryName -eq $null){
$ArtifactRepositoryName = "PrivateRepo" + (Get-Random -Maximum 999)
}
# Sign in to Azure.
Connect-AzAccount
#Get Lab Resource.
$LabResource = Get-AzResource -ResourceType 'Microsoft.DevTestLab/labs' -ResourceName $LabName -ResourceGroupName $LabResourceGroupName
Write-Verbose "Lab Name: $($LabResource.Name)"
Write-Verbose "Lab Resource Group Name: $($LabResource.ResourceGroupName)"
Write-Verbose "Lab Resource Location: $($LabResource.Location)"
Write-Verbose "Artifact Repository Internal Name: $ArtifactRepositoryName"
#Prepare properties object for the call to New-AzResource.
$propertiesObject = @{
uri = $RepositoryUri;
folderPath = $FolderPath;
branchRef = $RepositoryBranch;
displayName = $ArtifactRepositoryDisplayName;
securityToken = $PersonalAccessToken;
sourceType = $SourceType;
status = 'Enabled'
}
Write-Verbose "Properties to be passed to New-AzResource:$($propertiesObject | Out-String)"
#Add resource to the current subscription.
$resourcetype = 'Microsoft.DevTestLab/labs/artifactSources'
$resourceName = $LabName + '/' + $ArtifactRepositoryName
Write-Verbose "Az ResourceType: $resourcetype"
Write-Verbose "Az ResourceName: $resourceName"
Write-Verbose "Creating artifact repository '$ArtifactRepositoryDisplayName'..."
$result = New-AzResource -Location $LabResource.Location -ResourceGroupName $LabResource.ResourceGroupName -properties $propertiesObject -ResourceType $resourcetype -ResourceName $resourceName -ApiVersion 2016-05-15 -Force
#Alternate implementation:
# Use resourceId rather than resourcetype and resourcename parameters.
# Using resourceId lets you specify the $SubscriptionId rather than using the
# subscription id of Get-AzContext.
#$resourceId = "/subscriptions/$SubscriptionId/resourceGroups/$($LabResource.ResourceGroupName)/providers/Microsoft.DevTestLab/labs/$LabName/artifactSources/$ArtifactRepositoryName"
#$result = New-AzResource -properties $propertiesObject -ResourceId $resourceId -ApiVersion 2016-05-15 -Force
# Check the result.
if ($result.Properties.ProvisioningState -eq "Succeeded") {
Write-Verbose ("Successfully added artifact repository source '$ArtifactRepositoryDisplayName'")
}
else {
Write-Error ("Error adding artifact repository source '$ArtifactRepositoryDisplayName'")
}
#Return the newly created resource to use in later scripts.
return $result
매개 변수
PowerShell 스크립트는 다음 매개 변수를 사용합니다.
매개 변수 | 설명 |
---|---|
LabName |
랩의 이름입니다. |
ArtifactRepositoryName |
새 아티팩트 리포지토리의 이름입니다. 지정되지 않은 경우 스크립트는 리포지토리의 임의 이름을 만듭니다. |
ArtifactRepositoryDisplayName |
랩의 아티팩트 리포지토리 목록에 표시되는 표시 이름입니다. |
RepositoryUri |
이전에 복사한 아티팩트 리포지토리의 URI입니다. |
RepositoryBranch |
아티팩트가 포함된 리포지토리 분기입니다. 기본값은 main 입니다. |
FolderPath |
아티팩트가 포함된 폴더입니다. 기본값은 /Artifacts 입니다. |
PersonalAccessToken |
이전에 복사한 리포지토리에 액세스하기 위한 보안 토큰입니다. |
SourceType |
아티팩트 리포지토리가 VSOGit(Azure Repos) 또는 GitHub 리포지토리인지 여부입니다. |
리포지토리에는 식별을 위한 내부 이름이 필요하며, 이는 Azure Portal의 표시 이름과 다릅니다. 내부 이름은 Azure Portal을 사용할 때는 표시되지 않으며 Azure REST API 또는 Azure PowerShell을 사용할 때 표시됩니다. 배포 명령이 이름을 지정하지 않는 경우 스크립트는 임의 이름을 만듭니다.
#Set artifact repository name, if not set by user
if ($ArtifactRepositoryName -eq $null){
$ArtifactRepositoryName = "PrivateRepo" + (Get-Random -Maximum 999)
}
PowerShell 명령
스크립트는 다음 PowerShell 명령을 사용합니다.
명령 | 주의 |
---|---|
Get-AzResource | 랩에 관한 세부 정보(예: 해당 위치)를 가져옵니다. 랩과 동일한 위치 및 동일한 리소스 그룹에 아티팩트 리포지토리 원본을 만듭니다. |
New-AzResource | Azure 리소스를 추가합니다. 아티팩트 리포지토리를 추가하기 위한 특정 명령은 없습니다. 이 cmdlet은 만들 리소스 종류를 알기 위해 ResourceId 또는 ResourceName /ResourceType 쌍이 필요합니다. 현재 스크립트는 ResourceType 및 ResourceName 쌍을 사용합니다. |
리소스 이름 및 리소스 종류 정보를 검색하는 좋은 방법은 Azure REST API Browser 웹 사이트를 사용하는 것입니다. DevTest Labs 아티팩트 원본은 DevTest Labs 아티팩트 원본을 만들고 관리하기 위한 REST API를 보여 줍니다. 현재 스크립트는 다음 리소스 ID를 사용합니다.
https://management.azure.com/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DevTestLab/labs/{labName}/artifactsources/{name}
리소스 종류는 URI의 providers
뒤에 나열되는 모든 항목입니다(중괄호 안의 항목 제외). 리소스 이름은 중괄호 안에 있는 모든 항목입니다. 리소스 이름에 대한 항목을 두 개 이상 사용하는 경우 다음과 같이 각 항목을 슬래시로 구분합니다.
$resourcetype = 'Microsoft.DevTestLab/labs/artifactSources'
$resourceName = $LabName + '/' + $ArtifactRepositoryName
PowerShell 스크립트 실행
PowerShell 스크립트를 실행하여 LabName
, LabResourceGroupName
, ArtifactRepositoryName
, RepositoryUri
, PersonalAccessToken
, SourceType
의 예제 값을 고유한 값으로 대체합니다.
Set-AzContext -SubscriptionId <Your Azure subscription ID>
.\New-DevTestLabArtifactRepository.ps1 -LabName "mydevtestlab" -LabResourceGroupName "mydtlrg" -ArtifactRepositoryName "myteamrepository" -RepositoryUri "https://github.com/myteam/myteamrepository.git" - "1111...." -SourceType "GitHub"