다음을 통해 공유


자체 호스팅 macOS 에이전트

Azure DevOps Services | Azure DevOps Server 2022 - Azure DevOps Server 2019

이 문서에서는 Azure DevOps Services 및 현재 버전의 Azure DevOps Server와 함께 3.x 에이전트 소프트웨어 사용하기 위한 지침을 제공합니다. 3.x 에이전트를 지원하는 Azure DevOps Server 버전 목록은 "Azure DevOps Server가 3.x 에이전트를 지원하나요?" 부분을 참조하세요.

Xcode 앱을 빌드하고 배포하려면 하나 이상의 macOS 에이전트가 필요합니다. 이 에이전트는 Java 및 Android 앱을 빌드하고 배포할 수도 있습니다.

메모

이 문서에서는 자체 호스팅 에이전트구성하는 방법을 설명합니다. Azure DevOps Services를 사용 중이고 Microsoft가 호스팅하는 요원이 여러분의 필요를 충족하는 경우, 자체 호스팅 macOS 요원 설정을 건너뛸 수 있습니다.

에이전트에 대해 알아보기

에이전트가 무엇이고 어떻게 작동하는지 이미 알고 있는 경우 다음 섹션으로 바로 이동할 수 있습니다. 더 많은 정보가 필요하시면 Azure Pipelines 에이전트의 기능과 작동 방식에 대한 배경을 파악하시려면 을 참조하세요.

필수 구성 요소 확인

  • 지원되는 운영 체제
    • x64
      • macOS 10.15 "Catalina"
      • macOS 11.0 "Big Sur"
      • macOS 12.0 "Monterey"
      • macOS 13.0 "Ventura"
      • macOS 14.0 "Sonoma"
    • ARM64
      • macOS 11.0 "Big Sur"
      • macOS 12.0 "Monterey"
      • macOS 13.0 "Ventura"
      • macOS 14.0 "Sonoma"
  • Git - Git 2.9.0 이상(최신 버전 권장 - Homebrew사용하여 쉽게 설치할 수 있습니다.)
  • .NET - 에이전트 소프트웨어는 .NET 6에서 실행되지만 .NET 필수 구성 요소가 없도록 자체 버전의 .NET을 설치합니다.
  • TFVC - TFVC 리포지토리에서 빌드하는 경우 TFVC 필수 구성 요소를 참조하세요.

권한 설정 준비

Subversion 리포지토리에서 빌드하는 경우 컴퓨터에 Subversion 클라이언트를 설치해야 합니다.

에이전트 설치 프로그램을 처음 수동으로 실행해야 합니다. 에이전트가 어떻게 작동하는지 이해하거나 많은 에이전트를 설정하는 작업을 자동화하려는 경우, 무인 설정사용하는 것을 고려해 보세요.

자체 호스팅 에이전트에 대한 정보 보안

에이전트를 구성하는 사용자에게는 풀 관리자 권한이 필요하지만 에이전트를 실행하는 사용자는 그렇지 않습니다.

에이전트에서 제어하는 폴더에는 암호 해독 또는 유출될 수 있는 비밀이 포함되어 있으므로 가능한 한 적은 수의 사용자로 제한해야 합니다.

Azure Pipelines 에이전트는 외부 원본에서 다운로드하는 코드를 실행하도록 설계된 소프트웨어 제품입니다. 기본적으로 RCE(원격 코드 실행) 공격의 대상이 될 수 있습니다.

따라서 작업을 수행하기 위해 파이프라인 에이전트의 각 개별 사용에 대한 위협 모델을 고려하여, 에이전트를 실행하는 사용자, 에이전트가 실행되는 기기, 파이프라인 정의에 대한 쓰기 액세스가 있는 사용자, YAML이 저장된 git 리포지토리, 그리고 새 파이프라인을 위한 풀에 대한 액세스를 통제하는 사용자 그룹에게 부여할 수 있는 최소 권한을 결정하는 것이 중요합니다.

에이전트를 실행하는 ID가 에이전트를 풀에 연결할 수 있는 권한이 있는 ID와 달라지도록 하는 것이 가장 좋습니다. 자격 증명(및 기타 에이전트 관련 파일)을 생성하는 사용자는 자격 증명을 읽어야 하는 사용자와 다릅니다. 따라서 에이전트 컴퓨터 자체에 부여된 액세스 권한과 로그 및 아티팩트와 같은 중요한 파일이 포함된 에이전트 폴더를 신중하게 고려하는 것이 더 안전합니다.

DevOps 관리자 및 에이전트 프로세스를 실행하는 사용자 ID에 대해서만 에이전트 폴더에 대한 액세스 권한을 부여하는 것이 좋습니다. 관리자는 파일 시스템을 조사하여 빌드 실패를 이해하거나 로그 파일을 가져와서 Azure DevOps 오류를 보고해야 할 수 있습니다.

사용할 사용자 결정

일회성 단계로 에이전트를 등록해야 합니다. 에이전트 큐 을(를) 관리할 수 있는 권한이 있는 사용자는 다음 단계를 완료해야 합니다. 에이전트는 일상적인 작업에서 이 사용자의 자격 증명을 사용하지 않지만 등록을 완료해야 합니다. 에이전트가 통신하는 방법 에 대해자세히 알아봅니다.

사용자에게 사용 권한이 있는지 확인

사용하려는 사용자 계정에 에이전트를 등록할 수 있는 권한이 있는지 확인합니다.

