Azure Data Factory 및 Synapse 파이프라인에서 지원하는 컴퓨팅 환경

적용 대상: Azure Data Factory Azure Synapse Analytics

기업용 올인원 분석 솔루션인 Microsoft Fabric의 Data Factory를 사용해 보세요. Microsoft Fabric은 데이터 이동부터 데이터 과학, 실시간 분석, 비즈니스 인텔리전스 및 보고에 이르기까지 모든 것을 다룹니다. 무료로 새 평가판을 시작하는 방법을 알아봅니다!

Important

Azure Machine Learning Studio(클래식)에 대한 지원은 2024년 8월 31일에 종료됩니다. 해당 날짜까지 Azure Machine Learning으로 전환하는 것이 좋습니다.

2021년 12월 1일부터 새 Machine Learning Studio(클래식) 리소스(작업 영역 및 웹 서비스 계획)를 만들 수 없습니다. 2024년 8월 31일까지 기존 Machine Learning Studio(클래식) 실험 및 웹 서비스를 계속 사용할 수 있습니다. 자세한 내용은 다음을 참조하세요.

Machine Learning Studio(클래식) 설명서는 사용 중지 중이며 나중에 업데이트되지 않을 수 있습니다.

이 문서는 프로세스 또는 변환 데이터에 사용할 수 있는 다양한 컴퓨팅 환경을 설명합니다. 또한 이러한 컴퓨팅 환경을 연결하는 연결된 서비스를 구성하는 경우 지원되는 다양한 구성(주문형 대비 자체 환경 사용)에 관해 자세히 설명합니다.

다음 표는 지원되는 컴퓨팅 환경 및 해당 환경에서 실행할 수 있는 작업의 목록을 제공합니다.

컴퓨팅 환경 활동
주문형 HDInsight 클러스터 또는 사용자 고유의 HDInsight 클러스터 Hive, Pig, Spark, MapReduce, Hadoop 스트리밍
Azure Batch 사용자 지정
ML Studio(클래식): ML Studio(클래식) 작업: Batch Execution 및 리소스 업데이트
Azure Machine Learning Azure Machine Learning 실행 파이프라인
Azure Data Lake Analytics 데이터 레이크 분석 U-SQL
Azure SQL, Azure Synapse Analytics, SQL Server 저장 프로시저
Azure Databricks Notebook, Jar, Python
Azure Synapse Analytics(아티팩트) Synapse Notebook 작업, Synapse Spark 작업 정의
Azure 함수 Azure 함수 작업

HDInsight 컴퓨팅 환경

주문형 및 BYOC(Bring Your Own Compute) 환경에서 구성을 위해 지원되는 스토리지 연결된 서비스 형식에 대한 자세한 내용은 아래 표를 참조하세요.

컴퓨팅 연결된 서비스에서 속성 이름 설명 Blob ADLS Gen2 Azure SQL DB ADLS Gen 1
주문형 linkedServiceName 데이터를 저장 및 처리하기 위해 주문형 클러스터에서 사용하는 Azure Storage 연결 서비스입니다. 없음 아니요
additionalLinkedServiceNames HDInsight 연결된 서비스에 대한 추가 스토리지 계정을 지정하므로 서비스가 사용자를 대신해 해당 계정을 등록할 수 있습니다. 없음 없음 아니요
hcatalogLinkedServiceName HCatalog 데이터베이스를 가리키는 Azure SQL 연결된 서비스 이름입니다. 주문형 HDInsight 클러스터는 Azure SQL 데이터베이스를 메타스토어로 사용하여 만들어집니다. 아니요 없음 아니요
BYOC linkedServiceName Azure Storage 연결된 서비스 참조입니다. 없음 아니요
additionalLinkedServiceNames HDInsight 연결된 서비스에 대한 추가 스토리지 계정을 지정하므로 서비스가 사용자를 대신해 해당 계정을 등록할 수 있습니다. 아니요 없음 없음 아니요
hcatalogLinkedServiceName HCatalog 데이터베이스를 가리키는 Azure SQL 연결된 서비스에 대한 참조입니다. 아니요 없음 없음 아니요

Azure HDInsight 주문형 연결된 서비스

이 유형의 구성에서 컴퓨팅 환경은 서비스에서 완전 관리됩니다. 데이터를 처리하기 위한 작업을 제출하기 전에 서비스에서 자동으로 컴퓨팅 환경을 만들고 작업이 완료되면 제거합니다. 사용자는 주문형 컴퓨팅 환경에 대한 연결된 서비스를 만들고 구성하며 작업 실행, 클러스터 관리, 부트스트래핑 작업에 대한 세부적인 설정을 제어할 수 있습니다.

참고 항목

주문형 구성은 현재 Azure HDInsight 클러스터에 대해서만 지원됩니다. 또한 Azure Databricks는 작업 클러스터를 사용하여 주문형 작업도 지원합니다. 자세한 내용은 Azure Databricks 연결된 서비스를 참조하세요.

서비스는 데이터를 처리하는 주문형 HDInsight 클러스터를 자동으로 만들 수 있습니다. 클러스터는 클러스터와 연결된 스토리지 계정(JSON에서 linkedServiceName 속성)과 동일한 하위 지역에 만들어집니다. 스토리지 계정 must는 범용 표준 Azure Storage 계정이어야 합니다.

