CentOS 7 i RHEL 7 Pregled procesa pokretanja i rješavanje problema

Ovaj članak opisuje proces pokretanja sustava CentOS/RHEL 7.x. Iako može ostati sličan prethodnim izdanjima, s RHEL 7, systemd se uvodi. Uz proces pokretanja, usput ću vam pružiti savjete i trikove za rješavanje problema.

Morate razumjeti proces pokretanja prije nego što možete aktivno rješavati problem pri pokretanju. Pregledajte donje korake dok se ne upoznate s postupkom.

Pregled na visokoj razini

  • Snaga + post.
  • Pretraživanje uređaja za firmver.
  • Firmware čita bootloader.
  • Boot loader učitava konfiguraciju (grub2).
  • Boot loader učitava kernel i initramfs.
  • Boot loader prenosi kontrolu na kernel.
  • Kernel inicijalizira hardver + izvršava se /sbin/initkao pid 1.
  • Systemd izvršava sve initrd ciljeve (montira datotečni sustav na /sysroot).
  • Korijenski FS kernela prebacio se s initramfs root ( /sysroot) na rootfs sustava ( /) i systemd se ponovno izvršava kao verzija sustava.
  • Systemd traži zadani cilj i pokreće/zaustavlja jedinice kako su konfigurirane dok se automatski rješavaju ovisnosti i pojavljuje se stranica za prijavu.

Za više informacija o procesu pokretanja, pogledajte službenu dokumentaciju OS-a za vaš sustav.

Systemd ciljevi

Ciljevi su u osnovi provjere ovisnosti. Imaju konfiguraciju "prije" i "poslije" za točno koje usluge su potrebne za postizanje tog cilja. Na primjer: arp.ethernet.service, firewalld.service, i tako dalje moraju se pokrenuti i raditi prije nego što network.targetse do njih dođe. Ako se ne dosegne, usluge kao što su httpd, nfs, i ldapne mogu se pokrenuti. Postoje 4 cilja koja se mogu postaviti u RHEL/CentOS 7.

  • graphical.target (GUI sučelje)
  • multi-user.target (višekorisnički način rada, tekstualna prijava)
  • rescue.target (sulogin prompt, osnovna inicijalizacija sustava)
  • emergency.target (sulogin prompt, initramfs stožer je dovršen i korijen sustava montiran na / samo za čitanje)

Da biste vidjeli trenutni zadani cilj pokretanja, koristite sljedeće:

systemctl get-default

Imajte na umu da to možete promijeniti tijekom izvođenja izolacijom cilja. Ovo će pokrenuti/zaustaviti sve usluge povezane s novim ciljem, stoga budite oprezni (pogledajte systemctl isolate new.target).

Jednokorisnički način rada

Postoje slučajevi kada ćete se morati pokrenuti u jednokorisničkom načinu kako biste riješili problem s operativnim sustavom. Za ovaj primjer, pokazat ću vam kako koristiti rescue.target"single user mode" na RHEL/CentOS 7.

  1. Prekinite izbornik grub2 pritiskom na "e" za uređivanje kada se od vas zatraži izbornik grub.
  2. Pronađite redak koji navodi verziju kernela ( vmlinuz ) i dodajte mu sljedeće:systemd.unit=rescue.target
  3. Pritisnite "Ctrl+x" za početak.
  4. Zatim ćete biti upitani s korijenskom lozinkom za nastavak, nakon što izađete iz ljuske za spašavanje, proces pokretanja nastavit će učitavati vaš zadani cilj.

Oporavak root lozinke

