Hướng dẫn sử dụng Kdump để tìm nguyên nhân lỗi Kernel Panic trên Ubuntu 20.04
Bạn không sử dụng Ubuntu 20.04?
Xem bài viết cho các distro khácGiới thiệu
Khi máy chủ bị lỗi lỗi kernel panic, hệ điều hành sẽ bị crash đột ngột. Lúc này việc kiểm tra trạng thái lúc máy chủ gặp sự cố rất khó khăn bởi máy chủ đã bị crash và không thao tác được, hoặc phải reboot.
Kdump là gì?
Kdump là tính năng của kernel Linux được sử dụng để chụp lại trạng thái của hệ thống khi kernel bị crash. Để bật kdump, chúng ta cần cấp cho nó một lượng RAM vật lý cố định, nó sẽ dùng để chứa các thông tin khi kernel bị panic hoặc crash.
Khi kernel bị crash hoặc panic, nó sẽ gọi kexec(kdump kernel), các thông tin về các vùng nhớ RAM
, SWAP
đang sử dụng sẽ được copy vào file vmcore , được lưu vào ổ đĩa của máy chủ hoặc lưu qua mạng tùy vào cấu hình kdump mà chúng ta chỉ định.
Bằng cách phân tích các file dump này, chúng ta có thể tìm ra nguyên nhân dẫn đến kernel bị panic hoặc crash. Hoặc chúng ta cũng có thể gởi file dump này cho các chuyên gia để họ phân tích lỗi.
Bài viết này sẽ hướng dẫn các bạn cài đặt và cấu hình kdump trên Ubuntu 20.04
Bước 1: Cài đặt kexec-tools
Sử dụng lệnh yum để cài đặt với quyền root:
Giao diện cấu hình gói sẽ hiện lên, bạn cần chọn Yes
hai lần để hệ thống cho phép kexcec-tools
handle reboot và đọc file cấu hình grub
Nếu lỡ bỏ qua hai cấu hình trên, bạn có thể dùng hai lệnh sau để thực hiện cấu hình lại: dpkg-reconfigure kexec-tools
và dpkg-reconfigure kdump-tools
Reboot lại máy chủ
Bước 2: Kiểu tra cấu hình
Sử dụng các lệnh kdump-config show
để biết rằng kdump đang hoạt động:
Kiểm tra file cat /proc/cmdline
. Nếu có dòng cấu hình crashkernel
là bạn đã thao tác đúng.
Bước 3: Kiểm tra hoạt động của kdump
Nguy hiểm: Thao tác sau sẽ làm crash hệ thống, máy chủ của bạn sẽ bị crash để test kdump và reboot. Vì vậy bạn không nên thực hiện thao tác sau ở các máy chủ production.
Bước này sẽ thử làm crash hệ thống. Để làm hệ thống crash, thực hiện lệnh sau:
Sau khi hệ thống crash và khởi động lại, chúng ta sẽ thấy file dump tại /var/crash/
Chúc các bạn thành công.
Tính năng đang được phát triển