주문형 HDInsight 연결된 서비스에 대해 다음 중요한 점에 유의하십시오.

  • 주문형 HDInsight 클러스터는 Azure 구독에 따라 생성됩니다. 클러스터가 실행 중인 경우 Azure Portal에서 클러스터를 볼 수 있습니다.
  • 주문형 HDInsight 클러스터에서 실행하는 작업에 대한 로그는 HDInsight 클러스터와 연결된 스토리지 계정에 복사됩니다. 연결된 서비스 정의에 정의된 clusterUserName, clusterPassword, clusterSshUserName, clusterSshPassword는 클러스터의 수명 주기 동안 자세한 문제 해결을 위해 클러스터에 로그인하는 데 사용됩니다.
  • HDInsight 클러스터가 작업을 실행 중인 경우에 대해서만 청구됩니다.
  • Azure HDInsight 주문형 연결된 서비스와 함께 스크립트 동작을 사용할 수 없습니다.

Important

주문형 Azure HDInsight 클러스터를 프로비전하는 데 일반적으로 20분 이상이 걸립니다.

예시

다음 JSON는 Linux 기반 주문형 HDInsight 연결된 서비스를 정의합니다. 서비스는 Linux 기반 HDInsight 클러스터를 자동으로 만들어 필요한 작업을 처리합니다.

{
  "name": "HDInsightOnDemandLinkedService",
  "properties": {
    "type": "HDInsightOnDemand",
    "typeProperties": {
      "clusterType": "hadoop",
      "clusterSize": 1,
      "timeToLive": "00:15:00",
      "hostSubscriptionId": "<subscription ID>",
      "servicePrincipalId": "<service principal ID>",
      "servicePrincipalKey": {
        "value": "<service principal key>",
        "type": "SecureString"
      },
      "tenant": "<tenent id>",
      "clusterResourceGroup": "<resource group name>",
      "version": "3.6",
      "osType": "Linux",
      "linkedServiceName": {
        "referenceName": "AzureStorageLinkedService",
        "type": "LinkedServiceReference"
      }
    },
    "connectVia": {
      "referenceName": "<name of Integration Runtime>",
      "type": "IntegrationRuntimeReference"
    }
  }
}

Important

HDInsight 클러스터는 JSON(linkedServiceName)에서 지정한 Blob Storage에 기본 컨테이너를 만듭니다. HDInsight는 클러스터가 삭제될 때 이 컨테이너를 삭제하지 않습니다. 이 동작은 의도된 것입니다. 주문형 HDInsight 연결된 서비스에서는 기존 라이브 클러스터(timeToLive)가 없는 한 슬라이스를 처리해야 할 때마다 HDInsight 클러스터가 만들어지며 처리가 완료되면 삭제됩니다.

더 많은 작업이 실행될수록 Azure Blob Storage에 컨테이너가 많아집니다. 작업의 문제 해결에 이 항목들이 필요하지 않다면 스토리지 비용을 줄이기 위해 삭제할 수 있습니다. 이러한 컨테이너의 이름은 adf**yourfactoryorworkspacename**-**linkedservicename**-datetimestamp 패턴을 따릅니다. Microsoft Azure Storage Explorer 같은 도구를 사용하여 Azure Blob 스토리지에서 컨테이너를 삭제합니다.

속성

Property 설명 필수
type 형식 속성은 HDInsightOnDemand로 설정해야 합니다.
clusterSize 클러스터의 작업자/데이터 노드 수 HDInsight 클러스터는 속성에 지정한 작업자 노드의 수와 함께 2개의 헤드 노드로 생성됩니다. 노드의 크기는 4개 코어를 포함한 Standard_D3이므로, 4개 작업자 노드 클러스터에서 24개 코어(작업자 노드용 4*4 = 16코어 및 헤드 노드용 2*4 = 8코어)를 사용합니다. 자세한 내용은 Hadoop, Spark, Kafka 등으로 HDInsight에서 클러스터를 설정을 참조하세요.
linkedServiceName 데이터를 저장 및 처리하기 위해 주문형 클러스터에서 사용하는 Azure Storage 연결 서비스입니다. HDInsight 클러스터는 Azure Storage 계정과 동일한 지역에 생성됩니다. Azure HDInsight에는 지원하는 각 Azure 지역에서 사용할 수 있는 총 코어 수에 대한 제한이 있습니다. 필요한 clustersize를 충족하기에 해당 Azure 지역의 코어 할당량이 충분한지 확인합니다. 자세한 내용은 Hadoop, Spark, Kafka 등으로 HDInsight에서 클러스터를 설정을 참조하세요.

현재 Azure Data Lake Storage(Gen 2)를 스토리지로 사용하는 주문형 HDInsight 클러스터를 만들 수 없습니다. HDInsight 처리의 결과 데이터를 Azure Data Lake Storage(Gen 2)에 저장하려면 복사 작업을 사용하여 Azure Blob Storage의 데이터를 Azure Data Lake Storage(Gen 2)로 복사합니다.

clusterResourceGroup HDInsight 클러스터는 이 리소스 그룹에 생성됩니다.
timetolive 주문형 HDInsight 클러스터에 대한 허용된 유휴 시간입니다. 클러스터에 다른 활성 작업이 없으면 작업이 완료된 후에 주문형 HDInsight 클러스터가 유지될 기간을 지정합니다. 최소 허용 값은 5분(00:05:00)입니다.

예를 들어 활동 실행에 6분이 걸리고 timetolive이 5분으로 설정된 경우 클러스터는 활동을 처리하는 6분 동안 실행된 후에 5분 동안 유지됩니다. 다른 활동 실행이 6분 창을 실행하는 경우 동일한 클러스터에 의해 처리됩니다.

