Ikhtisar Proses dan Pemecahan Masalah CentOS 7 dan RHEL 7

Artikel ini menjelaskan proses boot untuk sistem CentOS / RHEL 7.x. Meskipun mungkin tetap mirip dengan rilis sebelumnya, dengan RHEL 7, systemd sedang diperkenalkan. Selain proses boot, saya akan memberikan tips dan trik pemecahan masalah di sepanjang jalan.

Anda harus memahami proses boot sebelum Anda dapat secara aktif memecahkan masalah saat boot. Tinjau langkah-langkah di bawah ini sampai Anda terbiasa dengan prosesnya.

Ikhtisar tingkat tinggi

  • Power + post.
  • Pencarian perangkat firmware.
  • Firmware membaca bootloader.
  • Boot loader memuat konfigurasi (grub2).
  • Boot loader memuat kernel dan initramfs.
  • Boot loader melewati kendali ke kernel.
  • Kernel menginisialisasi perangkat keras + dijalankan /sbin/initsebagai pid 1.
  • Systemd mengeksekusi semua target initrd (me-mount filesystem aktif /sysroot).
  • Kernel root FS beralih dari initramfs root ( /sysroot) ke rootf sistem ( /) dan systemd dieksekusi kembali sebagai versi sistem.
  • Systemd mencari target default dan memulai / menghentikan unit yang dikonfigurasikan sementara secara otomatis menyelesaikan dependensi dan halaman login muncul.

Untuk informasi lebih lanjut tentang proses boot, lihat dokumentasi OS resmi untuk sistem Anda.

Target systemd

Target pada dasarnya adalah pemeriksaan ketergantungan. Mereka memiliki konfigurasi "sebelum" dan "setelah" untuk layanan apa yang dibutuhkan untuk memenuhi target tersebut. Misalnya: arp.ethernet.service,, firewalld.servicedan sebagainya perlu dimulai dan bekerja sebelum network.targetdapat dihubungi. Jika tidak tercapai, layanan seperti httpd, nfs, dan ldaptidak dapat dimulai. Ada 4 target yang dapat diatur di RHEL / CentOS 7.

  • graphical.target (antarmuka GUI)
  • multi-user.target (mode multi-pengguna, login berbasis teks)
  • rescue.target (sulogin prompt, inisialisasi sistem dasar)
  • emergency.target (sulogin prompt, pivot initramfs selesai dan root sistem dipasang pada / sebagai hanya baca)

Untuk melihat target boot default saat ini, gunakan yang berikut:

systemctl get-default

Ingat, Anda dapat mengubahnya saat dijalankan dengan mengisolasi target. Ini akan memulai / menghentikan semua layanan yang terkait dengan target baru, jadi gunakan hati-hati (lihat systemctl isolate new.target).

Mode pengguna tunggal

Ada kalanya Anda harus boot ke mode pengguna tunggal untuk memperbaiki masalah dengan sistem operasi. Untuk contoh ini, saya akan menunjukkan kepada Anda bagaimana menggunakan rescue.target"mode pengguna tunggal" di RHEL / CentOS 7.

  1. Interupsi menu grub2 dengan menekan "e" untuk mengedit ketika diminta dengan menu grub.
  2. Temukan baris yang menentukan versi kernel ( vmlinuz ) dan tambahkan yang berikut ke dalamnya:systemd.unit=rescue.target
  3. Tekan "Ctrl + x" untuk memulai.
  4. Anda kemudian akan diminta dengan kata sandi root untuk melanjutkan, setelah Anda keluar dari shell penyelamatan, proses booting akan terus memuat target default Anda.

Memulihkan kata sandi root

