Azure용 Oracle Linux 가상 머신 준비

적용 대상: ✔️ Linux VM ✔️ 유연한 확장 집합

이 문서에서는 VHD(가상 하드 디스크)에 Oracle Linux OS(운영 체제)를 이미 설치했다고 가정합니다. .vhd 파일을 만드는 도구는 여러 가지가 있습니다. 예를 들어 Hyper-V와 같은 가상화 솔루션이 있습니다. 자세한 내용은 Hyper-V 역할 설치 및 VM(가상 머신) 구성을 참조하세요.

Oracle Linux 설치 참고 사항

  • Azure용 Linux를 준비하는 방법에 대한 추가 팁은 일반 Linux 설치 참고 사항을 참조하세요.
  • Hyper-V 및 Azure는 UEK(Unbreakable Enterprise Kernel) 또는 Red Hat 호환 커널을 사용하는 Oracle Linux를 지원합니다.
  • Oracle의 UEK2는 필수 드라이버를 포함하지 않으므로 Hyper-V 및 Azure에서 지원되지 않습니다.
  • VHDX 형식은 Azure에서 지원되지 않습니다. 고정된 VHD만 지원됩니다. Hyper-V 관리자 또는 convert-vhd cmdlet을 사용하여 디스크를 VHD 형식으로 변환할 수 있습니다.
  • UDF(사용자 정의 함수) 파일 시스템을 탑재하기 위해 커널 지원이 필요합니다. Azure에서 처음 부팅 시 프로비저닝 구성이 게스트에 연결된 UDF 형식의 미디어를 통해 Linux VM에 전달됩니다. Azure Linux 에이전트는 해당 구성을 읽고 VM을 프로비전하기 위해 UDF 파일 시스템을 탑재할 수 있어야 합니다.
  • Linux 시스템을 설치하는 경우 설치 기본값인 경우가 많은 LVM(논리 볼륨 관리자)이 아닌 표준 파티션을 사용하는 것이 좋습니다. 이러한 표준 파티션은 특히 문제 해결을 위해 OS 디스크를 다른 VM에 연결해야 하는 경우 복제된 VM과 LVM 이름이 충돌하지 않도록 방지합니다. 데이터 디스크에서 LVM 또는 RAID를 사용할 수도 있습니다.
  • 2.6.37 이전 버전의 Linux 커널은 더 큰 VM 크기의 Hyper-V에서 NUMA를 지원하지 않습니다. 이 문제는 주로 업스트림 Red Hat 2.6.32 커널을 사용하는 이전 배포에 영향을 주며 Oracle Linux 6.6 이상에서 해결되었습니다.
  • OS 디스크에 스왑 파티션을 구성하지 않습니다.
  • Azure의 모든 VHD에는 1MB로 정렬된 가상 크기가 있어야 합니다. 원시 디스크에서 VHD로 변환할 때 변환하기 전에 원시 디스크 크기가 1MB의 배수인지 확인해야 합니다. 자세한 내용은 Linux 설치 참고 사항을 참조하세요.
  • Addons 리포지토리가 사용되도록 설정되었는지 확인합니다. 파일 /etc/yum.repos.d/public-yum-ol6.repo(Oracle Linux 6) 또는 /etc/yum.repos.d/public-yum-ol7.repo(Oracle Linux 7)를 편집합니다. 이 파일의 [ol6_addons] 또는 [ol7_addons] 아래에서 줄 enabled=0을(를) enabled=1(으)로 변경합니다.

Oracle Linux 6.X

Important

Oracle Linux 6.x는 이미 수명이 다했습니다. Oracle Linux 버전 6.10에는 2024년 7월에 종료되는 확장 수명 주기 지원 기능이 있습니다.