주문형 HDInsight 클러스터 만들기는 다소 시간이 걸릴 수 있는 비용이 많이 드는 작업이므로 필요할 때마다 이 설정을 사용하여 주문형 HDInsight 클러스터를 다시 사용함으로써 서비스의 성능을 향상합니다.

timetolive 값을 0으로 설정한 경우 클러스터는 작업 실행이 완료되는 즉시 삭제됩니다. 반면 높은 값을 설정하는 경우 몇 가지 문제 해결 목적으로 로그온하려는 사용자를 위해 클러스터는 많은 비용이 발생하는 유휴 상태에 머무를 수 있습니다. 따라서 필요에 따라 적절한 값을 설정하는 것이 중요합니다.

timetolive 속성 값이 적절하게 설정되는 경우 여러 파이프라인은 주문형 HDInsight 클러스터의 인스턴스를 공유할 수 있습니다.
clusterType 만들 HDInsight 클러스터의 형식입니다. 허용되는 값은 "hadoop" 및 "spark"입니다. 지정하지 않으면 기본값은 hadoop입니다. Enterprise Security Package 지원 클러스터는 주문형으로 만들 수 없으며, 대신 기존 클러스터/사용자 고유의 컴퓨팅 가져오기를 사용합니다. 아니요
version HDInsight 클러스터의 버전입니다. 지정하지 않으면 현재 HDInsight에 정의된 기본 버전을 사용하는 것입니다. 아니요
hostSubscriptionId HDInsight 클러스터를 만드는 데 사용되는 Azure 구독 ID입니다. 지정하지 않으면 Azure 로그인 컨텍스트의 구독 ID를 사용합니다. 아니요
clusterNamePrefix HDI 클러스터 이름의 접두사로, 클러스터 이름 끝에 타임스탬프가 자동으로 추가됩니다. 아니요
sparkVersion 클러스터 형식이 "Spark"인 경우 Spark 버전입니다. 아니요
additionalLinkedServiceNames HDInsight 연결된 서비스에 대한 추가 스토리지 계정을 지정하므로 서비스가 사용자를 대신해 해당 계정을 등록할 수 있습니다. 이러한 스토리지 계정은 linkedServiceName에 지정된 스토리지 계정과 동일한 지역에 생성된 HDInsight 클러스터와 동일한 지역에 있어야 합니다. 아니요
osType 운영 체제 유형입니다. 허용되는 값은 Linux 및 Windows(HDInsight 3.3에만 해당)입니다. 기본값은 Linux입니다. 아니요
hcatalogLinkedServiceName HCatalog 데이터베이스를 가리키는 Azure SQL 연결된 서비스 이름입니다. 주문형 HDInsight 클러스터는 Azure SQL Database를 메타스토어로 사용하여 만들어집니다. 아니요
connectVia 이 HDInsight 연결된 서비스에 작업을 디스패치하는 데 사용할 통합 런타임입니다. 주문형 HDInsight 연결된 서비스의 경우 Azure 통합 런타임만 지원합니다. 지정하지 않으면 기본 Azure Integration Runtime을 사용합니다. 아니요
clusterUserName 클러스터에 액세스하기 위한 사용자 이름입니다. 아니요
clusterPassword 클러스터에 액세스하기 위한 보안 문자열 형식의 암호입니다. 아니요
clusterSshUserName SSH를 통해 클러스터 노드에 원격으로 연결하기 위한 사용자 이름입니다(Linux용). 아니요
clusterSshPassword SSH를 통해 클러스터 노드에 원격으로 연결하기 위한 보안 문자열 형식의 암호입니다(Linux용). 아니요
scriptActions 주문형 클러스터를 만드는 동안 HDInsight 클러스터 사용자 지정을 위한 스크립트를 지정합니다.
현재 UI 제작 도구는 1개의 스크립트 동작만 지정하도록 지원하지만 JSON에서는 이 제한을 무시할 수 있습니다(JSON에서 여러 스크립트 동작 지정).
아니요

Important

HDInsight는 배포할 수 있는 여러 Hadoop 클러스터 버전을 지원합니다. 각 버전을 선택하면 특정 버전의 HDP(Hortonworks Data Platform) 배포 및 배포에 포함된 구성 요소 집합이 만들어집니다. 지원되는 HDInsight 버전 목록을 계속 업데이트하여 최신 Hadoop 에코시스템 구성 요소 및 수정 프로그램을 제공합니다. 지원되는 HDInsight 버전 및 OS 형식의 최신 정보를 항상 참조하여 지원되는 HDInsight 버전을 사용 중인지 확인합니다.

Important

현재 HDInsight 연결된 서비스에서는 HBase, 대화형 쿼리(Hive LLAP), Storm을 지원하지 않습니다.

  • additionalLinkedServiceNames JSON 예제
"additionalLinkedServiceNames": [{
    "referenceName": "MyStorageLinkedService2",
    "type": "LinkedServiceReference"          
}]

서비스 주체 인증

주문형 HDInsight 연결된 서비스가 사용자를 대신해 HDInsight 클러스터를 만들려면 서비스 주체 인증이 필요합니다. 서비스 주체 인증을 사용하려면 Microsoft Entra ID에 애플리케이션 엔터티를 등록하고 구독의 기여자 역할 또는 HDInsight 클러스터가 만들어진 리소스 그룹을 부여합니다. 자세한 단계는 포털을 사용하여 리소스에 액세스할 수 있는 Microsoft Entra 애플리케이션 및 서비스 주체 만들기를 참조하세요. 연결된 서비스를 정의하는 데 사용되므로 다음 값을 적어둡니다.

  • 애플리케이션 ID
  • 애플리케이션 키
  • 테넌트 ID