Proses ini sedikit berbeda dengan apa yang kami gunakan dalam rilis sebelumnya, tetapi ini adalah tugas yang sederhana dan hanya memerlukan sedikit langkah untuk melakukannya. Jika Anda perlu memulihkan kredensial, Anda dapat menggunakan metode ini untuk mendapatkan akses ke VM. Anda masih dapat mem-boot CD langsung, me-mount sistem file root, dan mengedit kata sandi, tetapi metode itu sudah ketinggalan zaman dan membutuhkan lebih banyak usaha.

  1. Mulai ulang sistem.
  2. Interupsi menu grub2 dengan menekan "e" untuk mengedit ketika diminta dengan menu grub.
  3. Pindahkan kursor ke akhir baris yang menentukan kernel ( vmlinuz ). Anda mungkin ingin menghapus semua konsol lain selain TTY0, namun langkah ini mungkin tidak diperlukan di lingkungan Anda.
  4. Tambahkan rd.break( tanpa tanda kutip ) yang akan memecah proses booting tepat sebelum kontrol diserahkan dari initramfs ke sistem aktual.
  5. Ctrl + x untuk mem-boot.

Pada titik ini, sebuah root shell disajikan dengan filesystem root yang dipasang dalam mode read-only aktif /sysroot. Kami harus mengirim ulang dengan hak istimewa menulis.

Remount /sysroot.

# mount -oremount,rw /sysroot

Beralih ke penjara chroot.

# chroot /sysroot

Ubah kata sandi untuk pengguna yang kredensialnya sudah usang.

# passwd <username>

Jika Anda menggunakan SElinux, Anda harus mempertimbangkan memberi label ulang semua file sebelum melanjutkan proses booting. Bagian ini dapat dilewati jika Anda tidak menggunakan SElinux.

# touch /.autorelabel

Keluar dua kali dan sistem akan boot dengan bersih dari titik kami terputus.

Meninjau log dari boot sebelumnya

Mungkin bermanfaat untuk melihat log dari upaya boot gagal sebelumnya. Jika jurnal jurnal dibuat persisten (biasanya disimpan di memori dan dirilis saat boot) ini dapat dilakukan dengan journalctlalat ini. Ikuti langkah-langkah ini jika Anda perlu mengatur logging boot persisten.

Sebagai root, buat file log untuk menyimpan informasi ini.

# mkdir -p 2775 /var/log/journal && chown :systemd-journal /var/log/journal
# systemctl restart systemd-journald

Untuk memeriksa log dari boot sebelumnya, gunakan -bopsi dengan journalctl. Tanpa argumen apa pun, -bakan memfilter output hanya ke pesan yang berkaitan dengan boot terakhir. Angka negatif untuk argumen ini akan difilter dengan boot sebelumnya. Sebagai contoh:

# journalctl -b-1 -p err

Ini akan menunjukkan kepada Anda log kesalahan dari boot yang terjadi sebelum yang terbaru. Anda harus mengubah nilai numerik untuk mencerminkan boot yang perlu Anda lihat.

Memperbaiki kesalahan disk dan sistem file

Salah satu kesalahan waktu boot yang paling umum adalah /etc/fstabfile yang salah konfigurasi . Anda TIDAK BISA menggunakan rescue.targetuntuk memperbaiki /etc/fstabkesalahan. Sebagian besar masalah ini akan mengharuskan kita untuk menggunakan emergency.targetkarena "penyelamatan" membutuhkan sistem yang lebih fungsional.

Berikut ini adalah contoh masalah yang membutuhkan emergency.target:

  1. Sistem file rusak.
  2. UUID tidak ada di /etc/fstab.
  3. Tidak ada titik pemasangan di /etc/fstab.
  4. Opsi pemasangan salah di /etc/fstab.

Penting : Setelah mengedit /etc/fstabfile dalam mode darurat, Anda harus menjalankan yang berikut ini untuk langkah-langkah keamanan:

# systemctl daemon-reload

