다음을 통해 공유


HPC Pack IaaS 배포 스크립트를 사용하여 Linux HPC(고성능 컴퓨팅) 클러스터 만들기

중요

클래식 VM은 2023년 3월 1일에 사용 중지됩니다.

ASM의 IaaS 리소스를 사용하는 경우 2023년 3월 1일까지 마이그레이션을 완료하세요. Azure Resource Manager의 다양한 기능 향상을 활용하려면 빨리 전환하는 것이 좋습니다.

자세한 내용은 2023년 3월 1일까지 IaaS 리소스를 Azure Resource Manager로 마이그레이션을 참조하세요.

HPC Pack IaaS 배포 PowerShell 스크립트를 실행하여 Azure 가상 머신에 완전한 Linux 워크로드용 HPC Pack 2012 R2 클러스터를 배포합니다. 이 클러스터는 Windows Server 및 Microsoft HPC Pack을 실행하는 Active Directory 가입 헤드 노드와 HPC Pack에서 지원하는 Linux 배포판 중 하나를 실행하는 컴퓨팅 노드로 구성됩니다. Azure에서 Windows 워크로드용 HPC 팩 클러스터를 배포하려면 HPC 팩 IaaS 배포 스크립트를 사용하여 Windows HPC 클러스터 만들기를 참조하세요.

중요

이 문서에 설명된 PowerShell 스크립트는 클래식 배포 모델을 사용하여 Azure에 Microsoft HPC Pack 2012 R2 클러스터를 만듭니다. 새로운 배포는 대부분 리소스 관리자 모델을 사용하는 것이 좋습니다. 또한 이 문서에 설명된 스크립트는 HPC Pack 2016을 지원하지 않습니다. HPC Pack 2012 R2 및 HPC 팩 2016에 대한 Resource Manager 템플릿에 대한 정보는 Azure에서 HPC Pack 클러스터 배포 옵션을 참조하세요.

사용자의 환경과 선택 사항에 따라 스크립트를 사용하여 Azure 가상 네트워크, 스토리지 계정, 클라우드 서비스, 도메인 컨트롤러, 원격 또는 로컬 SQL 데이터베이스, 헤드 노드, 추가 클러스터 노드를 포함한 모든 클러스터 인프라를 만들 수 있습니다. 또는 스크립트에서 기존 Azure 인프라를 사용하여 HPC 클러스터 노드만 만들 수도 있습니다.

HPC 팩 클러스터 계획에 대한 배경 정보는 HPC 팩 2012 R2 TechNet 라이브러리에서 제품 평가 및 계획시작하기 콘텐츠를 참조하세요.

필수 선행 작업

  • Azure 구독: Azure Global 또는 Azure China 서비스의 구독을 사용할 수 있습니다. 구독 제한은 배포할 수 있는 클러스터 노드의 수와 유형에 영향을 줍니다. 자세한 내용은 Azure 구독 및 서비스 제한, 할당량 및 제약 조건을 참조하세요.
  • Azure PowerShell 0.8.10 이상이 설치 및 구성된 Windows 클라이언트 컴퓨터: Azure 구독에 연결하기 위한 설치 지침 및 단계는 Azure PowerShell 시작을 참조하세요.
  • HPC 팩 IaaS 배포 스크립트: Microsoft 다운로드 센터에서 최신 버전의 스크립트를 다운로드하고 압축을 풉니다. New-HPCIaaSCluster.ps1 –Version을 실행하여 스크립트 버전을 확인합니다. 이 문서는 버전 4.5.2의 스크립트를 기반으로 합니다.
  • 스크립트 구성 파일: 스크립트가 HPC 클러스터를 구성하는 데 사용하는 XML 파일을 만듭니다. 정보 및 예제는 이 문서의 후반부에 나오는 단원 및 배포 스크립트와 함께 제공되는 Manual.rtf 파일을 참조하세요.

Syntax

New-HPCIaaSCluster.ps1 [-ConfigFile] <String> [-AdminUserName]<String> [[-AdminPassword] <String>] [[-HPCImageName] <String>] [[-LogFile] <String>] [-Force] [-NoCleanOnFailure] [-PSSessionSkipCACheck] [<CommonParameters>]

참고

스크립트는 관리자 권한으로 실행합니다.