다음 속성을 지정하여 서비스 주체 인증을 사용합니다.

속성 설명 필수
servicePrincipalId 애플리케이션의 클라이언트 ID를 지정합니다.
servicePrincipalKey 애플리케이션의 키를 지정합니다.
테넌트 애플리케이션이 있는 테넌트 정보(도메인 이름 또는 테넌트 ID)를 지정합니다. Azure Portal의 오른쪽 위 모서리에 마우스를 이동하여 검색할 수 있습니다.

고급 속성

또한 주문형 HDInsight 클러스터의 세부적인 구성에 다음 속성을 지정할 수 있습니다.

속성 설명 필수
coreConfiguration 만들어지는 HDInsight 클러스터에 대한 핵심 구성 매개 변수(core-site.xml에서 처럼)를 지정합니다. 아니요
hBaseConfiguration HDInsight 클러스터에 대한 HBase 구성 매개 변수(hbase-site.xml)를 지정합니다. 아니요
hdfsConfiguration HDInsight 클러스터에 대한 HDFS 구성 매개 변수(hdfs-site.xml)를 지정합니다. 아니요
hiveConfiguration HDInsight 클러스터에 대한 hive 구성 매개 변수(hive-site.xml)를 지정합니다. 아니요
mapReduceConfiguration HDInsight 클러스터에 대한 MapReduce 구성 매개 변수(mapred-site.xml)를 지정합니다. 아니요
oozieConfiguration HDInsight 클러스터에 대한 Oozie 구성 매개 변수(oozie-site.xml)를 지정합니다. 아니요
stormConfiguration HDInsight 클러스터에 대한 Storm 구성 매개 변수(storm-site.xml)를 지정합니다. 아니요
yarnConfiguration HDInsight 클러스터에 대한 Yarn 구성 매개 변수(yarn-site.xml)를 지정합니다. 아니요
  • 예 - 고급 속성을 포함하는 주문형 HDInsight 클러스터 구성
{
    "name": " HDInsightOnDemandLinkedService",
    "properties": {
      "type": "HDInsightOnDemand",
      "typeProperties": {
          "clusterSize": 16,
          "timeToLive": "01:30:00",
          "hostSubscriptionId": "<subscription ID>",
          "servicePrincipalId": "<service principal ID>",
          "servicePrincipalKey": {
            "value": "<service principal key>",
            "type": "SecureString"
          },
          "tenant": "<tenent id>",
          "clusterResourceGroup": "<resource group name>",
          "version": "3.6",
          "osType": "Linux",
          "linkedServiceName": {
              "referenceName": "AzureStorageLinkedService",
              "type": "LinkedServiceReference"
            },
            "coreConfiguration": {
                "templeton.mapper.memory.mb": "5000"
            },
            "hiveConfiguration": {
                "templeton.mapper.memory.mb": "5000"
            },
            "mapReduceConfiguration": {
                "mapreduce.reduce.java.opts": "-Xmx4000m",
                "mapreduce.map.java.opts": "-Xmx4000m",
                "mapreduce.map.memory.mb": "5000",
                "mapreduce.reduce.memory.mb": "5000",
                "mapreduce.job.reduce.slowstart.completedmaps": "0.8"
            },
            "yarnConfiguration": {
                "yarn.app.mapreduce.am.resource.mb": "5000",
                "mapreduce.map.memory.mb": "5000"
            },
            "additionalLinkedServiceNames": [{
                "referenceName": "MyStorageLinkedService2",
                "type": "LinkedServiceReference"          
            }]
        }
    },
      "connectVia": {
      "referenceName": "<name of Integration Runtime>",
      "type": "IntegrationRuntimeReference"
    }
}

노드 크기

다음 속성을 사용하여 헤드, 데이터 및 Zookeeper 노드의 크기를 지정할 수 있습니다.

속성 설명 필수
headNodeSize 헤드 노드의 크기를 지정합니다. 기본값은 Standard_D3입니다. 자세한 내용은 노드 크기 지정 섹션을 참조하세요. 아니요
dataNodeSize 데이터 노드의 크기를 지정합니다. 기본값은 Standard_D3입니다. 아니요
zookeeperNodeSize Zookeeper 노드의 크기를 지정합니다. 기본값은 Standard_D3입니다. 아니요
  • 노드 크기 지정 이전 섹션에 언급된 속성에 대해 지정해야 하는 문자열 값은 Virtual Machines 크기 문서를 참조하세요. 값은 이 문서에서 참조된 Cmdlet 및 API를 준수해야 합니다. 이 문서에서 볼 수 있는 것처럼 크게(기본값) 크기의 데이터 노드는 메모리가 7GB이므로 시나리오에 맞지 않을 수 있습니다.

D4 크기의 헤드 노드 및 작업자 노드를 만들려는 경우 headNodeSize 및 dataNodeSize 속성에 대한 값으로 Standard_D4를 지정합니다.

"headNodeSize": "Standard_D4",    
"dataNodeSize": "Standard_D4",