Berikut adalah contoh langkah-langkah. Kami akan boot ke mode darurat untuk menghapus entri palsu di /etc/fstab.

  1. Interupsi menu grub2 dengan menekan "e" untuk mengedit ketika diminta dengan menu grub.
  2. Temukan baris yang menentukan versi kernel ( vmlinuz ) dan tambahkan yang berikut ke dalamnya:systemd.unit=emergency.target
  3. Tekan "Ctrl + x" untuk boot.
  4. Anda akan diminta memasukkan kata sandi root untuk melanjutkan.
  5. Remount /agar kami dapat membuat perubahan pada fstabfile:# mount -oremount,rw /
  6. Kita dapat menggunakan mountperintah untuk melihat entri mana yang menyebabkan kesalahan:# mount -a
  7. Hapus entri yang menyinggung dari fstabfile.
  8. Gunakan mount -alagi untuk memastikan kesalahan telah diselesaikan.
  9. Gunakan systemctl daemon-reloadseperti yang saya sebutkan sebelumnya untuk memuat ulang semua file unit, dan membuat ulang seluruh pohon dependensi.

Setelah Anda keluar dari shell darurat, sistem akan menyelesaikan booting dari target darurat, Anda kemudian dapat melanjutkan seperti biasa dari titik itu. Contoh ini hanya digunakan untuk menunjukkan kepada Anda proses menggunakan target darurat untuk membuat perubahan terus-menerus ke file pada sistem.

Masalah boot loader dengan Grub 2

The /boot/grub2/grub.cfgfile file konfigurasi utama. JANGAN mengedit file ini secara manual. Sebagai gantinya, gunakan grub2-mkconfiguntuk membuat konfigurasi grub2 baru menggunakan sekumpulan file konfigurasi berbeda dan daftar kernel yang diinstal. The grub2-mkconfigperintah akan melihat /etc/default/grubuntuk pilihan seperti timeout menu default dan baris perintah kernel untuk digunakan, kemudian menggunakan satu set script di /etc/grub.d/untuk menghasilkan file konfigurasi yang dihasilkan.

Berikut ini adalah diagram tekstual dari hubungan ini.

