- 인쇄
- PDF
RHEL 8
- 인쇄
- PDF
네이버 클라우드 플랫폼 RedHat Enterprise Linux 8 서버의 커널 업데이트 방법을 설명합니다.
이 가이드는 네이버 클라우드 플랫폼에서 신규 생성한 서버를 기준으로 작성하였기 때문에 사용자 서버 환경과 차이가 있을 수 있습니다. 사용자 서버 환경은 보안 하드닝 작업이나 여러 설정 작업 등 다양한 이유로 커널 업데이트 작업 및 서버 재시작에 영향을 받을 수 있습니다. 따라서 다음 사항을 숙지하여 커널 업데이트를 수행해 주십시오.
- 실제 서버의 커널을 업데이트하기 전에 서버 이미지를 사용하여 복제 서버를 생성합니다. 생성한 복제 서버에서 커널 업데이트를 수행하고 정상적으로 재시작이 되는지 확인합니다. 재시작 후 운영 상태로 전환이 되면 서비스에 문제가 없는지 확인합니다. 충분히 검증한 후에 문제가 없을 경우에만 커널 업데이트를 수행해 주십시오.
- GPU 서버의 경우, 커널 버전에 맞는 GPU 드라이버가 설치되어 있어야만 정상적으로 동작합니다. 업데이트한 커널이 GPU 드라이버와 호환되지 않을 경우 GPU 서버가 정상 동작하지 않을 수 있습니다. 따라서 GPU 드라이버 호환성을 확인한 후 커널 업데이트를 수행해 주십시오. 관련 정보는 GPU 드라이버 가이드를 확인해 주십시오.
본 커널 업데이트 가이드는 이후로 정기 업데이트를 제공하지 않습니다. 따라서, 최신 정보를 확인하거나 다른 커널 버전을 설치할 경우, 해당 가이드를 참고하여 별도로 작업해 주시기 바랍니다.
가이드에 명시된 커널 버전은 하나의 예시이며, 필요에 따라 다른 커널 버전을 충분히 테스트한 후 설치해 주십시오.
- 사용자 서버 커널 업데이트는 전적으로 사용자의 책임 하에 수행되어야 하며, 커널 업데이트로 인해 발생하는 문제에 대해 네이버 클라우드 플랫폼에서 책임지지 않습니다.
- 커널 업데이트 및 재시작 중에는 서버의 정상적인 사용이 불가능할 수 있으며 이에 따른 복구는 지원하지 않습니다. 또한 커널 업데이트 실패 시 서버 복구를 지원하지 않습니다.
- 커널을 업데이트 전 서버 이미지를 통해 생성한 백업본은 백업이 필요 없을 때까지 보관해 주십시오.
- 이 가이드와 관련된 문제에 대해서는 별도 지원이 제공되지 않습니다.
업데이트 가능한 커널 버전 확인
RedHat Enterprise Linux 8 서버에서 업데이트 가능한 커널 버전을 확인하는 방법은 다음과 같습니다.
기본적으로 NCP Repo인 http://repo.fin-ncloud.com
가 Base URL로 설정되어 있으며, 공인 IP를 보유하거나 NAT가 구성된 Private Subnet 환경에서는 NCP Repo 대신 외부 Public Mirror 사이트로 Repository를 변경할 수 있습니다.
NCP Repo는 외부 접속이 제한되는 VPC Private Subnet 등 사용자 환경을 지원하기 위해 네이버 클라우드 플랫폼에서 제공하는 리포지토리입니다.
NCP Repo는 연 4회만 동기화되므로, 최신 패치를 빠르게 적용하려면 외부 Public Mirror 사이트로 변경하는 것을 권장합니다. 자세한 내용은 Linux OS Repository 설정 점검 가이드를 참고해 주십시오.
- 커널 업데이트를 적용할 서버에 원격 접속해 주십시오.
- 서버에 적용할 커널 버전을 확인해 주십시오.
[root@rhel810 ~]# dnf --showduplicates --releasever=8.10 list kernel Updating Subscription Management repositories. Unable to read consumer identity This system is not registered with an entitlement server. You can use subscription-manager to register. Installed Packages kernel.x86_64 4.18.0-553.16.1.el8_10 @System Available Packages ... 생략 kernel.x86_64 4.18.0-553.el8_10 rhel-8-for-x86_64-baseos-rpms kernel.x86_64 4.18.0-553.5.1.el8_10 rhel-8-for-x86_64-baseos-rpms kernel.x86_64 4.18.0-553.8.1.el8_10 rhel-8-for-x86_64-baseos-rpms kernel.x86_64 4.18.0-553.16.1.el8_10 rhel-8-for-x86_64-baseos-rpms kernel.x86_64 4.18.0-553.22.1.el8_10 rhel-8-for-x86_64-baseos-rpms
커널 업데이트
RedHat Enterprise Linux 8 서버의 커널을 업데이트하는 방법은 다음과 같습니다.
본 가이드에서는 RedHat Enterprise Linux 8 서버에서 커널 버전을 4.18.0-553.22.1.el8_10
로 업그레이드하는 예시를 제공합니다.
가이드를 참고하는 시점에 설치 가능한 커널 버전은 다를 수 있으니, 다른 버전도 충분히 테스트한 후 설치해 주십시오.
- 커널 업데이트를 적용할 서버에 원격 접속해 주십시오.
- 서버의 커널 버전을 확인해 주십시오.
[root@rhel810 ~]# uname -r 4.18.0-553.16.1.el8_10.x86_64
- 서버에 연결된 리포지토리 정보를 확인해 주십시오.
Repo 파일 수정이 필요할 경우에는 Linux OS Repository 설정 점검 가이드를 참고해서 리포지토리 정보를 수정해 주십시오.[root@rhel810 ~]# grep ^baseurl /etc/yum.repos.d/rhel-priv.repo baseurl=http://repo.fin-ncloud.com/rhel/$releasever/BaseOS baseurl=http://repo.fin-ncloud.com/rhel/$releasever/AppStream baseurl=http://repo.fin-ncloud.com/rhel/$releasever/rhel-8-for-x86_64-baseos-rpms baseurl=http://repo.fin-ncloud.com/rhel/$releasever/rhel-8-for-x86_64-appstream-rpms baseurl=http://repo.fin-ncloud.com/rhel/$releasever/rhel-8-for-x86_64-supplementary-rpms baseurl=http://repo.fin-ncloud.com/rhel/$releasever/codeready-builder-for-rhel-8-x86_64-rpms baseurl=http://repo.fin-ncloud.com/rhel/$releasever/ansible-2-for-rhel-8-x86_64-rpms baseurl=http://repo.fin-ncloud.com/rhel/$releasever/rhel-8-for-x86_64-highavailability-rpms baseurl=http://repo.fin-ncloud.com/rhel/$releasever/rhel-8-for-x86_64-resilientstorage-rpms
- 리포지토리에서 제공하는 커널 버전을 확인해 주십시오.참고
가이드 수행하는 시점에 따라 더 최신 커널 버전을 확인하는 방법은 Linux OS Repository 설정 점검 가이드를 참고 부탁드립니다.
[root@rhel810 ~]# rm -rf /var/cache/dnf/* [root@rhel810 ~]# yum --releasever=8.10 list kernel-4.18.0-553.22.1.el8_10 Updating Subscription Management repositories. Unable to read consumer identity This system is not registered with an entitlement server. You can use subscription-manager to register. Available Packages kernel.x86_64 4.18.0-553.22.1.el8_10 rhel-8-for-x86_64-baseos-rpms
- 최신 버전의 커널을 설치해 주십시오.
신규 설치 및 업데이트, 삭제되는 패키지 목록을 상세하게 확인하고, 이상없을 경우 y를 입력하여 커널 설치를 완료해 주십시오.[root@rhel810 ~]# yum --releasever=8.10 install kernel-4.18.0-553.22.1.el8_10 Updating Subscription Management repositories. Unable to read consumer identity This system is not registered with an entitlement server. You can use subscription-manager to register. Dependencies resolved. =============================================================================================================================================================================== Package Architecture Version Repository Size =============================================================================================================================================================================== Installing: kernel x86_64 4.18.0-553.22.1.el8_10 rhel-8-for-x86_64-baseos-rpms 10 M kernel-core x86_64 4.18.0-553.22.1.el8_10 rhel-8-for-x86_64-baseos-rpms 43 M kernel-modules x86_64 4.18.0-553.22.1.el8_10 rhel-8-for-x86_64-baseos-rpms 36 M Transaction Summary =============================================================================================================================================================================== Install 3 Packages Total download size: 90 M Installed size: 96 M Is this ok [y/N]: y (위의 설치되는 패키지, 업데이트되는 패키지, 삭제되는 패키지들을 면밀히 살펴보고 이상이 없을 때 y 로 진행) ... 생략 ... Installed: kernel-4.18.0-553.22.1.el8_10.x86_64 kernel-core-4.18.0-553.22.1.el8_10.x86_64 kernel-modules-4.18.0-553.22.1.el8_10.x86_64 Complete!
- 설치 완료된 후에 부팅 가능한 커널 버전 및 기본 부팅 커널 버전을 확인해 주십시오.
[root@rhel810 ~]# grubby --info=ALL | grep "^kernel" kernel="/boot/vmlinuz-4.18.0-553.22.1.el8_10.x86_64" kernel="/boot/vmlinuz-4.18.0-553.16.1.el8_10.x86_64" kernel="/boot/vmlinuz-0-rescue-1fe45f553b634401ac027ef85c71e078" [root@rhel810 ~]# ls -l /boot/loader/entries total 12 -rw-r--r--. 1 root root 409 Aug 28 16:09 1fe45f553b634401ac027ef85c71e078-0-rescue.conf -rw-r--r-- 1 root root 377 Sep 11 19:47 1fe45f553b634401ac027ef85c71e078-4.18.0-553.16.1.el8_10.x86_64.conf -rw-r--r-- 1 root root 377 Oct 30 15:04 1fe45f553b634401ac027ef85c71e078-4.18.0-553.22.1.el8_10.x86_64.conf [root@rhel810 ~]# grubby --default-kernel /boot/vmlinuz-4.18.0-553.22.1.el8_10.x86_64
참고설치한 커널 버전이 보이지 않은 경우, grub2-mkconfig 명령을 사용하여 grub.cfg를 다시 생성해 주십시오.
grub2-mkconfig -o /boot/grub2/grub.cfg - (선택사항) 기본 부팅 커널 버전이 설치한 커널 버전과 다른 경우, 기본 부팅 커널을 변경해 주십시오.
[root@rhel810 ~]# grubby --set-default="/boot/vmlinuz-4.18.0-553.22.1.el8_10.x86_64" The default is /boot/loader/entries/1fe45f553b634401ac027ef85c71e078-4.18.0-553.22.1.el8_10.x86_64.conf with index 0 and kernel /boot/vmlinuz-4.18.0-553.22.1.el8_10.x86_64 [root@rhel810 ~]# grubby --default-kernel /boot/vmlinuz-4.18.0-553.22.1.el8_10.x86_64
- 최신 커널 버전을 활성화하기 위해서 서버를 재부팅해 주십시오.
[root@rhel810 ~]# sync;reboot
- 서버에 다시 로그인하여 새로운 커널이 활성화 상태인지 확인해 주십시오.
[root@rhel810 ~]# uname -r 4.18.0-553.22.1.el8_10.x86_64
커널 업데이트 확인
업데이트 커널이 정상적으로 적용되었는지 확인하는 방법은 다음과 같습니다.
- 서버에 원격 접속해 주십시오.
- 커널 패키지가 설치되어 있는지 확인해 주십시오.
[root@rhel810 ~]# rpm -qa | grep kernel-4.18.0-553.22.1.el8_10.x86_64 kernel-4.18.0-553.22.1.el8_10.x86_64
- /boot 디렉터리에 initramfs 파일과 vmlinuz 파일이 생성되어 있는지 확인해 주십시오.참고
/boot/initramfs-<커널버전>.x86_64kdump.img 파일은 설정에 따라 생성이 안될 수도 있습니다.
[root@rhel810 ~]# ls -l /boot/initramfs-4.18.0-553.22.1.el8_10.x86_64.img -rw------- 1 root root 29497109 Oct 30 15:04 /boot/initramfs-4.18.0-553.22.1.el8_10.x86_64.img [root@rhel810 ~]# ls -l /boot/initramfs-4.18.0-553.22.1.el8_10.x86_64kdump.img -rw------- 1 root root 25144832 Oct 30 15:08 /boot/initramfs-4.18.0-553.22.1.el8_10.x86_64kdump.img [root@rhel810 ~]# ls -l /boot/vmlinuz-4.18.0-553.22.1.el8_10.x86_64 -rwxr-xr-x 1 root root 10880632 Sep 12 07:23 /boot/vmlinuz-4.18.0-553.22.1.el8_10.x86_64
- BLS(부트 로더 사양) 설정에 최신 커널 설정이 등록되어 있는지 확인해 주십시오.
[root@rhel810 ~]# ls -l /boot/loader/entries total 12 -rw-r--r--. 1 root root 409 Aug 28 16:09 1fe45f553b634401ac027ef85c71e078-0-rescue.conf -rw-r--r-- 1 root root 377 Sep 11 19:47 1fe45f553b634401ac027ef85c71e078-4.18.0-553.16.1.el8_10.x86_64.conf -rw-r--r-- 1 root root 377 Oct 30 15:04 1fe45f553b634401ac027ef85c71e078-4.18.0-553.22.1.el8_10.x86_64.conf
- grub 설정을 확인해 주십시오.
[root@rhel810 ~]# grubby --info=ALL | grep "^kernel" kernel="/boot/vmlinuz-4.18.0-553.22.1.el8_10.x86_64" kernel="/boot/vmlinuz-4.18.0-553.16.1.el8_10.x86_64" kernel="/boot/vmlinuz-0-rescue-1fe45f553b634401ac027ef85c71e078" [root@rhel810 ~]# grubby --default-kernel /boot/vmlinuz-4.18.0-553.22.1.el8_10.x86_64
커널 업데이트 원복
커널 업데이트 후 서버 재시작이 정상적으로 수행되지 않을 경우, 업데이트 이전의 커널로 되돌려야 합니다. 설치된 커널 중 여러 버전으로 원복할 수 있으며, 이 가이드에서는 커널 업데이트하기 직전에 사용한 커널 버전으로 원복하는 방법을 다루고 있습니다.
서버 재시작 문제를 해결하기 위해 Single mode에 진입하여 서버 복구를 시도할 수도 있습니다. Single mode 부팅 방법은 서버 복구 가이드를 참고해 주십시오.
네이버 클라우드 플랫폼 콘솔의 Region 메뉴와 Platform 메뉴에서 이용 중인 환경을 클릭해 주십시오.
Services > Compute > Server 메뉴를 차례대로 클릭해 주십시오.
Server 메뉴를 클릭해 주십시오.
서버 목록에서 복구할 서버를 선택한 후 [서버 접속 콘솔] 버튼을 선택하여 주십시오.
grub 부팅 화면에서 부팅 커널을 이전 버전으로 선택하여 재부팅해 주십시오.
- RedHat Enterprise Linux 8 grub 부팅 화면
- RedHat Enterprise Linux 8 grub 부팅 화면
부팅 완료 후에 서버의 커널 버전을 확인해 주십시오.
[root@rhel810 ~]# uname -r 4.18.0-553.16.1.el8_10.x86_64
현재 활성화된 커널 버전을 확인해 주십시오.
[root@rhel810 ~]# grubby --default-kernel /boot/vmlinuz-4.18.0-553.22.1.el8_10.x86_64 [root@rhel810 ~]# grubby --info=ALL | grep ^kernel kernel="/boot/vmlinuz-4.18.0-553.22.1.el8_10.x86_64" kernel="/boot/vmlinuz-4.18.0-553.16.1.el8_10.x86_64" kernel="/boot/vmlinuz-0-rescue-1fe45f553b634401ac027ef85c71e078"
부팅 시 기본값 커널 버전을 이전 버전의 커널 버전으로 재설정해 주십시오.
[root@rhel810 ~]# grubby --set-default="/boot/vmlinuz-4.18.0-553.16.1.el8_10.x86_64" The default is /boot/loader/entries/1fe45f553b634401ac027ef85c71e078-4.18.0-553.16.1.el8_10.x86_64.conf with index 1 and kernel /boot/vmlinuz-4.18.0-553.16.1.el8_10.x86_64 [root@rhel810 ~]# grubby --default-kernel /boot/vmlinuz-4.18.0-553.16.1.el8_10.x86_64
참고최신 버전 커널 업데이트 시에 기본 부팅 커널 설정을 변경했기 때문에, 커널 원복 시 부팅 커널 기본값도 같이 변경해야 합니다. 그렇지 않을 경우 다음 부팅 시에 문제 버전의 커널로 부팅됩니다.
(선택사항) 변경된 커널 버전으로 정상 부팅되는지 확인하기 위해서 서버를 재부팅해 주십시오.
[root@rhel810 ~]# sync;reboot
(선택사항) 서버에 다시 로그인하여 부팅 여부 및 커널 버전을 확인해 주십시오.
[root@rhel810 ~]# uname -r 4.18.0-553.16.1.el8_10.x86_64
커널 업데이트 진행 중에 Repository 관련 이슈 발생 시
커널 업데이트를 진행하면서 Repository 관련 이슈 발생 시, Linux OS Repository 설정 점검 가이드 FAQ를 참고해 주십시오.