이러한 속성에 잘못된 값을 지정하는 경우 다음과 같은 오류가 발생할 수 있습니다. 오류: 클러스터를 만들지 못했습니다. 예외: 클러스터 만들기 작업을 완료할 수 없습니다. 작업이 실패했습니다. 오류 코드는 '400'입니다. 클러스터의 상태가 '오류'로 남아 있습니다. 메시지: 'PreClusterCreationValidationFailure'. 이 오류가 발생하면 Virtual Machines 크기 문서의 테이블에서 CMDLET 및 API 이름을 사용하고 있는지 확인합니다.

사용자 고유의 컴퓨팅 환경 가져오기

이 유형의 구성에서 사용자는 기존 컴퓨팅 환경을 연결된 서비스로 등록할 수 있습니다. 컴퓨팅 환경은 사용자가 관리하며 서비스는 이를 사용하여 작업을 실행합니다.

이 구성의 형식은 다음의 컴퓨팅 환경에 대해 지원됩니다.

  • Azure HDInsight
  • Azure Batch
  • Azure Machine Learning
  • Azure 데이터 레이크 분석
  • Azure SQL DB, Azure Synapse Analytics, SQL Server

Azure HDInsight 연결된 서비스

Azure HDInsight 연결된 서비스를 만들어서 데이터 팩터리 또는 Synapse 작업 영역에 고유한 HDInsight 클러스터를 등록할 수 있습니다.

예시

{
    "name": "HDInsightLinkedService",
    "properties": {
      "type": "HDInsight",
      "typeProperties": {
        "clusterUri": " https://<hdinsightclustername>.azurehdinsight.net/",
        "userName": "username",
        "password": {
            "value": "passwordvalue",
            "type": "SecureString"
          },
        "linkedServiceName": {
              "referenceName": "AzureStorageLinkedService",
              "type": "LinkedServiceReference"
        }
      },
      "connectVia": {
        "referenceName": "<name of Integration Runtime>",
        "type": "IntegrationRuntimeReference"
      }
    }
  }

속성

Property 설명 필수
type 형식 속성은 HDInsight로 설정해야 합니다.
clusterUri HDInsight 클러스터의 URI입니다.
사용자 이름 기존 HDInsight 클러스터에 연결하는데 사용할 사용자의 이름을 지정합니다.
password 사용자 계정으로 password를 지정합니다.
linkedServiceName HDInsight 클러스터에서 사용하는 Azure Blob Storage를 참조하는 Azure Storage 연결된 서비스의 이름입니다.

현재 이 속성에 대한 Azure Data Lake Storage(Gen 2) 연결된 서비스를 지정할 수 없습니다. HDInsight 클러스터가 Data Lake Store에 액세스할 경우 Hive/Pig 스크립트의 Azure Data Lake Storage(Gen 2)에 있는 데이터에 액세스할 수 있습니다.

isEspEnabled HDInsight 클러스터에서 Enterprise Security Package가 사용하도록 설정되어 있으면 'true'를 지정합니다. 기본값은 ‘false’입니다. 아니요
connectVia 이 연결된 서비스에 작업을 디스패치하는 데 사용할 통합 런타임입니다. Azure 통합 런타임 또는 자체 호스팅 통합 런타임을 사용할 수 있습니다. 지정하지 않으면 기본 Azure Integration Runtime을 사용합니다.
ESP(Enterprise Security Package) 지원 HDInsight 클러스터는 클러스터가 표시되는 자체 호스팅 통합 런타임을 사용하거나, ESP HDInsight 클러스터와 동일한 Virtual Network 내에서 배포해야 합니다.
아니요

Important

HDInsight는 배포할 수 있는 여러 Hadoop 클러스터 버전을 지원합니다. 각 버전을 선택하면 특정 버전의 HDP(Hortonworks Data Platform) 배포 및 배포에 포함된 구성 요소 집합이 만들어집니다. 지원되는 HDInsight 버전 목록을 계속 업데이트하여 최신 Hadoop 에코시스템 구성 요소 및 수정 프로그램을 제공합니다. 지원되는 HDInsight 버전 및 OS 형식의 최신 정보를 항상 참조하여 지원되는 HDInsight 버전을 사용 중인지 확인합니다.

Important

현재 HDInsight 연결된 서비스에서는 HBase, 대화형 쿼리(Hive LLAP), Storm을 지원하지 않습니다.

Azure Batch 연결된 서비스

참고 항목

Azure Az PowerShell 모듈을 사용하여 Azure와 상호 작용하는 것이 좋습니다. 시작하려면 Azure PowerShell 설치를 참조하세요. Az PowerShell 모듈로 마이그레이션하는 방법에 대한 자세한 내용은 Azure PowerShell을 AzureRM에서 Azure로 마이그레이션을 참조하세요.

Azure Batch 연결된 서비스를 만들어서 데이터 또는 Synapse 작업 영역에 VM(가상 머신)의 Batch 풀을 등록할 수 있습니다. Azure 배치를 사용하여 사용자 지정 작업을 실행할 수 있습니다.

Azure Batch 서비스가 처음이라면 다음 문서를 참조하세요.

Important

새 Azure Batch 풀을 만들 때 ‘CloudServiceConfiguration’이 아니라 ‘VirtualMachineConfiguration’을 사용해야 합니다. 자세한 내용은 Azure Batch 풀 마이그레이션 참고 자료를 참조하세요.

예시