VM이 Azure에서 실행되도록 OS에서 특정 구성 단계를 완료해야 합니다.

  1. Hyper-V 관리자의 가운데 창에서 VM을 선택합니다.

  2. 연결을 선택하여 VM 창을 엽니다.

  3. NetworkManager 제거:

    sudo rpm -e --nodeps NetworkManager
    

    참고 항목

    패키지가 아직 설치되어 있지 않은 경우 이 명령이 실패하고 오류 메시지가 표시됩니다. 이 메시지가 필요합니다.

  4. 다음 텍스트가 포함된 network in the /etc/sysconfig/ 디렉터리에 만듭니다.

    NETWORKING=yes
    HOSTNAME=localhost.localdomain
    
  5. 다음 텍스트가 포함된 ifcfg-eth0 in the /etc/sysconfig/network-scripts/ 디렉터리에 만듭니다.

    DEVICE=eth0
    ONBOOT=yes
    BOOTPROTO=dhcp
    TYPE=Ethernet
    USERCTL=no
    PEERDNS=yes
    IPV6INIT=no
    
  6. 이더넷 인터페이스에 대한 정적 규칙을 생성하지 않도록 방지하는 udev 규칙을 수정합니다. 이러한 규칙은 Azure 또는 Hyper-V에서 VM을 복제할 때 문제를 일으킬 수 있습니다.

    sudo ln -s /dev/null /etc/udev/rules.d/75-persistent-net-generator.rules
    sudo rm -f /etc/udev/rules.d/70-persistent-net.rules
    
  7. 부팅 시 네트워크 서비스가 시작되는지 확인합니다.

    sudo chkconfig network on
    
  8. python-pyasn1 설치:

    sudo yum install python-pyasn1
    
  9. Azure용 커널 매개 변수를 추가로 포함하려면 grub 구성에서 커널 부팅 줄을 수정합니다. 이 단계를 수행하려면 /boot/grub/menu.lst을(를) 텍스트 편집기에서 열고 커널이 다음 매개 변수를 포함하는지 확인합니다.

    console=ttyS0 earlyprintk=ttyS0
    

    이 설정은 모든 콘솔 메시지가 Azure에서 디버깅 문제를 지원할 수 있는 첫 번째 직렬 포트로 전송되게 합니다.

    이전 단계 외에도 작업을 수행하는 동시에 다음 매개 변수를 제거 하는 것이 좋습니다.

    rhgb quiet crashkernel=auto
    

    모든 로그를 직렬 포트로 보내려는 클라우드 환경에서는 그래픽 및 자동 부팅 기능이 유용하지 않습니다.

    원하는 경우 crashkernel 옵션을 구성된 상태로 둘 수 있습니다. 이 매개 변수는 VM에서 사용 가능한 메모리 양을 128MB 이상 줄입니다. 이는 더 작은 VM 크기에 문제가 될 수 있습니다.

  10. SSH 서버가 설치되어 부팅 시 시작되도록 구성되어 있는지 확인합니다. 이 설정이 일반적으로 기본값입니다.

  11. 다음 명령을 실행하여 Azure Linux 에이전트를 설치합니다. 최신 버전은 2.0.15입니다.

    sudo yum install WALinuxAgent
    

    WALinuxAgent 패키지를 설치하면 2단계에서 설명한 대로 패키지가 아직 제거되지 않은 경우 NetworkManagerNetworkManager-gnome 패키지가 제거됩니다.

  12. OS 디스크에 스왑 공간을 만들지 않습니다.

    Azure Linux 에이전트는 Azure에서 프로비전한 후 VM에 연결된 로컬 리소스 디스크를 사용하여 자동으로 스왑 공간을 구성할 수 있습니다. 로컬 리소스 디스크는 임시 디스크이며, VM의 프로비전을 해제할 때 비울 수 있습니다. Azure Linux 에이전트를 설치한 후에(이전 단계 참조) /etc/waagent.conf에서 다음 매개 변수를 적절하게 수정합니다.

    ResourceDisk.Format=y
    ResourceDisk.Filesystem=ext4
    ResourceDisk.MountPoint=/mnt
    ResourceDisk.EnableSwap=y
    ResourceDisk.SwapSizeMB=2048    ## NOTE: set this to whatever you need it to be.
    
  13. VM 프로비전을 해제하고 Azure에서 프로비전할 수 있도록 준비합니다.

    sudo waagent -force -deprovision
    sudo export HISTSIZE=0
    sudo logout
    
  14. Hyper-V 관리자에서 작업>종료를 선택합니다. 이제 Linux VHD를 Azure에 업로드할 수 있습니다.


Oracle Linux 7.0 이상

Oracle Linux 7.0 이상을 사용하는 경우 다음 섹션의 단계를 따릅니다.

Oracle Linux 7의 변경 내용