매개 변수

  • ConfigFile: HPC 클러스터를 설명하는 구성 파일의 파일 경로를 지정합니다. 자세한 내용은 이 토픽의 구성 파일 또는 스크립트가 포함된 폴더의 Manual.rtf 파일을 참조하세요.

  • AdminUserName: 사용자 이름을 지정합니다. 스크립트로 도메인 포리스트를 만든 경우 모든 VM의 로컬 관리자 사용자 이름과 도메인 관리자 이름이 됩니다. 도메인 포리스트가 이미 있는 경우에는 로컬 관리자 이름으로 도메인 사용자를 지정하여 HPC 팩을 설치합니다.

  • AdminPassword: 관리자의 암호를 지정합니다. 명령줄에서 이 매개 변수를 지정하지 않은 경우 스크립트에서 암호를 입력하라는 메시지를 표시합니다.

  • HPCImageName(선택 사항): HPC 클러스터를 배포하는 데 사용하는 HPC 팩 VM 이미지 이름을 지정합니다. Microsoft에서 제공한 Azure Marketplace의 HPC 팩 이미지여야 합니다. 이 매개 변수를 지정하지 않을 경우(일반적으로 지정하는 것이 좋음) 스크립트에서 최근 게시된 HPC Pack 2012 R2 이미지를 선택합니다. 최신 이미지는 HPC Pack 2012 R2 업데이트 3이 설치된 Windows Server 2012 R2 Datacenter를 기준으로 합니다.

    참고

    유효한 HPC 팩 이미지를 지정하지 않으면 배포가 실패합니다.

  • LogFile(선택 사항): 배포 로그 파일 경로를 지정합니다. 이 매개 변수를 지정하지 않을 경우 스크립트를 실행하는 컴퓨터의 temp 디렉터리에 로그 파일이 만들어집니다.

  • Force(선택 사항): 모든 확인 메시지를 표시하지 않습니다.

  • NoCleanOnFailure(선택 사항): 성공적으로 배포되지 않은 Azure VM을 제거하지 않도록 지정합니다. 배포를 계속하려면 스크립트를 다시 실행하기 전에 이러한 VM을 수동으로 제거합니다. 그렇지 않을 경우 배포가 실패합니다.

  • PSSessionSkipCACheck(선택 사항): 이 스크립트에서 배포한 VM을 사용하는 모든 클라우드 서비스에서는 Azure가 자체 서명된 인증서를 자동으로 생성하며 클라우드 서비스의 모든 VM은 이 인증서를 기본 WinRM(Windows 원격 관리) 인증서로 사용합니다. 이러한 Azure VM에 HPC 기능을 배포하기 위해 스크립트는 기본적으로 스크립트 실행 중에 "신뢰할 수 없는 CA" 보안 오류를 표시하지 않도록 클라이언트 컴퓨터의 로컬 컴퓨터\신뢰할 수 있는 루트 인증 기관 저장소에 이러한 인증서를 일시적으로 설치합니다. 스크립트가 완료되면 인증서가 제거됩니다. 이 매개 변수를 지정할 경우 인증서가 클라이언트 컴퓨터에 설치되지 않고 보안 경고가 표시되지 않습니다.

    중요

    이 매개 변수는 프로덕션 배포에 권장되지 않습니다.

예제

다음 예제는 MyConfigFile.xml구성 파일을 사용하여 HPC 팩 클러스터를 만들며 클러스터 설치를 위한 관리자 자격 증명을 지정합니다.

.\New-HPCIaaSCluster.ps1 –ConfigFile MyConfigFile.xml -AdminUserName <username> –AdminPassword <password>

기타 고려 사항

  • 이 스크립트는 HPC 팩 웹 포털 또는 HPC 팩 REST API를 통한 작업 제출을 선택적으로 활성화할 수 있습니다.
  • 추가 소프트웨어를 설치하거나 다른 설정을 구성하려는 경우 이 스크립트로 헤드 노드에서 사용자 지정 사전/사후 구성 스크립트를 선택적으로 실행할 수 있습니다.

구성 파일