사용자가 Azure DevOps 조직 소유자 또는 TFS 또는 Azure DevOps Server 관리자인가요? 여기서 중지하십시오허가가 되었습니다.

그렇지 않으면:

  1. 브라우저를 열고 Azure Pipelines 조직 또는 Azure DevOps Server 또는 TFS 서버에 대한 에이전트 풀 탭으로 이동합니다.

    1. 조직(https://dev.azure.com/{yourorganization})에 로그인하세요.

    2. Azure DevOps, 조직 설정을 선택합니다.

      조직 설정을 선택합니다.

    3. 에이전트 풀 중에서을 선택하세요.

      에이전트 풀 탭을 선택하세요.

    1. 프로젝트 컬렉션(http://your-server/DefaultCollection)에 로그인합니다.

    2. Azure DevOps컬렉션 설정선택합니다.

      컬렉션 설정을 선택합니다.

    3. 에이전트 풀 을 선택합니다.

      에이전트 풀을 선택합니다.

    1. Azure DevOps, 컬렉션 설정을 선택합니다.

      컬렉션 설정, 2019.

    2. 에이전트 풀 을(를) 선택합니다.

      에이전트 풀 선택, 2019.

  2. 페이지 오른쪽의 풀을 선택한 다음, 보안을 클릭합니다.

  3. 사용하려는 사용자 계정이 표시되지 않으면 관리자에게 추가해 달라고 요청하세요. 관리자는 에이전트 풀 관리자, Azure DevOps 조직 소유자또는 TFS 또는 Azure DevOps Server 관리자수 있습니다.

    배포 그룹 에이전트인 경우 관리자는 배포 그룹 관리자, Azure DevOps 조직 소유자또는 TFS 또는 Azure DevOps Server 관리자수 있습니다.

    Azure Pipelines배포 그룹 페이지의 보안 탭에서 배포 그룹 관리자 역할에 사용자를 추가할 수 있습니다.

메모

다음과 같은 메시지가 표시되는 경우: 죄송합니다, ID를 추가할 수 없습니다. 다른 ID를 사용해 보세요., 이는 아마도 조직 소유자 또는 TFS 또는 Azure DevOps Server 관리자를 위해 앞서 설명한 단계를 따랐기 때문일 것입니다. 아무 것도 할 필요가 없습니다. 에이전트 풀을 관리할 수 있는 권한이 이미 있습니다.

에이전트 다운로드 및 구성

Azure Pipelines

  1. 이전 섹션에서 설명한 대로 사용 권한을 준비한 계정을 사용하여 컴퓨터에 로그온합니다.

  2. 웹 브라우저에서 Azure Pipelines에 로그인하고 에이전트 풀 탭으로 이동합니다.

    1. 조직(https://dev.azure.com/{yourorganization})에 로그인하세요.

    2. Azure DevOps, 조직 설정을 선택하십시오.

      조직 설정을 선택합니다.

    3. 에이전트 풀을 선택합니다.

      에이전트 풀 탭을 선택하세요.

    1. 프로젝트 컬렉션(http://your-server/DefaultCollection)에 로그인합니다.

    2. Azure DevOps컬렉션 설정선택합니다.

      컬렉션 설정을 선택합니다.

    3. 에이전트 풀을 선택합니다.

      에이전트 풀을 선택합니다.

    1. Azure DevOps컬렉션 설정선택합니다.

      컬렉션 설정, 2019.

    2. 에이전트 풀을 선택합니다.

      에이전트 풀 선택, 2019.

  3. 기본 풀을 선택하고 에이전트 탭을 선택한 다음 새 에이전트를 선택합니다.

  4. 에이전트 가져오기 대화 상자에서 macOS클릭합니다.

  5. 다운로드 단추를 클릭하세요.

  6. 페이지의 지침을 따릅니다.

  7. tar 파일에서 확장된 특성을 지우세요. xattr -c vsts-agent-osx-x64-V.v.v.tar.gz.

  8. 선택한 디렉터리에 에이전트의 압축을 풉니다. 그 디렉터리에 cd를 이동하여 ./config.sh을 실행합니다. 도구와 스크립트가 항상 공백을 제대로 이스케이프하지는 않으므로 디렉터리의 경로에 공백이 포함되어 있지 않은지 확인합니다.

서버 URL

Azure Pipelines: https://dev.azure.com/{your-organization}

Azure DevOps Server: https://{your_server}/tfs

인증 유형

에이전트를 등록할 때 다음 인증 유형 중에서 선택하면 에이전트 설정에서 각 인증 유형에 필요한 특정 추가 정보를 묻는 메시지를 표시합니다. 자세한 내용은 자체 호스팅 에이전트 인증 옵션을 참조하세요.

대화형으로 실행

대화형 모드 또는 서비스로 에이전트를 실행할지 여부에 대한 지침은 에이전트: 대화형 및 서비스참조하세요.

에이전트를 대화형으로 실행하려면 다음을 수행합니다.

  1. 에이전트를 서비스로 실행한 경우 서비스를제거하십시오.

  2. 에이전트를 실행합니다.

    ./run.sh
    

에이전트를 다시 시작하려면 Ctrl+C를 누른 다음 run.sh 실행하여 다시 시작합니다.

에이전트를 사용하려면, 에이전트의 풀을 사용하여 작업을 실행해야 합니다. 다른 풀을 선택하지 않은 경우 에이전트가 기본 풀에 배치됩니다.

한 번 실행

대화형으로 실행하도록 구성된 에이전트의 경우 에이전트가 하나의 작업만 허용하도록 선택할 수 있습니다. 이 구성에서 실행하려면 다음을 수행합니다.

./run.sh --once

이 모드의 에이전트는 하나의 작업만 허용한 다음 정상적으로 스핀다운합니다(Azure Container Instances와 같은 서비스에서 실행하는 데 유용).

launchd 서비스로 실행

에이전트를 launchd LaunchAgent 서비스로 실행하고 관리할 수 있는 ./svc.sh 스크립트를 제공합니다. 이 스크립트는 에이전트를 구성한 후에 생성됩니다. 서비스는 UI 테스트를 실행하기 위해 UI에 액세스할 수 있습니다.

메모

다른 방법을 선호하는 경우 원하는 서비스 메커니즘을 사용할 수 있습니다. 서비스 파일참조하세요.

토큰

다음 섹션에서는 이러한 토큰이 바뀝니다.

  • {agent-name}

  • {tfs-name}

예를 들어 이름 our-osx-agent사용하여 에이전트를 구성했습니다(이전 예제와 같이). 다음 예제들에서, {tfs-name}는 다음 중 하나일 수 있습니다.

  • Azure Pipelines: 조직의 이름입니다. 예를 들어 https://dev.azure.com/fabrikam에 연결하면 서비스 이름은 vsts.agent.fabrikam.our-osx-agent입니다.

  • TFS: 온-프레미스 TFS AT 서버의 이름입니다. 예를 들어 http://our-server:8080/tfs에 연결하면, 서비스 이름은 vsts.agent.our-server.our-osx-agent입니다.

명령

에이전트 목록으로 이동

예를 들어 홈 디렉터리의 myagent 하위 폴더에 설치한 경우:

cd ~/myagent$

설치하다

명령:

./svc.sh install

이 명령은 ./runsvc.sh가리키는 launchd plist를 만듭니다. 이 스크립트는 환경(다음 섹션의 자세한 내용)을 설정하고 에이전트의 호스트를 시작합니다.

시작

명령:

./svc.sh start

출력:

starting vsts.agent.{tfs-name}.{agent-name}
status vsts.agent.{tfs-name}.{agent-name}:

/Users/{your-name}/Library/LaunchAgents/vsts.agent.{tfs-name}.{agent-name}.plist

Started:
13472 0 vsts.agent.{tfs-name}.{agent-name}

서비스가 실행 중인 경우 왼쪽 번호는 pid입니다. 두 번째 숫자가 0이 아니면 문제가 발생했습니다.

상태

명령:

./svc.sh status

출력:

status vsts.agent.{tfs-name}.{agent-name}:

/Users/{your-name}/Library/LaunchAgents/vsts.{tfs-name}.{agent-name}.testsvc.plist

Started:
13472 0 vsts.agent.{tfs-name}.{agent-name}

서비스가 실행 중인 경우 왼쪽 번호는 pid입니다. 두 번째 숫자가 0이 아니면 문제가 발생했습니다.

멈춰

명령:

./svc.sh stop

출력:

stopping vsts.agent.{tfs-name}.{agent-name}
status vsts.agent.{tfs-name}.{agent-name}:

/Users/{your-name}/Library/LaunchAgents/vsts.{tfs-name}.{agent-name}.testsvc.plist

Stopped

제거

제거하기 전에 중지해야 합니다.

명령:

./svc.sh uninstall

자동 로그인 및 잠금

일반적으로 에이전트 서비스는 사용자가 로그인한 후에만 실행됩니다. 컴퓨터가 다시 시작될 때 에이전트 서비스가 자동으로 시작되도록 하려면 컴퓨터를 자동으로 로그인하고 시작에 잠그도록 구성할 수 있습니다. 시작 중에 자동으로 로그인하도록 Mac 설정 - Apple 지원참조하세요.

메모

자세한 내용은 Terminally Geeky: 자동 로그인을 더 안전하게 사용하는 방법 블로그를 참조하세요. 해당 블로그에 언급된 .plist 파일은 더 이상 원본에서 사용할 수 없지만, 사본을 여기에서 찾을 수 있습니다: Lifehacker - 로그인하기 전에 OS X가 데스크톱을 로드하도록 설정합니다.

환경 변수 업데이트

서비스를 구성할 때 PATH, LANG, JAVA_HOME, ANT_HOME 및 MYSQL_PATH 같은 현재 로그온 사용자에 대한 몇 가지 유용한 환경 변수의 스냅샷을 만듭니다. 변수를 업데이트해야 하는 경우(예: 새 소프트웨어를 설치한 후)

./env.sh
./svc.sh stop
./svc.sh start

환경 변수의 스냅샷은 에이전트 루트 디렉터리의 .env 파일에 저장되며, 환경 변수 변경 내용을 적용하도록 해당 파일을 직접 변경할 수도 있습니다.

서비스가 시작되기 전에 지침 실행

또한 서비스가 시작될 때 실행하기 위해 사용자 고유의 지침과 명령을 실행할 수 있습니다. 예를 들어 환경을 설정하거나 스크립트를 호출할 수 있습니다.

  1. runsvc.sh편집합니다.

  2. 다음 줄을 설명으로 바꿉니다.

    # insert anything to setup env when running as a service
    

서비스 파일

서비스를 설치하면 일부 서비스 파일이 배치됩니다.

.plist 서비스 파일

.plist 서비스 파일이 만들어집니다.

~/Library/LaunchAgents/vsts.agent.{tfs-name}.{agent-name}.plist

예를 들어:

~/Library/LaunchAgents/vsts.agent.fabrikam.our-osx-agent.plist

./svc.sh install 이 템플릿에서 이 파일을 생성합니다. ./bin/vsts.agent.plist.template

.service 파일

./svc.sh start 위에서 설명한 plist 서비스 파일의 경로를 포함하는 .service 파일을 읽어 서비스를 찾습니다.

대체 서비스 메커니즘

launchd LaunchAgent 서비스로 에이전트를 실행하고 관리할 수 있는 편리한 방법으로 ./svc.sh 스크립트를 제공합니다. 그러나 원하는 서비스 메커니즘을 사용할 수 있습니다.

위에서 설명한 템플릿을 사용하여 다른 종류의 서비스 파일을 쉽게 생성할 수 있습니다. 예를 들어 UI 테스트가 필요하지 않고 자동 로그온 및 잠금을 구성하지 않으려는 경우 시작 디먼으로 실행되는 서비스를 생성하도록 템플릿을 수정합니다. Apple 개발자 라이브러리: 런치 디먼 및 에이전트 생성을 참조하세요.

에이전트 바꾸기

에이전트를 바꾸려면 다운로드를 수행하고 에이전트 단계를 다시 구성합니다.

이미 존재하는 에이전트와 동일한 이름을 사용하여 에이전트를 구성하는 경우 기존 에이전트를 바꿀 것인지 묻는 메시지가 표시됩니다. Y에 대답하는 경우, 대체하려는 에이전트를(아래 참조) 반드시 제거해야 합니다. 그렇지 않으면 몇 분 동안 충돌이 발생하면 에이전트 중 하나가 종료됩니다.

에이전트 제거 및 다시 구성

에이전트를 제거하려면 다음을 수행합니다.

  1. 이전 섹션에서 설명한 대로 서비스를 중지하고 제거합니다.

  2. 에이전트를 제거합니다.

    ./config.sh remove
    
  3. 자격 증명을 입력합니다.

에이전트를 제거한 후다시 구성할 있습니다.

무인 설정

에이전트는 사람의 개입 없이 스크립트에서 설정할 수 있습니다. --unattended 및 모든 질문에 대한 답변을 통과해야 합니다.

에이전트를 구성하려면, 조직 또는 컬렉션의 URL과 에이전트를 설정할 권한이 있는 사용자의 자격 증명을 알고 있어야 합니다. 다른 모든 응답은 선택 사항입니다. 대신 환경 변수를 사용하여 명령줄 매개 변수를 지정할 수 있습니다. 대문자로 이름을 입력하고 VSTS_AGENT_INPUT_앞에 추가합니다. 예를 들어 --password을 지정하는 대신 VSTS_AGENT_INPUT_PASSWORD을 사용합니다.

필수 옵션

  • --unattended - 에이전트 설정에서 정보를 입력하라는 메시지가 표시되지 않으며 명령줄에 모든 설정을 제공해야 합니다.
  • --url <url> - 서버의 URL입니다. 예: https://dev.azure.com/myorganization 또는 http://my-azure-devops-server:8080/tfs
  • --auth <type> - 인증 유형입니다. 유효한 값은 다음과 같습니다.
    • pat(개인용 액세스 토큰) - PAT는 Azure DevOps Services에서 작동하는 유일한 체계입니다.
    • alt(기본 인증)

인증 옵션

  • --auth pat선택한 경우:
    • --token <token> - 개인용 액세스 토큰 지정
    • PAT는 Azure DevOps Services에서 작동하는 유일한 체계입니다.
  • --auth negotiate 또는 --auth alt을 선택한 경우:
    • --userName <userName> - 사용자 이름 지정
    • --password <password> - 암호 지정

풀 및 에이전트 이름

  • --pool <pool> - 조인할 에이전트의 풀 이름
  • --agent <agent> - 에이전트 이름
  • --replace - 풀에서 에이전트를 대체합니다. 다른 에이전트가 같은 이름으로 신호를 수신하고 있는 경우, 충돌로 인해 실행이 실패하기 시작합니다.

에이전트 설정

  • --work <workDirectory> - 작업 데이터가 저장되는 작업 디렉터리입니다. 기본적으로 에이전트 디렉터리의 루트 아래에 _work으로 설정됩니다. 작업 디렉터리가 지정된 에이전트에 의해 소유되며 여러 에이전트 간에 공유해서는 안 됩니다.
  • --acceptTeeEula - Team Explorer Everywhere 최종 사용자 라이선스 계약 수락(macOS 및 Linux만 해당)
  • --disableloguploads - 서버로 콘솔 로그 출력을 스트리밍하거나 보내지 마세요. 대신 작업이 완료된 후 에이전트 호스트의 파일 시스템으로부터 검색할 수 있습니다.

배포 그룹만

  • --deploymentGroup - 에이전트를 배포 그룹 에이전트로 구성
  • --deploymentGroupName <name> - --deploymentGroup 함께 사용하여 에이전트가 조인할 배포 그룹을 지정합니다.
  • --projectName <name> - --deploymentGroup 사용하여 프로젝트 이름 설정
  • --addDeploymentGroupTags - --deploymentGroup 함께 배포 그룹 태그를 추가해야 함을 나타내는 데 사용됩니다.
  • --deploymentGroupTags <tags> - 배포 그룹 에이전트에 대한 쉼표로 구분된 태그 목록을 지정하기 위해 --addDeploymentGroupTags 함께 사용됩니다(예: "web, db").

환경만

  • --addvirtualmachineresourcetags - 환경 리소스 태그를 추가해야 함을 나타내는 데 사용됩니다.
  • --virtualmachineresourcetags <tags> - 환경 리소스 에이전트에 대한 쉼표로 구분된 태그 목록을 지정하기 위해 --addvirtualmachineresourcetags 함께 사용됩니다(예: "web, db").

./config.sh --help 항상 최신 필수 및 선택적 응답을 나열합니다.

진단

자체 호스팅 에이전트에 문제가 있는 경우 진단을 실행해 볼 수 있습니다. 에이전트를 구성한 후:

./run.sh --diagnostics

이 작업은 문제 해결에 도움이 될 수 있는 진단 제품군을 통해 실행됩니다. 진단 기능은 에이전트 버전 2.165.0부터 사용할 수 있습니다.

자체 호스팅 에이전트에 대한 네트워크 진단

Agent.Diagnostic 값을 true로 설정하여 자체 호스팅 에이전트의 네트워크 문제를 해결할 수 있는 추가 로그를 수집합니다. 자세한 내용은 자체 호스팅 에이전트대한 네트워크 진단을 참조하세요.

다른 옵션에 대한 도움말

다른 옵션에 대해 알아보려면 다음을 수행합니다.

./config.sh --help

이 도움말은 인증 대안 및 무인 구성에 대한 정보를 제공합니다.

기능

에이전트의 기능은 풀에서 카탈로그화되고 보급되므로 처리할 수 있는 빌드 및 릴리스만 할당됩니다. 빌드 및 릴리스 에이전트 기능을 참조하세요.

대부분의 경우 에이전트를 배포한 후 소프트웨어 또는 유틸리티를 설치해야 합니다. 일반적으로 개발 머신에서 사용하는 소프트웨어와 도구는 에이전트에 설치해야 합니다.

예를 들어 빌드에 npm 작업포함된 경우 npm이 설치된 풀에 빌드 에이전트가 없는 한 빌드가 실행되지 않습니다.

중요하다

기능에는 모든 환경 변수와 에이전트가 실행되면 설정된 값이 포함됩니다. 에이전트가 실행되는 동안 이러한 값이 변경되면 에이전트를 다시 시작하여 새 값을 선택해야 합니다. 에이전트에 새 소프트웨어를 설치한 후에는 빌드를 실행할 수 있도록 새 기능이 풀에 표시되도록 에이전트를 다시 시작해야 합니다.

환경 변수를 기능으로 제외하려면 무시할 쉼표로 구분된 변수 목록을 사용하여 환경 변수 VSO_AGENT_IGNORE 설정하여 지정할 수 있습니다.

자주 묻는 질문(FAQ)

최신 에이전트 버전이 있는지 확인하려면 어떻게 해야 하나요?

  1. 에이전트 풀 탭으로 이동하세요.

    1. 조직(https://dev.azure.com/{yourorganization})에 로그인하세요.

    2. Azure DevOps에서 , 조직 설정에서 를 선택합니다.

      조직 설정을 선택합니다.

    3. 에이전트 풀을 선택합니다.

      에이전트 풀 탭을 선택하십시오.

    1. 프로젝트 컬렉션(http://your-server/DefaultCollection)에 로그인합니다.

    2. Azure DevOps컬렉션 설정선택합니다.

      컬렉션 설정을 선택합니다.

    3. 에이전트 풀를 선택합니다.

      에이전트 풀을 선택합니다.

    1. Azure DevOps컬렉션 설정선택합니다.

      컬렉션 설정, 2019.

    2. 에이전트 풀 을 선택합니다.

      에이전트 풀 선택, 2019.

  2. 에이전트가 포함된 풀을 클릭합니다.

  3. 에이전트가 사용하도록 설정되어 있는지 확인합니다.

  4. 기능 탭으로 이동합니다.

    1. 에이전트 풀 탭에서 원하는 에이전트 풀을 선택합니다.

      에이전트 풀에서 원하는 에이전트 풀을 선택합니다.

    2. 에이전트을 탭하고, 원하는 에이전트를 선택합니다.

      에이전트를 선택하고 에이전트를 지정합니다.

    3. 기능 탭을 선택합니다.

      기능 탭을 선택합니다.

      메모

      Microsoft 호스팅 에이전트는 시스템 기능을 표시하지 않습니다. Microsoft 호스팅 에이전트에 설치된 소프트웨어 목록은 Microsoft 호스팅 에이전트에서 확인하세요.

    1. 에이전트 풀 탭에서 원하는 풀을 선택합니다.

      원하는 풀을 선택합니다.

    2. 에이전트을 선택한 후 원하는 에이전트를 고릅니다.

      에이전트 목록을 선택하고 원하는 에이전트를 지정합니다.

    3. 기능 탭을 선택합니다.

      에이전트 기능 탭.

    1. 에이전트 풀 탭에서 원하는 풀을 선택합니다.

      원하는 탭 선택, 2019.

    2. 에이전트을 선택하고 원하는 에이전트를 고릅니다.

      원하는 에이전트 선택, 2019.

    3. 기능 탭을 선택합니다.

      기능 탭 선택, 2019.

  5. Agent.Version 기능을 찾습니다. 최신 게시된 에이전트 버전에 대해 이 값을 확인할 수 있습니다. Azure Pipelines 에이전트 을 참조하고, 나열된 가장 높은 버전 번호를 페이지에서 확인합니다.

  6. 각 에이전트는 최신 버전의 에이전트가 필요한 작업을 실행할 때 자동으로 업데이트됩니다. 일부 에이전트를 수동으로 업데이트하려면 풀을 마우스 오른쪽 단추로 클릭하고 모든 에이전트 업데이트선택합니다.

Azure DevOps Server 풀의 일부인 에이전트를 업데이트할 수 있나요?

예. Azure DevOps Server 2019부터 로컬 디스크에서 에이전트 패키지 파일을 찾도록 서버를 구성할 수 있습니다. 이 구성은 릴리스 당시 서버와 함께 제공된 기본 버전을 재정의합니다. 이 시나리오는 서버에 인터넷에 액세스할 수 없는 경우에도 적용됩니다.

  1. 인터넷에 액세스할 수 있는 컴퓨터에서 Azure Pipelines 에이전트 GitHub 릴리스 페이지최신 버전의 에이전트 패키지 파일(.zip 또는 .tar.gz 형식)을 다운로드합니다.

  2. 선택한 방법(예: USB 드라이브, 네트워크 전송 등)을 사용하여 다운로드한 패키지 파일을 각 Azure DevOps 서버 애플리케이션 계층으로 전송합니다. 에이전트 파일을 다음 폴더 아래에 배치합니다.

  • Windows: %ProgramData%\Microsoft\Azure DevOps\Agents
  • Linux: usr/share/Microsoft/Azure DevOps/Agents
  • macOS: usr/share/Microsoft/Azure DevOps/Agents

Agents 폴더가 없으면 만듭니다.

  1. 준비 완료되었습니다! 이제 Azure DevOps Server는 에이전트가 업데이트될 때마다 로컬 파일을 사용합니다. 각 에이전트는 최신 버전의 에이전트가 필요한 작업을 실행할 때 자동으로 업데이트됩니다. 그러나 일부 에이전트를 수동으로 업데이트하려면 풀을 마우스 오른쪽 단추로 클릭한 다음 모든 에이전트 업데이트를 선택합니다.

최신 에이전트 버전이 있는지 확인하려면 어떻게 해야 하나요?

  1. 에이전트 풀 탭으로 이동하십시오.

    1. 조직(https://dev.azure.com/{yourorganization})에 로그인하세요.

    2. Azure DevOps, 조직 설정선택합니다.

      조직 설정을 선택합니다.

    3. 에이전트 풀을 선택합니다.

      에이전트 풀 탭을 선택하세요.

    1. 프로젝트 컬렉션(http://your-server/DefaultCollection)에 로그인합니다.

    2. Azure DevOps, 컬렉션 설정을 선택합니다.

      컬렉션 설정을 선택합니다.

    3. 에이전트 풀을 선택한 다음을 선택합니다.

      에이전트 풀을 선택합니다.

    1. Azure DevOps 를 선택하고, 컬렉션 설정을 선택합니다.

      컬렉션 설정, 2019.

    2. 에이전트 풀을 선택합니다.

      에이전트 풀 선택, 2019.

  2. 에이전트가 포함된 풀을 클릭하세요.

  3. 에이전트가 활성화되어 있는지 확인하세요.

  4. 기능 탭으로 이동합니다.

    1. 에이전트 풀 탭에서 원하는 에이전트 풀을 선택합니다.

      에이전트 풀에서 원하는 에이전트 풀을 선택합니다.

    2. 에이전트 선택하고 원하는 에이전트를 선택합니다.

    3. 기능 탭을 선택합니다.

      기능 탭을 선택합니다.

      메모

      Microsoft 호스팅 에이전트는 시스템 기능을 표시하지 않습니다. Microsoft 호스팅 에이전트에 설치된 소프트웨어 목록은 Microsoft 호스팅 에이전트 사용을 참고하세요.

    1. 에이전트 풀 탭에서 원하는 풀을 선택합니다.

      원하는 풀을 선택합니다.

    2. 에이전트을 선택한 후 원하는 에이전트를 고르세요.

      에이전트를 선택합니다. 원하는 에이전트를 고르십시오.

    3. 기능 탭을 선택합니다.

      에이전트 기능 탭.

    1. 에이전트 풀 탭에서 원하는 풀을 선택합니다.

      원하는 탭 선택, 2019.

    2. 에이전트 및을(를) 선택한 후 원하는 에이전트를 고릅니다.

      원하는 에이전트 선택, 2019.

    3. 기능 탭을 선택합니다.

      기능 탭 선택, 2019.

  5. Agent.Version 기능을 찾으세요. 최신 게시된 에이전트 버전에 대해 이 값을 확인할 수 있습니다. Azure Pipelines 에이전트를 참조하고, 나열된 가장 높은 버전 번호의 페이지를 확인합니다.

  6. 각 에이전트는 최신 버전의 에이전트가 필요한 작업을 실행할 때 자동으로 업데이트됩니다. 일부 에이전트를 수동으로 업데이트하려면 에이전트 풀을 마우스 오른쪽 단추로 클릭하고 모든 에이전트 업데이트선택합니다.

Azure DevOps Server 풀의 일부인 에이전트를 업데이트할 수 있나요?

예. Azure DevOps Server 2019부터 로컬 디스크에서 에이전트 패키지 파일을 찾도록 서버를 구성할 수 있습니다. 이 구성은 릴리스 당시 서버와 함께 제공된 기본 버전을 재정의합니다. 이 시나리오는 서버에 인터넷에 액세스할 수 없는 경우에도 적용됩니다.

  1. 인터넷에 액세스할 수 있는 컴퓨터에서 Azure Pipelines 에이전트 GitHub 릴리스 페이지최신 버전의 에이전트 패키지 파일(.zip 또는 .tar.gz 형식)을 다운로드합니다.

  2. 선택한 방법(예: USB 드라이브, 네트워크 전송 등)을 사용하여 다운로드한 패키지 파일을 각 Azure DevOps 서버 애플리케이션 계층으로 전송합니다. 에이전트 파일을 다음 폴더 아래에 배치합니다.

  • Windows: %ProgramData%\Microsoft\Azure DevOps\Agents
  • Linux: usr/share/Microsoft/Azure DevOps/Agents
  • macOS: usr/share/Microsoft/Azure DevOps/Agents

Agents 폴더가 없는 경우 만들어 주십시오.

  1. 모든 준비가 완료되었습니다! 이제 Azure DevOps Server는 에이전트가 업데이트될 때마다 로컬 파일을 사용합니다. 각 에이전트는 최신 버전의 에이전트가 필요한 작업을 실행할 때 자동으로 업데이트됩니다. 그러나 일부 에이전트를 수동으로 업데이트하려면 에이전트 풀을 마우스 오른쪽 단추로 클릭한 다음 모든 에이전트 업데이트를선택합니다.

시작 서비스가 작동하는 방식에 대한 자세한 내용은 어디에서 확인할 수 있나요?

Apple 개발자 라이브러리: 디먼 및 에이전트 시작하기

방화벽을 실행하고 있으며 내 코드는 Azure Repos에 있습니다. 에이전트가 통신해야 하는 URL은 무엇인가요?

방화벽 뒤의 보안 네트워크에서 에이전트를 실행하는 경우 에이전트가 다음 URL 및 IP 주소와의 통신을 시작할 수 있는지 확인합니다.

도메인 URL 묘사
https://{organization_name}.pkgs.visualstudio.com {organization_name}.visualstudio.com 도메인을 사용하는 조직을 위한 Azure DevOps 패키징 API
https://{organization_name}.visualstudio.com {organization_name}.visualstudio.com 도메인을 사용하는 조직의 경우
https://{organization_name}.vsblob.visualstudio.com {organization_name}.visualstudio.com 도메인을 사용하는 조직을 위한 Azure DevOps 원격 분석
https://{organization_name}.vsrm.visualstudio.com {organization_name}.visualstudio.com 도메인을 사용하는 조직을 위한 릴리스 관리 서비스
https://{organization_name}.vssps.visualstudio.com {organization_name}.visualstudio.com 도메인을 사용하는 조직을 위한 Azure DevOps Platform Services
https://{organization_name}.vstmr.visualstudio.com {organization_name}.visualstudio.com 도메인을 사용하는 조직을 위한 Azure DevOps 테스트 관리 서비스
https://*.blob.core.windows.net Azure Artifacts
https://*.dev.azure.com dev.azure.com 도메인을 사용하는 조직의 경우
https://*.vsassets.io CDN을 통한 Azure Artifacts
https://*.vsblob.visualstudio.com dev.azure.com 도메인을 사용하는 조직을 위한 Azure DevOps 원격 분석
https://*.vssps.visualstudio.com dev.azure.com 도메인을 사용하는 조직을 위한 Azure DevOps Platform Services
https://*.vstmr.visualstudio.com dev.azure.com 도메인을 사용하는 조직을 위한 Azure DevOps 테스트 관리 서비스
https://app.vssps.visualstudio.com {organization_name}.visualstudio.com 도메인을 사용하는 조직의 경우
https://dev.azure.com dev.azure.com 도메인을 사용하는 조직의 경우
https://login.microsoftonline.com Microsoft Entra 로그인
https://management.core.windows.net Azure 관리 API
https://vstsagentpackage.azureedge.net 에이전트 패키지

조직이 기존 방화벽 또는 IP 제한 사항과 함께 작동하도록 하려면 dev.azure.com*dev.azure.com 열려 있는지 확인하고 IP 버전에 따라 다음 IP 주소를 포함하도록 허용 목록에 있는 IP를 업데이트합니다. 현재 13.107.6.18313.107.9.183 IP 주소를 허용 목록에 포함하고 있다면, 제거할 필요 없이 그대로 두세요.

IPv4 범위

  • 13.107.6.0/24
  • 13.107.9.0/24
  • 13.107.42.0/24
  • 13.107.43.0/24

IPv6 범위

  • 2620:1ec:4::/48
  • 2620:1ec:a92::/48
  • 2620:1ec:21::/48
  • 2620:1ec:22::/48

메모

허용된 주소에 대한 자세한 내용은 허용된 주소 목록 및네트워크 연결을 참조하세요.

자체 서명된 인증서를 사용하여 에이전트를 실행하려면 어떻게 해야 하나요?

자체 서명된 인증서 사용하여 에이전트 실행

웹 프록시 뒤에서 에이전트를 실행하려면 어떻게 해야 하나요?

웹 프록시 뒤에서 에이전트 실행

에이전트를 다시 시작하는 방법

에이전트를 대화형으로 실행하는 경우 대화형 실행의 다시 시작 지침을 참고하세요. 에이전트를 서비스로 실행하는 경우 단계에 따라 중지를 에이전트 시작합니다.

웹 프록시를 무시하고 Azure Pipelines에 연결하도록 에이전트를 구성하려면 어떻게 해야 하나요?

에이전트가 프록시를 우회하고 Azure Pipelines에 직접 연결하도록 하려면 에이전트가 다음 URL에 액세스할 수 있도록 웹 프록시를 구성해야 합니다.

*.visualstudio.com 도메인을 사용하는 조직의 경우:

https://login.microsoftonline.com
https://app.vssps.visualstudio.com 
https://{organization_name}.visualstudio.com
https://{organization_name}.vsrm.visualstudio.com
https://{organization_name}.vstmr.visualstudio.com
https://{organization_name}.pkgs.visualstudio.com
https://{organization_name}.vssps.visualstudio.com

dev.azure.com 도메인을 사용하는 조직의 경우:

https://dev.azure.com
https://*.dev.azure.com
https://login.microsoftonline.com
https://management.core.windows.net
https://vstsagentpackage.azureedge.net
https://vssps.dev.azure.com

조직이 기존 방화벽 또는 IP 제한 사항과 함께 작동하도록 하려면 dev.azure.com*dev.azure.com 열려 있는지 확인하고 IP 버전에 따라 다음 IP 주소를 포함하도록 허용 목록에 있는 IP를 업데이트합니다. 현재 13.107.6.18313.107.9.183 IP 주소를 허용 목록에 포함하고 있다면, 제거할 필요가 없으므로 그대로 두십시오.

IPv4 범위

  • 13.107.6.0/24
  • 13.107.9.0/24
  • 13.107.42.0/24
  • 13.107.43.0/24

IPv6 범위

  • 2620:1ec:4::/48
  • 2620:1ec:a92::/48
  • 2620:1ec:21::/48
  • 2620:1ec:22::/48

메모

이 절차를 통해 에이전트는 웹 프록시를 바이패스할 수 있습니다. 빌드 파이프라인 및 스크립트는 빌드 과정에서 실행하는 각 작업과 도구에 대해 웹 프록시를 우회하는 것을 처리해야 합니다.

예를 들어 NuGet 작업을 사용하는 경우 사용 중인 NuGet 피드를 호스트하는 서버의 URL 무시를 지원하도록 웹 프록시를 구성해야 합니다.

TFS를 사용하고 있으며 위 섹션의 URL이 작동하지 않습니다. 어디에서 도움을 받을 수 있나요?

웹 사이트 설정 및 보안

온-프레미스에서 TFS를 사용하며 이러한 기능 중 일부가 표시되지 않습니다. 왜 안 돼요?

이러한 기능 중 일부는 Azure Pipelines만 사용할 수 있으며 온-프레미스에서는 아직 사용할 수 없습니다. 최신 버전의 TFS으로 업그레이드한 경우, 일부 기능을 온프레미스에서 사용할 수 있습니다.

TFVC 필수 구성 요소

TFVC를 사용하려면 Oracle Java JDK 1.6 버전 이상이 또한 필요합니다. (Oracle JRE 및 OpenJDK는 이 용도로 충분하지 않습니다.)

TEE 플러그 인 TFVC 기능에 사용됩니다. 구성 중에 TFVC를 사용하려는 경우 수락해야 하는 EULA가 있습니다.

TEE 플러그 인은 더 이상 유지 관리되지 않으며 일부 오래된 Java 종속성을 포함하므로 에이전트 2.198.0부터 더 이상 에이전트 배포에 포함되지 않습니다. 그러나 TFVC 리포지토리를 체크 아웃하는 경우 체크 아웃 작업 실행 중에 TEE 플러그 인이 다운로드됩니다. TEE 플러그 인은 작업 실행 후에 제거됩니다.

메모

참고: 이 다운로드 메커니즘으로 인해 체크 아웃 작업이 작업을 시작하는 데 시간이 오래 걸리는 것을 알 수 있습니다.

에이전트가 프록시 또는 방화벽 뒤에서 실행되는 경우 다음 사이트에 대한 액세스를 보장하기 위해 동의해야 합니다. https://vstsagenttools.blob.core.windows.net/. TEE 플러그 인은 이 주소에서 다운로드됩니다.

자체 호스팅 에이전트를 사용하고 TEE 다운로드와 관련된 문제가 발생하는 경우 TEE를 수동으로 설치할 수 있습니다.

  1. DISABLE_TEE_PLUGIN_REMOVAL 환경 또는 파이프라인 변수를 true로 설정합니다. 이 변수는 TFVC 리포지토리 체크 아웃 후 에이전트가 TEE 플러그 인을 제거하는 것을 방지합니다.
  2. TEE-CLC 버전 14.135.0을 Team Explorer Everywhere GitHub 릴리스 페이지에서 수동으로 다운로드합니다.
  3. TEE-CLC-14.135.0 폴더의 내용을 추출하여 <agent_directory>/externals/tee로 이동하십시오.