{
    "name": "AzureBatchLinkedService",
    "properties": {
      "type": "AzureBatch",
      "typeProperties": {
        "accountName": "batchaccount",
        "accessKey": {
          "type": "SecureString",
          "value": "access key"
        },
        "batchUri": "https://batchaccount.region.batch.azure.com",
        "poolName": "poolname",
        "linkedServiceName": {
          "referenceName": "StorageLinkedService",
          "type": "LinkedServiceReference"
        }
      },
      "connectVia": {
        "referenceName": "<name of Integration Runtime>",
        "type": "IntegrationRuntimeReference"
      }
    }
  }

속성

Property 설명 필수
type 형식 속성은 AzureBatch로 설정해야 합니다.
accountName Azure Batch 계정의 이름
accessKey Azure Batch 계정에 대한 선택키
batchUri Azure 배치 계정에 대한 URL로, https://batchaccountname.region.batch.azure.com 형식을 사용합니다.
poolName 가상 머신의 풀 이름입니다.
linkedServiceName Azure Batch 연결된 서비스와 관련된 Azure Storage 연결된 서비스의 이름입니다. 이 연결된 서비스는 작업을 실행하는 데 필요한 파일을 준비하는 데 사용됩니다.
connectVia 이 연결된 서비스에 작업을 디스패치하는 데 사용할 통합 런타임입니다. Azure 통합 런타임 또는 자체 호스팅 통합 런타임을 사용할 수 있습니다. 지정하지 않으면 기본 Azure Integration Runtime을 사용합니다. 아니요

Machine Learning Studio(클래식) 연결된 서비스

Important

Azure Machine Learning Studio(클래식)에 대한 지원은 2024년 8월 31일에 종료됩니다. 해당 날짜까지 Azure Machine Learning으로 전환하는 것이 좋습니다.

2021년 12월 1일부터 새 Machine Learning Studio(클래식) 리소스(작업 영역 및 웹 서비스 계획)를 만들 수 없습니다. 2024년 8월 31일까지 기존 Machine Learning Studio(클래식) 실험 및 웹 서비스를 계속 사용할 수 있습니다. 자세한 내용은 다음을 참조하세요.

Machine Learning Studio(클래식) 설명서는 사용 중지 중이며 나중에 업데이트되지 않을 수 있습니다.

Machine Learning Studio(클래식) 연결된 서비스를 만들어서 Machine Learning Studio(클래식) 일괄 채점 엔드포인트를 데이터 팩터리 또는 Synapse 작업 영역에 등록합니다.

예시

{
    "name": "AzureMLLinkedService",
    "properties": {
      "type": "AzureML",
      "typeProperties": {
        "mlEndpoint": "https://[batch scoring endpoint]/jobs",
        "apiKey": {
            "type": "SecureString",
            "value": "access key"
        }
     },
     "connectVia": {
        "referenceName": "<name of Integration Runtime>",
        "type": "IntegrationRuntimeReference"
      }
    }
}

속성

Property 설명 필수
Type 형식 속성은 AzureML로 설정해야 합니다.
mlEndpoint 일괄 처리 점수 매기기 URL입니다.
apiKey 게시된 작업 영역 모델의 API입니다.
updateResourceEndpoint 학습된 모델 파일이 있는 예측 웹 서비스를 업데이트하는 데 사용되는 ML Studio(classic) Web Service 엔드포인트에 대한 업데이트 리소스 URL입니다 아니요
servicePrincipalId 애플리케이션의 클라이언트 ID를 지정합니다. UpdateResourceEndpoint가 지정된 경우에 필요합니다.
servicePrincipalKey 애플리케이션의 키를 지정합니다. UpdateResourceEndpoint가 지정된 경우에 필요합니다.
테넌트 애플리케이션이 있는 테넌트 정보(도메인 이름 또는 테넌트 ID)를 지정합니다. Azure Portal의 오른쪽 위 모서리에 마우스를 이동하여 검색할 수 있습니다. UpdateResourceEndpoint가 지정된 경우에 필요합니다.
connectVia 이 연결된 서비스에 작업을 디스패치하는 데 사용할 통합 런타임입니다. Azure 통합 런타임 또는 자체 호스팅 통합 런타임을 사용할 수 있습니다. 지정하지 않으면 기본 Azure Integration Runtime을 사용합니다. 아니요

Azure Machine Learning 연결된 서비스

Azure Machine Learning 연결된 서비스를 만들어서 Azure Machine Learning 작업 영역을 데이터 팩터리 또는 Synapse 작업 영역에 연결합니다.

참고 항목

현재 Azure Machine Learning 연결된 서비스에 대한 서비스 주체 인증만 지원됩니다.

예시

{
    "name": "AzureMLServiceLinkedService",
    "properties": {
        "type": "AzureMLService",
        "typeProperties": {
            "subscriptionId": "subscriptionId",
            "resourceGroupName": "resourceGroupName",
            "mlWorkspaceName": "mlWorkspaceName",
            "servicePrincipalId": "service principal id",
            "servicePrincipalKey": {
                "value": "service principal key",
                "type": "SecureString"
            },
            "tenant": "tenant ID"
        },
        "connectVia": {
            "referenceName": "<name of Integration Runtime?",
            "type": "IntegrationRuntimeReference"
        }
    }
}

속성

Property 설명 필수
Type 형식 속성은 AzureMLService로 설정되어야 합니다.
subscriptionId Azure 구독 ID
resourceGroupName name
mlWorkspaceName Azure Machine Learning 작업 영역 이름
servicePrincipalId 애플리케이션의 클라이언트 ID를 지정합니다.
servicePrincipalKey 애플리케이션의 키를 지정합니다.
테넌트 애플리케이션이 있는 테넌트 정보(도메인 이름 또는 테넌트 ID)를 지정합니다. Azure Portal의 오른쪽 위 모서리에 마우스를 이동하여 검색할 수 있습니다. UpdateResourceEndpoint가 지정된 경우에 필요합니다.
connectVia 이 연결된 서비스에 작업을 디스패치하는 데 사용할 통합 런타임입니다. Azure 통합 런타임 또는 자체 호스팅 통합 런타임을 사용할 수 있습니다. 지정하지 않으면 기본 Azure Integration Runtime을 사용합니다. 아니요