배포 스크립트의 구성 파일은 XML 파일입니다. 스키마 파일 HPCIaaSClusterConfig.xsd는 HPC 팩 IaaS 배포 스크립트 폴더에 있습니다. IaaSClusterConfig 는 배포 스크립트 폴더의 Manual.rtf 파일에 자세히 설명된 하위 요소가 포함된 구성 파일의 루트 요소입니다.

예제 구성 파일

다음 구성 파일은 도메인 컨트롤러 및 도메인 포리스트를 만들고 HPC Pack 클러스터(로컬 데이터베이스를 사용하는 1개 헤드 노드 및 10개 Linux 컴퓨팅 노드)를 배포합니다. 모든 클라우드 서비스는 동아시아 위치에서 직접 생성됩니다. Linux 컴퓨팅 노드는 2개 클라우드 서비스와 2개 스토리지 계정에 만들어집니다(즉, MyLnxCNService01mylnxstorage01MyLnxCN-0001에서 MyLnxCN-0005까지와 MyLnxCNService02mylnxstorage02MyLnxCN-0006에서 MyLnxCN-0010까지). 컴퓨팅 노드는 OpenLogic CentOS 버전 7.0 Linux 이미지에서 만들어집니다.

구독 이름과 계정 및 서비스 이름을 고유한 값으로 대체합니다.

<?xml version="1.0" encoding="utf-8" ?>
<IaaSClusterConfig>
  <Subscription>
    <SubscriptionName>Subscription-1</SubscriptionName>
    <StorageAccount>mystorageaccount</StorageAccount>
  </Subscription>
  <Location>East Asia</Location>  
  <VNet>
    <VNetName>MyVNet</VNetName>
    <SubnetName>Subnet-1</SubnetName>
  </VNet>
  <Domain>
    <DCOption>NewDC</DCOption>
    <DomainFQDN>hpc.local</DomainFQDN>
    <DomainController>
      <VMName>MyDCServer</VMName>
      <ServiceName>MyHPCService</ServiceName>
      <VMSize>Large</VMSize>
    </DomainController>
  </Domain>
  <Database>
    <DBOption>LocalDB</DBOption>
  </Database>
  <HeadNode>
    <VMName>MyHeadNode</VMName>
    <ServiceName>MyHPCService</ServiceName>
    <VMSize>ExtraLarge</VMSize>
  </HeadNode>
  <LinuxComputeNodes>
    <VMNamePattern>MyLnxCN-%0001%</VMNamePattern>
    <ServiceNamePattern>MyLnxCNService%01%</ServiceNamePattern>
    <MaxNodeCountPerService>5</MaxNodeCountPerService>
    <StorageAccountNamePattern>mylnxstorage%01%</StorageAccountNamePattern>
    <VMSize>Medium</VMSize>
    <NodeCount>10</NodeCount>
    <ImageName>5112500ae3b842c8b9c604889f8753c3__OpenLogic-CentOS-70-20150325 </ImageName>
  </LinuxComputeNodes>
</IaaSClusterConfig>

문제 해결

  • "VNet이 없음" 오류. HPC 팩 IaaS 배포 스크립트를 실행하여 Azure에서 여러 클러스터를 동시에 하나의 구독으로 배포하는 경우 "VNet VNet_Name 존재하지 않음" 오류와 함께 하나 이상의 배포가 실패할 수 있습니다. 이 오류가 발생할 경우 실패한 배포에 대해 스크립트를 다시 실행합니다.

  • Azure 가상 네트워크에서 인터넷에 액세스할 수 없는 문제. 배포 스크립트를 사용하여 새 도메인 컨트롤러로 HPC Pack 클러스터를 만들거나 헤드 노드 VM을 도메인 컨트롤러로 수동으로 승격할 경우 Azure 가상 네트워크의 VM에서 인터넷으로 연결할 때 문제가 발생할 수 있습니다. 이러한 문제는 전달자 DNS 서버가 도메인 컨트롤러에 자동으로 구성되어 있고 이 전달자 DNS 서버가 올바르게 확인되지 않을 경우 발생할 수 있습니다.

    이 문제를 해결하려면 도메인 컨트롤러에 로그인하고 전달자 구성 설정을 제거하거나 유효한 전달자 DNS 서버를 구성합니다. 이렇게 하려면 서버 관리자 ToolsDNS> 를 클릭하여 DNS 관리자를 연 다음 전달자를 두 번 클릭합니다.

다음 단계