Ovaj je proces malo drugačiji od onoga koji smo koristili u prošlim izdanjima, ali je jednostavan zadatak i zahtijeva vrlo malo koraka da to učinite. Ako trebate oporaviti vjerodajnice, možete koristiti ovu metodu za dobivanje pristupa VM-u. Još uvijek se možete pokrenuti s live CD-a, montirati korijenski datotečni sustav i urediti lozinku, ali ta metoda je zastarjela i zahtijeva više truda.

  1. Ponovno pokrenite sustav.
  2. Prekinite izbornik grub2 pritiskom na "e" za uređivanje kada se od vas zatraži izbornik grub.
  3. Pomaknite pokazivač na kraj retka koji specificira kernel ( vmlinuz ). Možda ćete htjeti ukloniti sve druge konzole osim TTY0, no ovaj korak možda neće biti potreban u vašem okruženju.
  4. Dodati rd.break( bez navodnika ) koji će prekinuti proces pokretanja neposredno prije nego što se kontrola preda s initramfs-a na stvarni sustav.
  5. Ctrl+x za pokretanje.

U ovom trenutku prikazuje se korijenska ljuska s korijenskim datotečnim sustavom montiranim u načinu samo za čitanje na /sysroot. Morat ćemo ga ponovno montirati s privilegijama pisanja.

Ponovno montirajte /sysroot.

# mount -oremount,rw /sysroot

Prijeđite u chroot zatvor.

# chroot /sysroot

Promijenite lozinku za korisnika za kojeg imamo zastarjele vjerodajnice.

# passwd <username>

Ako koristite SElinux, trebali biste razmisliti o ponovnom označavanju svih datoteka prije nastavka procesa pokretanja. Ovaj dio se može preskočiti ako ne koristite SElinux.

# touch /.autorelabel

Izađite dvaput i sustav će se čisto pokrenuti od točke na kojoj smo ga prekinuli.

Pregledavanje zapisnika iz prethodnih pokretanja

Može biti korisno pregledati zapisnike prethodnih neuspjelih pokušaja pokretanja. Ako su zapisnici dnevnika trajni (obično pohranjeni u memoriji i pušteni pri pokretanju), to se može učiniti pomoću journalctlalata. Slijedite ove korake ako trebate postaviti trajno bilježenje pokretanja.

Kao root, stvorite datoteku dnevnika za pohranjivanje ovih informacija.

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

Za pregled zapisnika prethodnog pokretanja koristite -bopciju s journalctl. Bez ikakvih argumenata, -bfiltrirat će izlaz samo na poruke koje se odnose na posljednje pokretanje. Negativan broj za ovaj argument filtrirat će se na prethodnim podizanjima. Na primjer:

# journalctl -b-1 -p err

Ovo će vam pokazati zapise pogrešaka iz pokretanja sustava koji su se dogodili prije najnovijeg. Trebali biste promijeniti brojčanu vrijednost kako bi odražavala pokretanje koje trebate pogledati.

Popravak grešaka diska i datotečnog sustava

Jedna od najčešćih pogrešaka prilikom pokretanja je pogrešno konfigurirana /etc/fstabdatoteka. Vi NE MOŽETE koristiti rescue.targetza popraviti /etc/fstabpogreške. Većina ovih problema zahtijevat će od nas korištenje emergency.targetjer "spašavanje" zahtijeva funkcionalniji sustav.

Slijede primjeri problema koji zahtijevaju emergency.target:

  1. Oštećen datotečni sustav.
  2. Nepostojeći UUID u /etc/fstab.
  3. Nepostojeća točka montiranja u /etc/fstab.
  4. Netočna opcija montiranja u /etc/fstab.

Važno : Nakon uređivanja /etc/fstabdatoteke u hitnom načinu, morate pokrenuti sljedeće radi sigurnosnih mjera:

# systemctl daemon-reload

Evo primjera uputa. Pokrenut ćemo se u hitni način kako bismo uklonili lažni unos u /etc/fstab.

  1. Prekinite izbornik grub2 pritiskom na "e" za uređivanje kada se od vas zatraži izbornik grub.
  2. Pronađite redak koji navodi verziju kernela ( vmlinuz ) i dodajte mu sljedeće:systemd.unit=emergency.target
  3. Pritisnite "Ctrl+x" za pokretanje.
  4. Od vas će se tražiti root lozinka za nastavak.
  5. Ponovno montirajte /kako bismo mogli unijeti promjene u fstabdatoteku:# mount -oremount,rw /
  6. Možemo koristiti mountnaredbu da vidimo koji unos uzrokuje pogrešku:# mount -a
  7. Uklonite uvredljivi unos iz fstabdatoteke.
  8. Upotrijebite mount -aponovno kako biste bili sigurni da je pogreška riješena.
  9. Koristite systemctl daemon-reloadkao što sam ranije spomenuo za ponovno učitavanje svih datoteka jedinica i ponovno stvaranje cijelog stabla ovisnosti.

