Azure용 CentOS 기반 가상 머신 준비
주의
이 문서에서는 EOL(수명 종료) 상태에 가까워진 Linux 배포판인 CentOS를 참조합니다. 사용 및 계획을 적절하게 고려하세요. 자세한 내용은 CentOS 수명 종료 지침을 참조하세요.
적용 대상: ✔️ Linux VM ✔️ 유연한 확장 집합
CentOS 기반 Linux OS(운영 체제)가 포함된 Azure VHD(가상 하드 디스크)를 만들고 업로드하는 방법에 대해 알아봅니다. 자세한 내용은 다음을 참조하세요.
필수 조건
이 문서에서는 이미 CentOS(또는 유사한 파생) Linux OS를 VHD에 설치했다고 가정합니다. .vhd 파일을 만드는 도구는 여러 가지가 있습니다. 예를 들어 Hyper-V와 같은 가상화 솔루션이 있습니다. 지침은 Hyper-V 역할 설치 및 VM 구성을 참조하세요.
CentOS 설치 참고 사항
- Azure용 Linux를 준비하는 방법에 대한 추가 팁은 일반 Linux 설치 참고 사항을 참조하세요.
- VHDX 형식은 Azure에서 지원되지 않습니다. 고정된 VHD만 지원됩니다. Hyper-V 관리자 또는
convert-vhd
cmdlet을 사용하여 디스크를 VHD 형식으로 변환할 수 있습니다. VirtualBox를 사용하는 경우 디스크를 만들 때 동적으로 할당되는 기본값과 달리 고정 크기를 선택합니다. - 커널에서 vfat 커널 모듈을 사용하도록 설정해야 합니다.
- Linux 시스템을 설치하는 경우 설치 기본값인 경우가 많은 LVM(논리 볼륨 관리자)이 아닌 표준 파티션을 사용하는 것이 좋습니다. 파티션을 사용하면 특히 문제 해결을 위해 OS 디스크를 다른 VM에 연결해야 하는 경우 복제된 VM과 LVM 이름이 충돌하지 않도록 방지합니다. 데이터 디스크에서 LVM 또는 RAID를 사용할 수도 있습니다.
- UDF(사용자 정의 함수) 파일 시스템을 탑재하기 위해 커널 지원이 필요합니다. Azure에서 처음 부팅할 때 게스트에 연결된 UDF 형식의 미디어를 사용하여 Linux VM에 프로비전 구성이 전달됩니다. Azure Linux 에이전트 또는
cloud-init
은 해당 구성을 읽고 VM을 프로비전하기 위해 UDF 파일 시스템을 탑재해야 합니다. - 2.6.37 버전 미만의 Linux 커널은 VM 크기가 더 클 때 Hyper-V에서 NUMA를 지원하지 않습니다. 이 문제는 주로 업스트림 Centos 2.6.32 커널을 사용하는 이전 배포에 영향을 주며 Centos 6.6(kernel-2.6.32-504)에서는 해결되었습니다. 2.6.37 이전의 사용자 지정 커널 또는 2.6.32-504 이전의 RHEL(Red Hat Enterprise Linux) 기반 커널을 실행하는 시스템의 경우 grub.conf의 커널 명령줄에
numa=off
부트 매개 변수를 설정해야 합니다. 자세한 내용은 Red Hat KB 436883을 참조하세요. - OS 디스크에 스왑 파티션을 구성하지 않습니다.
- Azure의 모든 VHD에는 1MB로 정렬된 가상 크기가 있어야 합니다. 원시 디스크에서 VHD로 변환할 때 변환하기 전에 원시 디스크 크기가 1MB의 배수인지 확인해야 합니다. 자세한 내용은 Linux 설치 참고 사항을 참조하세요.
참고 항목
Cloud-init >= 21.2는 UDF 요구 사항을 제거합니다. 그러나 UDF 모듈을 사용하도록 설정하지 않으면 프로비전 중에 CD-ROM이 탑재되지 않아 사용자 지정 데이터가 적용되지 않습니다. 이 상황에 대한 해결 방법은 사용자 데이터를 사용하여 사용자 지정 데이터를 적용하는 것입니다. 사용자 지정 데이터와 달리 사용자 데이터는 암호화되지 않습니다. 자세한 내용은 사용자 데이터 형식을 참조하세요.
CentOS 6.x
Important
CentOS 6은 EOL에 도달했으며 CentOS 커뮤니티에서 더 이상 지원되지 않습니다. 이 버전에 대한 추가 업데이트 또는 보안 패치가 릴리스되지 않으므로 잠재적인 보안 위험에 취약합니다. 시스템의 안전과 안정성을 보장하기 위해 최신 버전의 CentOS로 업그레이드하는 것이 좋습니다. 추가 지원이 필요한 경우 IT 부서 또는 시스템 관리자에게 문의하세요.
Hyper-V 관리자에서 VM을 선택합니다.
연결을 선택하여 VM에 대한 콘솔 창을 엽니다.
CentOS 6에서
NetworkManager
는 Azure Linux 에이전트를 방해할 수 있습니다. 이 패키지를 제거합니다.sudo rpm -e --nodeps NetworkManager
파일
/etc/sysconfig/network
를 만들거나 편집하고 다음 텍스트를 추가합니다.NETWORKING=yes HOSTNAME=localhost.localdomain
파일
/etc/sysconfig/network-scripts/ifcfg-eth0
를 만들거나 편집하고 다음 텍스트를 추가합니다.DEVICE=eth0 ONBOOT=yes BOOTPROTO=dhcp TYPE=Ethernet USERCTL=no PEERDNS=yes IPV6INIT=no
이더넷 인터페이스에 대한 정적 규칙을 생성하지 않도록 방지하는 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
부팅 시 네트워크 서비스가 시작되는지 확인합니다.
sudo chkconfig network on
Azure 데이터 센터 내에서 호스트되는 OpenLogic 미러를 사용하려면
/etc/yum.repos.d/CentOS-Base.repo
파일을 다음 리포지토리로 바꿉니다. 또한 이 작업은 Azure Linux 에이전트와 같은 추가 패키지를 포함하는 [openlogic] 리포지토리를 추가합니다.[openlogic] name=CentOS-$releasever - openlogic packages for $basearch baseurl=http://olcentgbl.trafficmanager.net/openlogic/$releasever/openlogic/$basearch/ enabled=1 gpgcheck=0 [base] name=CentOS-$releasever - Base #mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=os&infra=$infra baseurl=http://olcentgbl.trafficmanager.net/centos/$releasever/os/$basearch/ gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6 #released updates [updates] name=CentOS-$releasever - Updates #mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=updates&infra=$infra baseurl=http://olcentgbl.trafficmanager.net/centos/$releasever/updates/$basearch/ gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6 #additional packages that might be useful [extras] name=CentOS-$releasever - Extras #mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=extras&infra=$infra baseurl=http://olcentgbl.trafficmanager.net/centos/$releasever/extras/$basearch/ gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6 #additional packages that extend functionality of existing packages [centosplus] name=CentOS-$releasever - Plus #mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=centosplus&infra=$infra baseurl=http://olcentgbl.trafficmanager.net/centos/$releasever/centosplus/$basearch/ gpgcheck=1 enabled=0 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6 #contrib - packages by Centos Users [contrib] name=CentOS-$releasever - Contrib #mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=contrib&infra=$infra baseurl=http://olcentgbl.trafficmanager.net/centos/$releasever/contrib/$basearch/ gpgcheck=1 enabled=0 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
참고 항목
이 문서의 나머지 부분에서는 최소 Azure Linux 에이전트를 설치하는 데 사용되는
[openlogic]
리포지토리를 사용한다고 가정합니다.다음 줄을
/etc/yum.conf
에 추가합니다.http_caching=packages
현재 yum 메타데이터를 지우고 최신 패키지로 시스템을 업데이트합니다.
sudo yum clean all
이전 버전의 CentOS에 대한 이미지를 만드는 경우가 아니면 모든 패키지를 최신으로 업데이트하는 것이 좋습니다.
sudo yum -y update
이 명령을 실행한 후 다시 부팅해야 할 수 있습니다.
선택 사항: LIS(Linux 통합 서비스)용 드라이버를 설치합니다.
Important
이 단계는 CentOS 6.3 및 이전 버전에 필수이고 최신 릴리스에서는 선택 사항입니다.
sudo rpm -e hypervkvpd ## (might return an error if not installed, that's OK) sudo yum install microsoft-hyper-v
또는 LIS 다운로드 페이지의 수동 설치 지침에 따르고 VM에 RPM을 설치할 수 있습니다.
Azure Linux 에이전트 및 종속성을 설치합니다.
waagent
서비스를 시작하고 사용하도록 설정합니다:sudo yum install python-pyasn1 WALinuxAgent sudo service waagent start sudo chkconfig waagent on
WALinuxAgent 패키지는 3단계에서 설명한 대로 아직 제거되지 않은 경우
NetworkManager
및NetworkManager-gnome
패키지를 제거합니다.Azure용 다른 커널 매개 변수를 포함하려면 grub 구성에서 커널 부팅 줄을 수정합니다. 이 단계를 수행하려면
/boot/grub/menu.lst
를 텍스트 편집기에서 열고 기본 커널이 다음 매개 변수를 포함하는지 확인합니다.console=ttyS0 earlyprintk=ttyS0 rootdelay=300
이 수정은 모든 콘솔 메시지를 첫 번째 직렬 포트로 전송하므로 Azure 지원에서 문제를 디버깅하는 데에도 도움이 될 수 있습니다.
또한 다음 매개 변수를 제거하는 것이 좋습니다.
rhgb quiet crashkernel=auto
모든 로그를 직렬 포트로 보내려는 클라우드 환경에서는 그래픽 및 자동 부팅 기능이 유용하지 않습니다. 원하는 경우
crashkernel
옵션을 구성된 상태로 둘 수 있습니다. 그러나 이 매개 변수는 VM에서 사용 가능한 메모리 양을 128MB 이상 줄여 더 작은 VM 크기에서는 문제가 될 수 있습니다.Important
또한 CentOS 6.5 및 이전 버전에서는 커널 매개 변수
numa=off
를 설정해야 합니다. 자세한 내용은 Red Hat KB 436883을 참조하세요.Secure Shell 서버가 설치되어 부팅 시 시작되도록 구성되어 있는지 확인합니다. 이 설정이 일반적으로 기본값입니다.
OS 디스크에 스왑 공간을 만들지 않습니다.
Azure Linux 에이전트는 Azure에서 VM을 프로비전한 후에 VM에 연결된 로컬 리소스 디스크를 사용하여 자동으로 스왑 공간을 구성할 수 있습니다. 로컬 리소스 디스크는 임시 디스크이며, VM의 프로비전을 해제할 때 비울 수 있습니다. Azure Linux 에이전트를 설치한 후에(이전 단계 참조)
/etc/waagent.conf
에서 다음 매개 변수를 적절하게 수정합니다.ResourceDisk.Format=y ResourceDisk.Filesystem=ext4 ResourceDisk.MountPoint=/mnt/resource ResourceDisk.EnableSwap=y ResourceDisk.SwapSizeMB=2048 ## NOTE: set this to whatever you need it to be.
VM 프로비전을 해제하고 Azure에서 프로비전할 수 있도록 준비합니다.
sudo waagent -force -deprovision+user sudo export HISTSIZE=0
참고 항목
특정 VM을 마이그레이션하고 범용 이미지를 만들지 않으려면 프로비전 해제 단계를 건너뜁니다.
Hyper-V 관리자에서 작업>종료를 선택합니다. 이제 Linux VHD를 Azure에 업로드할 수 있습니다.
CentOS 7.0 이상
CentOS 7.0 이상을 사용하는 경우 다음 섹션의 단계를 따릅니다.
CentOS 7 및 유사한 파생 버전의 변경 내용
Azure용 CentOS 7 VM을 준비하는 것은 CentOS 6과 비슷합니다. 몇 가지 중요한 차이점은 주목할 가치가 있습니다.
NetworkManager
패키지가 더 이상 Azure Linux 에이전트와 충돌하지 않습니다. 이 패키지는 기본적으로 설치되며 제거하지 않는 것이 좋습니다.이제 GRUB2가 기본 부팅 로더로 사용되므로 커널 매개 변수를 편집하는 절차가 변경되었습니다. ("구성 단계" 섹션을 참조하세요.)
이제 XFS가 기본 파일 시스템입니다. 원하는 경우 ext4 파일 시스템을 계속 사용할 수 있습니다.
CentOS 8 Stream 이상은 더 이상 기본적으로
network.service
를 포함하지 않으므로 수동으로 설치해야 합니다.sudo yum install network-scripts sudo systemctl enable network.service
구성 단계
Hyper-V 관리자에서 VM을 선택합니다.
연결을 선택하여 VM에 대한 콘솔 창을 엽니다.
파일
/etc/sysconfig/network
를 만들거나 편집하고 다음 텍스트를 추가합니다.NETWORKING=yes HOSTNAME=localhost.localdomain
파일
/etc/sysconfig/network-scripts/ifcfg-eth0
를 만들거나 편집하고 다음 텍스트를 추가합니다.DEVICE=eth0 ONBOOT=yes BOOTPROTO=dhcp TYPE=Ethernet USERCTL=no PEERDNS=yes IPV6INIT=no NM_CONTROLLED=no
이더넷 인터페이스에 대한 정적 규칙을 생성하지 않도록 방지하는 udev 규칙을 수정합니다. 이러한 규칙은 Azure 또는 Hyper-V에서 VM을 복제할 때 문제를 일으킬 수 있습니다.
sudo ln -s /dev/null /etc/udev/rules.d/75-persistent-net-generator.rules
Azure 데이터 센터 내에서 호스트되는
OpenLogic
미러를 사용하려면 /etc/yum.repos.d/CentOS-Base.repo 파일을 다음 리포지토리로 바꿉니다. 또한 이 작업은 Azure Linux 에이전트의 패키지를 포함하는 [openlogic] 리포지토리를 추가합니다.[openlogic] name=CentOS-$releasever - openlogic packages for $basearch baseurl=http://olcentgbl.trafficmanager.net/openlogic/$releasever/openlogic/$basearch/ enabled=1 gpgcheck=0 [base] name=CentOS-$releasever - Base #mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=os&infra=$infra baseurl=http://olcentgbl.trafficmanager.net/centos/$releasever/os/$basearch/ gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7 #released updates [updates] name=CentOS-$releasever - Updates #mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=updates&infra=$infra baseurl=http://olcentgbl.trafficmanager.net/centos/$releasever/updates/$basearch/ gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7 #additional packages that might be useful [extras] name=CentOS-$releasever - Extras #mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=extras&infra=$infra baseurl=http://olcentgbl.trafficmanager.net/centos/$releasever/extras/$basearch/ gpgcheck=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7 #additional packages that extend functionality of existing packages [centosplus] name=CentOS-$releasever - Plus #mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=centosplus&infra=$infra baseurl=http://olcentgbl.trafficmanager.net/centos/$releasever/centosplus/$basearch/ gpgcheck=1 enabled=0 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
참고 항목
이 문서의 나머지 부분에서는 최소 Azure Linux 에이전트를 설치하는 데 사용되는
[openlogic]
리포지토리를 사용한다고 가정합니다.현재 yum 메타데이터를 지우고 모든 업데이트를 설치합니다.
sudo yum clean all
이전 버전의 CentOS에 대한 이미지를 만드는 경우가 아니면 모든 패키지를 최신으로 업데이트하는 것이 좋습니다.
sudo yum -y update
이 명령을 실행한 후 다시 부팅해야 할 수 있습니다.
Azure용 다른 커널 매개 변수를 포함하려면 grub 구성에서 커널 부팅 줄을 수정합니다. 이 단계를 수행하려면 텍스트 편집기에서
/etc/default/grub
을 열고GRUB_CMDLINE_LINUX
매개 변수를 편집합니다. 예시:GRUB_CMDLINE_LINUX="rootdelay=300 console=ttyS0 earlyprintk=ttyS0 net.ifnames=0"
이 수정은 모든 콘솔 메시지를 첫 번째 직렬 포트로 전송하므로 Azure 지원에서 문제를 디버깅하는 데에도 도움이 될 수 있습니다. 네트워크 인터페이스 카드에 대한 새 CentOS 7 명명 규칙도 해제합니다. 또한 다음 매개 변수를 제거하는 것이 좋습니다.
rhgb quiet crashkernel=auto
모든 로그를 직렬 포트로 보내려는 클라우드 환경에서는 그래픽 및 자동 부팅 기능이 유용하지 않습니다. 원하는 경우
crashkernel
옵션을 구성된 상태로 둘 수 있습니다. 그러나 이 매개 변수는 VM에서 사용 가능한 메모리 양을 128MB 이상 줄여 더 작은 VM 크기에서는 문제가 될 수 있습니다./etc/default/grub
편집을 마친 후 grub 구성을 다시 빌드합니다.sudo grub2-mkconfig -o /boot/grub2/grub.cfg
참고 항목
UEFI를 사용하는 VM을 업로드하는 경우 grub을 업데이트하는 명령은
grub2-mkconfig -o /boot/efi/EFI/centos/grub.cfg
입니다. 또한 커널에서 vfat 커널 모듈을 사용하도록 설정해야 합니다. 그렇지 않으면 프로비전이 실패합니다.udf 모듈을 사용할 수 있는지 확인합니다. 이러한 모듈을 제거하거나 사용하지 않도록 설정하면 프로비전 또는 부팅 실패가 발생합니다. (_Cloud-init >= 21.2는 udf 요구 사항을 제거합니다. 자세한 내용은 문서 상단을 참조하세요.)
VMware, VirtualBox 또는 KVM에서 이미지를 빌드하는 경우 Hyper-V 드라이버가 initramfs에 포함되어 있는지 확인합니다.
/etc/dracut.conf
을 편집하고 콘텐츠를 추가합니다.add_drivers+=" hv_vmbus hv_netvsc hv_storvsc "
initramfs를 다시 빌드합니다.
sudo dracut -f -v
Azure VM 확장에 대한 Azure Linux 에이전트 및 종속성을 설치합니다.
sudo yum install python-pyasn1 WALinuxAgent sudo systemctl enable waagent
cloud-init
을 설치하여 프로비전을 처리합니다.sudo yum install -y cloud-init cloud-utils-growpart gdisk hyperv-daemons
cloud-init
에 대해waagent
를 구성합니다.
sudo sed -i 's/Provisioning.Agent=auto/Provisioning.Agent=auto/g' /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
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
sudo 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/swapfile ]]; then echo Removing swapfile - RHEL 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
스왑 구성:
OS 디스크에 스왑 공간을 만들지 않습니다.
이전에는 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
스왑 파일을 탑재하고, 포맷하고, 만들고자 하는 경우 다음 방법 중 하나를 수행합니다.
VM을 만들 때마다 이 명령을
cloud-init
구성으로 전달합니다.VM이 만들어질 때마다 이 단계를 수행하는 이미지에 포함된
cloud-init
지시문을 사용합니다.sudo echo 'DefaultEnvironment="CLOUD_CFG=/etc/cloud/cloud.cfg.d/00-azure-swap.cfg"' >> /etc/systemd/system.conf sudo 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"] - ["ephemeral0.2", "none", "swap", "sw,nofail,x-systemd.requires=cloud-init.service,x-systemd.device-timeout=2", "0", "0"] EOF
다음 명령을 실행하여 VM의 프로비전을 해제하고 Azure에서 프로비전을 준비합니다.
참고 항목
특정 VM을 마이그레이션하고 범용 이미지를 만들지 않으려면 프로비전 해제 단계를 건너뜁니다.
sudo rm -f /var/log/waagent.log sudo cloud-init clean sudo waagent -force -deprovision+user sudo rm -f ~/.bash_history sudo export HISTSIZE=0
Hyper-V 관리자에서 작업>종료를 선택합니다. 이제 Linux VHD를 Azure에 업로드할 수 있습니다.
관련 콘텐츠
이제 CentOS Linux VHD를 사용하여 Azure에서 새 VM을 만들 준비가 되었습니다. .vhd 파일을 Azure에 처음 업로드하는 경우 사용자 지정 디스크에서 Linux VM 만들기를 참조하세요.