Azure Data Lake Analytics 연결된 서비스

Azure Data Lake Analytics 연결된 서비스를 만들어서 Azure Data Lake Analytics 컴퓨팅 서비스를 데이터 팩터리 도는 Synapse 작업 영역에 연결합니다. 파이프라인에서 데이터 레이크 분석 U-SQL 작업은 이 연결된 서비스를 가리킵니다.

예시

{
    "name": "AzureDataLakeAnalyticsLinkedService",
    "properties": {
        "type": "AzureDataLakeAnalytics",
        "typeProperties": {
            "accountName": "adftestaccount",
            "dataLakeAnalyticsUri": "azuredatalakeanalytics URI",
            "servicePrincipalId": "service principal id",
            "servicePrincipalKey": {
                "value": "service principal key",
                "type": "SecureString"
            },
            "tenant": "tenant ID",
            "subscriptionId": "<optional, subscription ID of ADLA>",
            "resourceGroupName": "<optional, resource group name of ADLA>"
        },
        "connectVia": {
            "referenceName": "<name of Integration Runtime>",
            "type": "IntegrationRuntimeReference"
        }
    }
}

속성

Property 설명 필수
type type 속성은 AzureDataLakeAnalytics로 설정해야 합니다.
accountName Azure 데이터 레이크 분석 계정 이름입니다.
dataLakeAnalyticsUri Azure 데이터 레이크 분석 URI입니다. 아니요
subscriptionId Azure 구독 ID 아니요
resourceGroupName Azure 리소스 그룹 이름 아니요
servicePrincipalId 애플리케이션의 클라이언트 ID를 지정합니다.
servicePrincipalKey 애플리케이션의 키를 지정합니다.
테넌트 애플리케이션이 있는 테넌트 정보(도메인 이름 또는 테넌트 ID)를 지정합니다. Azure Portal의 오른쪽 위 모서리에 마우스를 이동하여 검색할 수 있습니다.
connectVia 이 연결된 서비스에 작업을 디스패치하는 데 사용할 통합 런타임입니다. Azure 통합 런타임 또는 자체 호스팅 통합 런타임을 사용할 수 있습니다. 지정하지 않으면 기본 Azure Integration Runtime을 사용합니다. 아니요

Azure Databricks 연결된 서비스

Azure Databricks 연결된 서비스를 만들어 Databricks 워크로드(노트북, jar, python)를 실행하는 데 사용할 Databricks 작업 영역을 등록할 수 있습니다.

Important

Databricks 연결된 서비스는 인스턴스 풀 및 시스템 할당 관리 ID 인증을 지원합니다.

예 - Databricks에서 새 작업 클러스터 사용

{
    "name": "AzureDatabricks_LS",
    "properties": {
        "type": "AzureDatabricks",
        "typeProperties": {
            "domain": "https://eastus.azuredatabricks.net",
            "newClusterNodeType": "Standard_D3_v2",
            "newClusterNumOfWorker": "1:10",
            "newClusterVersion": "4.0.x-scala2.11",
            "accessToken": {
                "type": "SecureString",
                "value": "dapif33c9c721144c3a790b35000b57f7124f"
            }
        }
    }
}

예 - Databricks에서 기존의 대화형 클러스터 사용