Nakon što izađete iz ljuske za hitne slučajeve, sustav će završiti podizanje sustava iz hitne mete, a zatim ćete moći nastaviti kao i obično od te točke. Ovaj primjer je upravo korišten da vam pokaže proces korištenja cilja za hitne slučajeve za trajne izmjene datoteka u sustavu.

Problemi s boot loaderom s Grub 2

/boot/grub2/grub.cfgDatoteka je glavni konfiguracijsku datoteku. NIKADA NEMOJTE uređivati ​​ovu datoteku ručno. Umjesto toga, koristite grub2-mkconfigza generiranje nove konfiguracije grub2 koristeći skup različitih konfiguracijskih datoteka i popis instaliranih kernela. grub2-mkconfigNaredba će izgledati na /etc/default/grubopcije poput timeout zadani izbornika i kernel komandne linije za korištenje, a zatim koristiti skup skripti u /etc/grub.d/generirati nastalu konfiguracijsku datoteku.

Ovdje je tekstualni dijagram ovog odnosa.

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

Važno: Da biste uredili glavnu datoteku grub.cfg, morat ćete unijeti željene promjene /etc/default/grubu datoteke /etc/grub.d/i datoteke, a zatim izraditi novu grub.cfgtako što ćete pokrenuti:

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

Rješavanje problema grub

Važno je razumjeti sintaksu /boot/grub2/grub.cfgdatoteke prije rješavanja problema.

  • Prvo, unosi za pokretanje kodirani su unutar blokova 'menuentry'. U tim blokovima linux16i initrd16retke upućuju na kernel koji će se učitati s diska (zajedno s naredbenim redom kernela) i initramfs koji će se učitati. Tijekom interaktivnog uređivanja pri pokretanju, kartica se koristi za pronalaženje ovih redaka.
  • Redovi "set root" unutar tih blokova ne upućuju na korijenski datotečni sustav za RHEL/CentOS 7 sustav, već umjesto toga upućuju na datotečni sustav iz kojeg grub2 treba učitati kernel i initramfs datoteke. Sintaksa je harddrive.partitiongdje hd0je prvi tvrdi disk u sustavu, a gdje hd1je drugi. Particije su označene kao msdos1za prvu MBR particiju ili gpt1za prvu GPT particiju.

Primjer iz /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

Ako trebate ponovno instalirati bootloader na uređaj, upotrijebite sljedeću naredbu.

# grub2-install <device>

Popravljanje pokvarene instalacije grube

Za slučajeve kada se sustav neće pokrenuti nakon što dođe do izbornika grub2.

  • Trebali biste započeti s uređivanjem grub izbornika i traženjem sintaksičkih pogrešaka. Ako ga pronađete, ispravite ga i uđite u sustav kako biste trajnim promjenama riješili problem.
  • Ako ne možete pronaći nijednu pogrešku, pogledajte gornji odjeljak u kojem pokrećemo cilj za hitne slučajeve. Morat ćete ponovno montirati root ( /).
  • Pogledajte trenutnu konfiguraciju grub2 sljedećom naredbom: # grub2-mkconfig
  • Ako ne vidite pogreške, vjerojatno je netko uređivao /boot/grub2/grub.cfgdatoteku. Nemojte mijenjati ovu datoteku. Ponovo izgradite konfiguraciju sljedećom naredbom:# grub2-mkconfig > /boot/grub2/grub.cfg

Nakon što ste ponovno izgradili konfiguraciju grub, trebali biste se moći ponovno pokrenuti bez ikakvih problema.


Instalirajte Plesk na CentOS 7

Instalirajte Plesk na CentOS 7