/boot/grub2/grub.cfg
               |
               |__________________
               |                  |
         /etc/default/grub         /etc/grub.d/*

Penting: Untuk mengedit file grub.cfg utama, Anda harus membuat perubahan yang diinginkan ke /etc/default/grubdan ke dalam file /etc/grub.d/lalu membuat yang baru grub.cfgdengan menjalankan:

# grub2-mkconfig > /boot/grub2/grub.cfg

Pemecahan masalah grub

Penting untuk memahami sintaksis dari /boot/grub2/grub.cfgfile sebelum pemecahan masalah.

  • Pertama, entri yang dapat di-boot dikodekan di dalam blok 'menuentry'. Dalam blok ini, linux16dan initrd16garis menunjuk ke kernel untuk dimuat dari disk (bersama dengan baris perintah kernel) dan initramfs untuk dimuat. Selama pengeditan interaktif saat boot, tab digunakan untuk menemukan baris-baris ini.
  • Baris "set root" di dalam blok-blok itu tidak menunjuk ke sistem file root untuk sistem RHEL / CentOS 7, tetapi sebaliknya menunjuk ke sistem file dari mana grub2 harus memuat file kernel dan initramfs. Sintaksnya adalah di harddrive.partitionmana hd0hard drive pertama dalam sistem dan hd1yang kedua. Partisi diindikasikan msdos1untuk partisi MBR pertama atau gpt1untuk partisi GPT pertama.

Contoh dari /boot/grub2/grub.cfg:

### BEGIN /etc/grub.d/10_linux ###
menuentry 'CentOS Linux (3.10.0-514.26.2.el7.x86_64) 7 (Core)' --class centos --class gnu-linux --class gnu --class os --unrestricted $menuentry_id_option 'gnulinux-3.10.0-514.el7.x86_64-advanced-a2531d12-46f8-4a0f-8a5c-b48d6ef71275' {
    load_video
    set gfxpayload=keep
    insmod gzio
    insmod part_msdos
    insmod ext2
    set root='hd0,msdos1'
    if [ x$feature_platform_search_hint = xy ]; then
      search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  123455ae-46f8-4a0f-8a5c-b48d6ef71275
    else
      search --no-floppy --fs-uuid --set=root 123455ae-46f8-4a0f-8a5c-b48d6ef71275
    fi

Jika Anda perlu menginstal ulang bootloader pada perangkat, gunakan perintah berikut.

# grub2-install <device>

Memperbaiki instalasi grub yang rusak

Untuk kasus-kasus ketika sistem tidak mau boot setelah mencapai menu grub2.

  • Anda harus mulai dengan mengedit menu grub dan mencari kesalahan sintaksis. Jika Anda menemukannya, perbaiki dan masuk ke sistem untuk melakukan perubahan terus-menerus untuk memperbaiki masalah.
  • Jika Anda tidak dapat menemukan kesalahan, lihat bagian di atas di mana kita boot ke target darurat. Anda harus melakukan remount root ( /) lagi.
  • Lihat konfigurasi grub2 saat ini dengan perintah berikut: # grub2-mkconfig
  • Jika Anda tidak melihat kesalahan, kemungkinan seseorang mengedit /boot/grub2/grub.cfgfile tersebut. Jangan modifikasi file ini. Bangun kembali konfigurasi dengan perintah berikut:# grub2-mkconfig > /boot/grub2/grub.cfg

Setelah Anda membangun kembali konfigurasi grub, Anda harus dapat melakukan reboot tanpa mengalami masalah.



Leave a Comment

Cara Memasang Graylog Server pada CentOS 7

Cara Memasang Graylog Server pada CentOS 7

Menggunakan Sistem yang Berbeda? Graylog server adalah perangkat lunak manajemen log sumber terbuka siap pakai perusahaan. Ia mengumpulkan log dari berbagai sumber dan menganalisis

Atur Akun Pengguna khusus SFTP di CentOS 7

Atur Akun Pengguna khusus SFTP di CentOS 7

Pada kesempatan tertentu, Administrator Sistem mungkin perlu membuat akun pengguna dan membatasi akses mereka untuk hanya mengelola file mereka sendiri melalui sFTP, tetapi tidak

Cara Memasang Chamilo 1.11.8 pada CentOS 7

Cara Memasang Chamilo 1.11.8 pada CentOS 7

Menggunakan Sistem yang Berbeda? Chamilo adalah sistem manajemen pembelajaran (LMS) gratis dan open source yang banyak digunakan untuk pendidikan online dan kolaborasi tim

Menginstal Komunitas Odoo 9 di CentOS 7

Menginstal Komunitas Odoo 9 di CentOS 7

Odoo, sebelumnya dikenal sebagai OpenERP, adalah platform bisnis ERP open source yang terkenal. Perusahaan dengan ukuran berapa pun dapat mengambil manfaat dari Odoo, berkat lisnya yang berlimpah

Cara Memasang CMS CMS 2.0 pada CentOS 7 LAMP VPS

Cara Memasang CMS CMS 2.0 pada CentOS 7 LAMP VPS

Menggunakan Sistem yang Berbeda? Couch CMS adalah Content Management System (CMS) sederhana dan fleksibel, gratis dan open source yang memungkinkan desainer web untuk mendesain

Cara Memasang NextCloud 9 pada CentOS 7

Cara Memasang NextCloud 9 pada CentOS 7

NextCloud, seperti namanya, adalah alternatif yang menjanjikan dari solusi hosting file sumber terbuka lainnya OwnCloud. Dalam artikel ini, saya akan menunjukkan kepada Anda ho

Menginstal Netdata di CentOS 7

Menginstal Netdata di CentOS 7

Menggunakan Sistem yang Berbeda? Netdata adalah bintang yang naik di bidang pemantauan metrik sistem waktu-nyata. Dibandingkan dengan alat lain dengan jenis yang sama, Netdata:

Cara Menginstal ERPNext Open Source ERP pada CentOS 7

Cara Menginstal ERPNext Open Source ERP pada CentOS 7

Menggunakan Sistem yang Berbeda? ERP atau Enterprise Resource Planning adalah rangkaian aplikasi perusahaan yang digunakan untuk mengelola proses bisnis inti. ERPNext adalah gratis

Menyiapkan SA-MP San Andreas Multiplayer Server pada CentOS 6

Menyiapkan SA-MP San Andreas Multiplayer Server pada CentOS 6

Selamat datang di tutorial Vultr lainnya. Di sini, Anda akan belajar cara menginstal dan menjalankan server SAMP. Panduan ini ditulis untuk CentOS 6. Prasyarat Anda akan tahu

Instal Elgg pada CentOS 7

Instal Elgg pada CentOS 7

Menggunakan Sistem yang Berbeda? Elgg adalah mesin jejaring sosial open source yang memungkinkan penciptaan lingkungan sosial seperti jejaring sosial kampus

Menginstal Bolt CMS pada CentOS 7

Menginstal Bolt CMS pada CentOS 7

Bolt adalah CMS open source yang ditulis dalam PHP. Kode sumber baut di-host di GitHub. Panduan ini akan menunjukkan kepada Anda cara menginstal Bolt CMS pada CentOS 7 Vult yang baru

Cara Memasang Bugzilla 5.0.x di CentOS 7

Cara Memasang Bugzilla 5.0.x di CentOS 7

Bugzilla adalah sistem pelacakan bug sumber bebas dan terbuka yang banyak digunakan oleh berbagai vendor untuk terus meningkatkan softwar mereka

Menyebarkan Kubernet Dengan Kubeadm di CentOS 7

Menyebarkan Kubernet Dengan Kubeadm di CentOS 7

Ikhtisar Artikel ini dimaksudkan untuk membantu Anda mendapatkan kluster Kubernet dan menjalankan dengan kubeadm dalam waktu singkat. Panduan ini akan menggunakan dua server, pada

Setup Sails.js untuk Pengembangan pada CentOS 7

Setup Sails.js untuk Pengembangan pada CentOS 7

Menggunakan Sistem yang Berbeda? Pendahuluan Sails.js adalah kerangka kerja MVC untuk Node.js, mirip dengan Ruby on Rails. Itu membuat untuk mengembangkan aplikasi modern ver

Menyiapkan Server Half Life 2 Pada CentOS 6

Menyiapkan Server Half Life 2 Pada CentOS 6

Tutorial ini akan membahas proses pemasangan server game Half Life 2 pada Sistem CentOS 6. Langkah 1: Menginstal prasyarat Untuk mengatur ou

Alat Pemantauan Yang Lebih Baik Untuk Ubuntu Dan CentOS

Alat Pemantauan Yang Lebih Baik Untuk Ubuntu Dan CentOS

Pendahuluan Sistem Linux dilengkapi dengan alat pemantauan secara default seperti top, df, dan du yang membantu memonitor proses dan ruang disk. Namun sering kali, mereka ar

Cara Memasang Kolab Groupware di CentOS 7

Cara Memasang Kolab Groupware di CentOS 7

Menggunakan Sistem yang Berbeda? Kolab Groupware adalah aplikasi groupware berbasis web gratis dan open source. Fitur-fiturnya terdiri dari komunikasi email, acara

Cara Memasang Koel di CentOS 7

Cara Memasang Koel di CentOS 7

Menggunakan Sistem yang Berbeda? Koel adalah aplikasi streaming audio pribadi sederhana berbasis web yang ditulis dalam Vue di sisi klien dan Laravel di sisi server. Koe

Cara Memasang GDB pada CentOS 6

Cara Memasang GDB pada CentOS 6

GDB adalah debugger untuk C, C ++, Objective-C, Pascal, Fortran, Go, D, OpenCL C, Ada, dan Modula-2. CentOS didasarkan pada RHEL (Red Hat Enterprise Linux). Salah satu th

Menginstal Akaunting di CentOS 7

Menginstal Akaunting di CentOS 7

Menggunakan Sistem yang Berbeda? Akaunting adalah perangkat lunak akuntansi sumber terbuka dan gratis yang dirancang untuk usaha kecil dan freelancer. Itu dibangun kecerdasan

Wawasan tentang 26 Teknik Analisis Data Besar: Bagian 1

Wawasan tentang 26 Teknik Analisis Data Besar: Bagian 1

Wawasan tentang 26 Teknik Analisis Data Besar: Bagian 1

6 Hal yang Sangat Menggila dari Nintendo Switch

6 Hal yang Sangat Menggila dari Nintendo Switch

Banyak dari Anda tahu Switch keluar pada Maret 2017 dan fitur-fitur barunya. Bagi yang belum tahu, kami sudah menyiapkan daftar fitur yang membuat 'Switch' menjadi 'gadget yang wajib dimiliki'.

Janji Teknologi Yang Masih Belum Ditepati

Janji Teknologi Yang Masih Belum Ditepati

Apakah Anda menunggu raksasa teknologi untuk memenuhi janji mereka? periksa apa yang belum terkirim.

Fungsionalitas Lapisan Arsitektur Referensi Big Data

Fungsionalitas Lapisan Arsitektur Referensi Big Data

Baca blog untuk mengetahui berbagai lapisan dalam Arsitektur Big Data dan fungsinya dengan cara yang paling sederhana.

Bagaimana AI Dapat Membawa Otomatisasi Proses ke Tingkat Selanjutnya?

Bagaimana AI Dapat Membawa Otomatisasi Proses ke Tingkat Selanjutnya?

Baca ini untuk mengetahui bagaimana Kecerdasan Buatan menjadi populer di antara perusahaan skala kecil dan bagaimana hal itu meningkatkan kemungkinan untuk membuat mereka tumbuh dan memberi keunggulan pada pesaing mereka.

CAPTCHA: Berapa Lama Itu Bisa Tetap Menjadi Teknik yang Layak Untuk Perbedaan Human-AI?

CAPTCHA: Berapa Lama Itu Bisa Tetap Menjadi Teknik yang Layak Untuk Perbedaan Human-AI?

CAPTCHA telah berkembang cukup sulit bagi pengguna untuk dipecahkan dalam beberapa tahun terakhir. Apakah itu akan tetap efektif dalam deteksi spam dan bot di masa mendatang?

Singularitas Teknologi: Masa Depan Peradaban Manusia yang Jauh?

Singularitas Teknologi: Masa Depan Peradaban Manusia yang Jauh?

Saat Sains Berkembang dengan kecepatan tinggi, mengambil alih banyak upaya kita, risiko menundukkan diri kita pada Singularitas yang tidak dapat dijelaskan juga meningkat. Baca, apa arti singularitas bagi kita.

Telemedicine Dan Perawatan Kesehatan Jarak Jauh: Masa Depan Ada Di Sini

Telemedicine Dan Perawatan Kesehatan Jarak Jauh: Masa Depan Ada Di Sini

Apa itu telemedicine, perawatan kesehatan jarak jauh dan dampaknya terhadap generasi mendatang? Apakah itu tempat yang bagus atau tidak dalam situasi pandemi? Baca blog untuk menemukan tampilan!

Pernahkah Anda Bertanya-tanya Bagaimana Hacker Menghasilkan Uang?

Pernahkah Anda Bertanya-tanya Bagaimana Hacker Menghasilkan Uang?

Anda mungkin pernah mendengar bahwa peretas menghasilkan banyak uang, tetapi pernahkah Anda bertanya-tanya bagaimana cara mereka mendapatkan uang sebanyak itu? mari berdiskusi.

Pembaruan Tambahan macOS Catalina 10.15.4 Menyebabkan Lebih Banyak Masalah Daripada Menyelesaikan

Pembaruan Tambahan macOS Catalina 10.15.4 Menyebabkan Lebih Banyak Masalah Daripada Menyelesaikan

Baru-baru ini Apple merilis macOS Catalina 10.15.4 pembaruan suplemen untuk memperbaiki masalah tetapi tampaknya pembaruan menyebabkan lebih banyak masalah yang mengarah ke bricking mesin mac. Baca artikel ini untuk mempelajari lebih lanjut