{
    "name": " AzureDataBricksLinedService",
    "properties": {
      "type": " AzureDatabricks",
      "typeProperties": {
        "domain": "https://westeurope.azuredatabricks.net",
        "accessToken": {
            "type": "SecureString", 
            "value": "dapif33c9c72344c3a790b35000b57f7124f"
          },
        "existingClusterId": "{clusterId}"
        }
}

속성

Property 설명 필수
name 연결된 서비스의 이름입니다.
type 형식 속성은 Azure Databricks로 설정되어야 합니다.
도메인 Databricks 작업 영역의 지역을 기준으로 Azure 지역을 적절히 지정합니다. 예: https://eastus.azuredatabricks.net
accessToken 서비스가 Azure Databricks에서 인증을 받으려면 액세스 토큰이 필요합니다. 액세스 토큰은 Databricks 작업 영역에서 생성해야 합니다. 액세스 토큰을 찾는 보다 자세한 단계는 여기에서 확인할 수 있습니다. 아니요
MSI 서비스의 관리 ID(시스템 할당)를 사용하여 Azure Databricks에 인증합니다. ‘MSI’ 인증을 사용하는 경우 액세스 토큰이 필요하지 않습니다. 관리 ID 인증에 관한 자세한 내용은 여기를 참조하세요. 아니요
existingClusterId 해당하는 모든 작업을 실행할 기존 클러스터의 클러스터 ID입니다. 이미 만들어진 대화형 클러스터여야 합니다. 클러스터가 응답을 중지하면 클러스터를 수동으로 다시 시작해야 할 수도 있습니다. 안정성을 높이기 위해서는 새 클러스터에서 작업을 실행하는 것이 좋습니다. Databricks 작업 영역 -> 대화형 클러스터 이름 -> 구성 -> 태그에서 대화형 클러스터의 클러스터 ID를 찾을 수 있습니다. 자세한 정보 아니요
instancePoolId Databricks 작업 영역에 있는 기존 풀의 인스턴스 풀 ID입니다. 아니요
newClusterVersion 클러스터의 Spark 버전입니다. Databricks에서 작업 클러스터를 만듭니다. 아니요
newClusterNumOfWorker 이 클러스터에 있어야 하는 작업자 노드의 수입니다. 하나의 클러스터에 총 num_workers + 1개의 Spark 노드에 대해 하나의 Spark 드라이버와 num_workers개의 실행기가 있습니다. "1"과 같은 Int32 형식의 문자열에서 numOfWorker는 1을 의미하고, "1:10"은 최소 1에서 최대 10 범위의 자동 크기 조정을 의미합니다. 아니요
newClusterNodeType 이 필드는 단일 값을 통해 이 클러스터의 각 Spark 노드에서 사용할 수 있는 리소스를 인코딩합니다. 예를 들어, Spark 노드는 메모리 또는 컴퓨팅 집약적 워크로드에 대해 프로비저닝되고 최적화될 수 있습니다. 이 필드는 새 클러스터에 필요합니다. 아니요
newClusterSparkConf 선택적인 사용자 지정 Spark 구성 키-값 쌍의 집합입니다. 또한 사용자는 각각 spark.driver.extraJavaOptions 및 spark.executor.extraJavaOptions를 통해 드라이버와 실행기에 추가 JVM 옵션 문자열을 전달할 수 있습니다. 아니요
newClusterInitScripts 새 클러스터에 대한 선택적 사용자 정의 초기화 스크립트의 세트입니다. 작업 영역 파일(권장) 또는 DBFS 경로(레거시)를 통해 init 스크립트를 지정할 수 있습니다. 아니요

Azure SQL Database 연결된 서비스

Azure SQL 연결된 서비스를 만들고 저장 프로시저 작업에서 사용하여 파이프라인에서 저장 프로시저를 호출합니다. 이 연결된 서비스에 대한 자세한 내용은 Azure SQL 커넥터 문서를 참조하세요.

Azure Synapse Analytics 연결된 서비스

Azure Synapse Analytics 연결된 서비스를 만들고 저장 프로시저 작업에서 사용하여 파이프라인에서 저장 프로시저를 호출합니다. 이 연결된 서비스에 대한 자세한 내용은 Azure Synapse Analytics 커넥터 문서를 참조하세요.

SQL Server 연결된 서비스

SQL Server 연결된 서비스를 만들고 저장 프로시저 작업에서 사용하여 파이프라인에서 저장 프로시저를 호출합니다. 이 연결된 서비스에 대한 자세한 내용은 SQL Server 커넥터 문서를 참조하세요.

Azure Synapse Analytics(아티팩트) 연결된 서비스

Azure Synapse Analytics(아티팩트) 연결된 서비스를 만들고 Synapse Notebook 작업Synapse Spark 작업 정의 작업과 함께 사용합니다.

예시

{
    "name": "AzureSynapseArtifacts",
    "type": "Microsoft.DataFactory/factories/linkedservice",
    "properties": {
      "properties": {
        "a":{
          "type": "String"
        }
      },
        "annotations": [],
        "type": "AzureSynapseArtifacts",
        "typeProperties": {
            "endpoint": "@{linkedService().a}",
            "authentication": "MSI",
            "workspaceResourceId": ""
        },
        "ConnectVia":{
          "referenceName": "integrationRuntime1",
          "type": "IntergrationRuntimeReference"
        }
    }
}

속성

속성 설명 필수
name 연결된 서비스의 이름입니다.
description 연결된 서비스에 대한 설명 아니요
annotations 연결된 서비스의 주석 아니요
type 형식 속성은 AzureSynapseArtifacts로 설정해야 합니다.
endpoint Azure Synapse Analytics URL
authentication 기본 설정은 시스템이 할당한 관리 ID입니다.
workspaceResourceId 작업 영역 리소스 ID
connectVia 데이터 저장소에 연결하는 데 사용할 통합 런타임입니다. Azure Integration Runtime을 사용할 수 있습니다. 지정하지 않으면 기본 Azure Integration Runtime을 사용합니다. 자체 호스팅 통합 런타임은 현재 지원되지 않습니다.

Azure 함수의 연결된 서비스

Azure 함수 연결된 서비스를 만들고 Azure 함수 작업에서 사용하여 파이프라인에서 Azure Functions를 실행합니다. Azure 함수의 반환 형식은 유효한 JObject여야 합니다. (JArrayJObject아님에 유의) JObject 이외의 모든 반환 형식이 실패하고 응답 콘텐츠가 유효한 JObject가 아닙니다 사용자 오류가 발생합니다.

속성 설명 필수
type 형식 속성은 AzureFunction으로 설정되어야 합니다.
함수 앱 URL Azure 함수 앱의 URL입니다. 형식은 https://<accountname>.azurewebsites.net입니다. 이 URL은 Azure Portal에서 함수 앱을 볼 때 URL 섹션 아래에 표시되는 값입니다.
기능 키 Azure 함수의 액세스 키입니다. 해당 함수의 관리 섹션을 클릭하고 기능 키 또는 호스트 키를 복사합니다. 여기에서 자세한 내용을 알아봅니다. Azure Functions HTTP 트리거 및 바인딩

지원되는 변환 작업 목록은 데이터 변환을 참조하세요.