Korištenje drugog sustava? Plesk je vlasnička upravljačka ploča web hosta koja omogućuje korisnicima da administriraju svoje osobne i/ili klijentske web stranice, baze podataka

Kako instalirati Squid proxy na CentOS

Kako instalirati Squid proxy na CentOS

Squid je popularan besplatni program za Linux koji vam omogućuje stvaranje web proxyja za prosljeđivanje. U ovom vodiču vidjet ćete kako instalirati Squid na CentOS da vas preokrene

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Uvod Lighttpd je fork Apachea koji ima za cilj da bude puno manje intenzivan prema resursima. Lagan je, otuda mu i naziv, i prilično je jednostavan za korištenje. Instaliraj

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

VULTR je nedavno napravio promjene na svojoj strani i sada bi sve trebalo raditi dobro iz kutije s omogućenim NetworkManagerom. Želite li onemogućiti

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Icinga2 je moćan sustav nadzora, a kada se koristi u modelu master-client, može zamijeniti potrebu za provjerama praćenja na temelju NRPE. Glavni klijent

Kako instalirati Apache Cassandra 3.11.x na CentOS 7

Kako instalirati Apache Cassandra 3.11.x na CentOS 7

Korištenje drugog sustava? Apache Cassandra je besplatni i otvorenog koda NoSQL sustav upravljanja bazom podataka koji je osmišljen kako bi osigurao skalabilnost, visoku

Kako instalirati Microweber na CentOS 7

Kako instalirati Microweber na CentOS 7

Korištenje drugog sustava? Microweber je CMS i internetska trgovina otvorenog koda povuci i ispusti. Izvorni kod Microwebera nalazi se na GitHubu. Ovaj vodič će vam pokazati

Kako instalirati Mattermost 4.1 na CentOS 7

Kako instalirati Mattermost 4.1 na CentOS 7

Korištenje drugog sustava? Mattermost je open source alternativa Slack SAAS servisu za razmjenu poruka. Drugim riječima, s Mattermostom možete ca

Stvaranje mreže Minecraft poslužitelja s BungeeCord na Debian 8, Debian 9 ili CentOS 7

Stvaranje mreže Minecraft poslužitelja s BungeeCord na Debian 8, Debian 9 ili CentOS 7

Što vam treba Vultr VPS s najmanje 1 GB RAM-a. SSH pristup (s root/administrativnim privilegijama). Korak 1: Instalacija BungeeCord-a Najprije

Omogućava šifriranje na Plesku

Omogućava šifriranje na Plesku

Upravljačka ploča Plesk ima vrlo lijepu integraciju za Lets Encrypt. Lets Encrypt je jedan od jedinih SSL pružatelja usluga koji u potpunosti izdaju certifikate

Omogućuje šifriranje na cPanelu

Omogućuje šifriranje na cPanelu

Lets Encrypt je tijelo za izdavanje certifikata posvećeno besplatnom pružanju SSL certifikata. cPanel je izgradio urednu integraciju tako da vi i vaš klijent

Kako instalirati Concrete5 na CentOS 7

Kako instalirati Concrete5 na CentOS 7

Korištenje drugog sustava? Concrete5 je CMS otvorenog koda koji nudi mnoge osebujne i korisne značajke koje pomažu urednicima u jednostavnoj proizvodnji sadržaja i

Kako instalirati ploču za pregled na CentOS 7

Kako instalirati ploču za pregled na CentOS 7

Korištenje drugog sustava? Review Board je besplatan alat otvorenog koda za pregled izvornog koda, dokumentacije, slika i još mnogo toga. To je web-bazirani softver

Postavite HTTP autentifikaciju pomoću Nginxa na CentOS 7

Postavite HTTP autentifikaciju pomoću Nginxa na CentOS 7

U ovom vodiču naučit ćete kako postaviti HTTP autentifikaciju za Nginx web poslužitelj koji radi na CentOS 7. Zahtjevi Da biste započeli, trebat će vam

Kako instalirati YOURLS na CentOS 7

Kako instalirati YOURLS na CentOS 7

YOURLS (Your Own URL Shortener) je aplikacija za skraćivanje URL-ova otvorenog koda i analizu podataka. U ovom članku ćemo pokriti proces instalacije