Azure용 Oracle Linux 7 VM 준비는 Oracle Linux 6과 유사하지만 몇 가지 차이점에 주목할 필요가 있습니다.

  • Azure는 UEK(Unbreakable Enterprise Kernel) 또는 Red Hat 호환 커널을 사용하는 Oracle Linux를 지원합니다. UEK에서 Oracle Linux를 사용하는 것이 좋습니다.
  • NetworkManager 패키지가 더 이상 Azure Linux 에이전트와 충돌하지 않습니다. 이 패키지는 기본적으로 설치되며 제거하지 않는 것이 좋습니다.
  • 이제 GRUB2가 기본 부팅 로더로 사용되므로 커널 매개 변수를 편집하는 절차가 변경되었습니다. ("구성 단계" 섹션을 참조하세요.)
  • 이제 XFS가 기본 파일 시스템입니다. 원하는 경우 ext4 파일 시스템을 계속 사용할 수 있습니다.

구성 단계

  1. Hyper-V 관리자에서 VM을 선택합니다.

  2. 연결을 선택하여 VM에 대한 콘솔 창을 엽니다.

  3. 다음 텍스트가 포함된 network in the /etc/sysconfig/ 디렉터리에 만듭니다.

    NETWORKING=yes
    HOSTNAME=localhost.localdomain
    
  4. 다음 텍스트가 포함된 ifcfg-eth0 in the /etc/sysconfig/network-scripts/ 디렉터리에 만듭니다.

    DEVICE=eth0
    ONBOOT=yes
    BOOTPROTO=dhcp
    TYPE=Ethernet
    USERCTL=no
    PEERDNS=yes
    IPV6INIT=no
    
  5. 이더넷 인터페이스에 대한 정적 규칙을 생성하지 않도록 방지하는 udev 규칙을 수정합니다. 이러한 규칙은 Azure 또는 Hyper-V에서 VM을 복제할 때 문제를 일으킬 수 있습니다.

    sudo ln -s /dev/null /etc/udev/rules.d/75-persistent-net-generator.rules
    
  6. 부팅 시 네트워크 서비스가 시작되는지 확인합니다.

    sudo chkconfig network on
    
  7. python-pyasn1 패키지를 설치합니다.

    sudo yum install python3-pyasn1
    
  8. 현재 yum 메타데이터를 지우고 모든 업데이트를 설치합니다.

    sudo yum clean all
    sudo yum -y update
    
  9. Azure용 커널 매개 변수를 추가로 포함하려면 grub 구성에서 커널 부팅 줄을 수정합니다. 이 단계를 수행하려면 텍스트 편집기에서 /etc/default/grub를 열고 GRUB_CMDLINE_LINUX 매개 변수를 편집합니다. 예시:

    GRUB_CMDLINE_LINUX="console=ttyS0 earlyprintk=ttyS0 net.ifnames=0"
    

    이 수정은 모든 콘솔 메시지를 첫 번째 직렬 포트로 전송하므로 Azure 지원에서 문제를 디버깅하는 데에도 도움이 될 수 있습니다. 또한 UEK를 사용하는 Oracle Linux 7의 네트워크 인터페이스 카드에 대한 명명 규칙도 해제합니다. 또한 다음 매개 변수를 제거하는 것이 좋습니다.

       rhgb quiet crashkernel=auto
    

    모든 로그를 직렬 포트로 보내려는 클라우드 환경에서는 그래픽 및 자동 부팅 기능이 유용하지 않습니다.

    원하는 경우 crashkernel 옵션을 구성된 상태로 둘 수 있습니다. 이 매개 변수는 VM에서 사용 가능한 메모리 양을 128MB 이상 줄입니다. 이는 더 작은 VM 크기에 문제가 될 수 있습니다.

  10. /etc/default/grub 편집을 마친 후 grub 구성을 다시 빌드합니다.

    sudo grub2-mkconfig -o /boot/grub2/grub.cfg
    
  11. SSH 서버가 설치되어 부팅 시 시작되도록 구성되어 있는지 확인합니다. 이 설정이 일반적으로 기본값입니다.

  12. Azure Linux 에이전트 및 종속성을 설치합니다.

    sudo yum install WALinuxAgent
    sudo systemctl enable waagent
    
  13. cloud-init을 설치하여 프로비전을 처리합니다.

    sudo yum install -y cloud-init cloud-utils-growpart gdisk hyperv-daemons
    
  14. cloud-init에 대해 waagent를 구성합니다.

    sudo sed -i 's/Provisioning.UseCloudInit=n/Provisioning.UseCloudInit=y/g' /etc/waagent.conf
    sudo sed -i 's/Provisioning.Enabled=y/Provisioning.Enabled=n/g' /etc/waagent.conf
    
    sudo echo "Adding mounts and disk_setup to init stage"
    sudo sed -i '/ - mounts/d' /etc/cloud/cloud.cfg
    sudo sed -i '/ - disk_setup/d' /etc/cloud/cloud.cfg
    sudo sed -i '/cloud_init_modules/a\\ - mounts' /etc/cloud/cloud.cfg
    sudo sed -i '/cloud_init_modules/a\\ - disk_setup' /etc/cloud/cloud.cfg
    
    echo "Allow only Azure datasource, disable fetching network setting via IMDS"
    
    sudo cat > /etc/cloud/cloud.cfg.d/91-azure_datasource.cfg <<EOF
    datasource_list: [ Azure ]
    datasource:
        Azure:
            apply_network_config: False
    EOF
    
    
    if [[ -f /mnt/resource/swapfile ]]; then
    echo Removing swapfile - Oracle Linux uses a swapfile by default
    swapoff /mnt/swapfile
    rm /mnt/swapfile -f
    fi
    
    echo "Add console log file"
    cat >> /etc/cloud/cloud.cfg.d/05_logging.cfg <<EOF
    
    # This tells cloud-init to redirect its stdout and stderr to
    # 'tee -a /var/log/cloud-init-output.log' so the user can see output
    # there without needing to look on the console.
    output: {all: '| tee -a /var/log/cloud-init-output.log'}
    EOF
    
  15. 스왑 구성:

    1. 운영 체제 디스크에 스왑 공간을 만들지 마세요.

      이전에는 Azure Linux 에이전트를 사용하여 Azure에서 VM을 프로비전한 후 VM에 연결된 로컬 리소스 디스크를 사용하여 스왑 공간을 자동으로 구성했습니다. 그러나 이제 cloud-init에서 이 단계를 처리합니다. Linux 에이전트를 사용하여 리소스 디스크를 포맷하여 스왑 파일을 만들어서는 안 됩니다. /etc/waagent.conf에서 다음 매개 변수를 적절하게 수정합니다.

      sudo sed -i 's/ResourceDisk.Format=y/ResourceDisk.Format=n/g' /etc/waagent.conf
      sudo sed -i 's/ResourceDisk.EnableSwap=y/ResourceDisk.EnableSwap=n/g' /etc/waagent.conf
      
    2. 교환을 탑재, 포맷 및 만들려면 다음 중 하나를 수행합니다.

      • VM을 만들 때마다 이 코드를 cloud-init 구성으로 전달합니다.
      • VM이 만들어질 때마다 이 단계를 수행하는 이미지에 포함된 cloud-init 지시문을 사용합니다.
      echo 'DefaultEnvironment="CLOUD_CFG=/etc/cloud/cloud.cfg.d/00-azure-swap.cfg"' >> /etc/systemd/system.conf
      cat > /etc/cloud/cloud.cfg.d/00-azure-swap.cfg << EOF
      #cloud-config
      # Generated by Azure cloud image build
      disk_setup:
        ephemeral0:
          table_type: mbr
          layout: [66, [33, 82]]
          overwrite: True
      fs_setup:
        - device: ephemeral0.1
          filesystem: ext4
        - device: ephemeral0.2
          filesystem: swap
      mounts:
        - ["ephemeral0.1", "/mnt/resource"]
        - ["ephemeral0.2", "none", "swap", "sw,nofail,x-systemd.requires=cloud-init.service,x-systemd.device-timeout=2", "0", "0"]
      EOF
      
  16. VM을 프로비전을 해제하고 Azure에서 프로비전할 수 있도록 준비합니다.

    sudo cloud-init clean
    sudo rm -f /var/log/waagent.log
    sudo waagent -force -deprovision
    sudo rm -f ~/.bash_history
    sudo export HISTSIZE=0
    

    참고 항목

    특정 VM을 마이그레이션하고 범용 이미지를 만들지 않으려면 프로비전 해제 단계를 건너뜁니다.

  17. Hyper-V 관리자에서 작업>종료를 선택합니다. 이제 Linux VHD를 Azure에 업로드할 수 있습니다.

이제 Oracle Linux .vhd를 사용하여 Azure에서 새 VM을 만들 준비가 되었습니다. .vhd 파일을 Azure에 처음 업로드하는 경우 사용자 지정 디스크에서 Linux VM 만들기를 참조하세요.