Kako instalirati i konfigurirati ArangoDB na CentOS 7

Kako instalirati i konfigurirati ArangoDB na CentOS 7

Korištenje drugog sustava? Uvod ArangoDB je NoSQL baza podataka otvorenog koda s fleksibilnim modelom podataka za dokumente, grafikone i ključ-vrijednosti. to je

Korištenje Etckeepera za kontrolu verzija /etc

Korištenje Etckeepera za kontrolu verzija /etc

Uvod Direktorij /etc/ igra ključnu ulogu u načinu na koji Linux sustav funkcionira. Razlog tome je što je gotovo svaka konfiguracija sustava

Zašto biste trebali koristiti SSHFS? Kako montirati udaljeni datotečni sustav sa SSHFS na CentOS 6

Zašto biste trebali koristiti SSHFS? Kako montirati udaljeni datotečni sustav sa SSHFS na CentOS 6

Mnogi administratori sustava upravljaju velikim količinama poslužitelja. Kada se datotekama treba pristupiti na različitim poslužiteljima, prijava na svaki pojedinačno ca

Postavljanje poslužitelja Half Life 2 na CentOS 6

Postavljanje poslužitelja Half Life 2 na CentOS 6

Ovaj vodič će pokriti proces instaliranja poslužitelja za igre Half Life 2 na sustavu CentOS 6. Korak 1: Instaliranje preduvjeta Kako biste postavili ou

Kako instalirati Laravel GitScrum na CentOS 7

Kako instalirati Laravel GitScrum na CentOS 7

Laravel GitScrum ili GitScrum je alat za produktivnost otvorenog koda dizajniran da pomogne razvojnim timovima da implementiraju Scrum metodologiju na sličan način.

Uspon strojeva: primjene AI u stvarnom svijetu

Uspon strojeva: primjene AI u stvarnom svijetu

Umjetna inteligencija nije u budućnosti, ovdje je upravo u sadašnjosti. U ovom blogu Pročitajte kako su aplikacije umjetne inteligencije utjecale na različite sektore.

DDOS napadi: kratak pregled

DDOS napadi: kratak pregled

Jeste li i vi žrtva DDOS napada i zbunjeni ste metodama prevencije? Pročitajte ovaj članak kako biste riješili svoje upite.

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Možda ste čuli da hakeri zarađuju mnogo novca, ali jeste li se ikada zapitali kako zarađuju toliki novac? raspravimo.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Želite li vidjeti revolucionarne izume Googlea i kako su ti izumi promijenili život svakog čovjeka danas? Zatim čitajte na blogu kako biste vidjeli Googleove izume.

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Koncept samovozećih automobila koji će krenuti na ceste uz pomoć umjetne inteligencije san je koji već neko vrijeme imamo. No, unatoč nekoliko obećanja, nigdje ih nema. Pročitajte ovaj blog kako biste saznali više…

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Kako se znanost razvija velikom brzinom, preuzimajući mnoge naše napore, raste i rizik da se podvrgnemo neobjašnjivoj Singularnosti. Pročitajte što bi za nas mogla značiti singularnost.

Evolucija pohrane podataka – Infografika

Evolucija pohrane podataka – Infografika

Metode pohrane podataka su se razvijale možda od rođenja podataka. Ovaj blog pokriva evoluciju pohrane podataka na temelju infografike.

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Pročitajte blog kako biste na najjednostavniji način upoznali različite slojeve u arhitekturi velikih podataka i njihove funkcionalnosti.

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

U ovom digitalnom svijetu, pametni kućni uređaji postali su ključni dio života. Evo nekoliko nevjerojatnih prednosti pametnih kućnih uređaja o tome kako naš život čine vrijednim življenja i jednostavnijim.

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Nedavno je Apple izdao macOS Catalina 10.15.4 dodatak ažuriranju kako bi riješio probleme, ali čini se da ažuriranje uzrokuje više problema koji dovode do zalijevanja mac strojeva. Pročitajte ovaj članak da biste saznali više