Visió general i resolució de problemes del procés darrencada de CentOS 7 i RHEL 7

Aquest article descriu el procés d'arrencada dels sistemes CentOS/RHEL 7.x. Tot i que pot seguir sent similar a les versions anteriors, amb RHEL 7, s'està introduint systemd. A més del procés d'arrencada, oferiré consells i trucs de resolució de problemes al llarg del camí.

Heu d'entendre el procés d'arrencada abans de poder solucionar activament un problema a l'arrencada. Reviseu els passos següents fins que us familiaritzeu amb el procés.

Visió general d'alt nivell

  • Potència + publicació.
  • Cerca de dispositius de firmware.
  • El firmware llegeix el carregador d'arrencada.
  • El carregador d'arrencada carrega la configuració (grub2).
  • El carregador d'arrencada carrega el nucli i initramfs.
  • El carregador d'arrencada passa el control al nucli.
  • El nucli inicialitza el maquinari + s'executa /sbin/initcom a pid 1.
  • Systemd executa tots els objectius initrd (munta el sistema de fitxers a /sysroot).
  • L'arrel del nucli FS ha canviat de l'arrel initramfs ( /sysroot) a l' arrel del sistema ( /) i systemd es torna a executar com a versió del sistema.
  • Systemd cerca l'objectiu predeterminat i inicia/atura les unitats tal com s'han configurat mentre resol automàticament les dependències i apareix la pàgina d'inici de sessió.

Per obtenir més informació sobre el procés d'arrencada, consulteu la documentació oficial del sistema operatiu del vostre sistema.

Objectius de sistema

Els objectius són bàsicament comprovacions de dependència. Tenen una configuració "abans" i "després" per a quins serveis es necessiten exactament per assolir aquest objectiu. Per exemple: arp.ethernet.service, firewalld.service, etcètera s'han de començar i treballar abans que network.targetes pugui arribar. Si no s'hi arriba, no es poden iniciar serveis com ara httpd, nfs, i ldap. Hi ha 4 objectius que es poden establir a RHEL/CentOS 7.

  • graphical.target (interfície GUI)
  • multi-usuari.target (mode multiusuari, inici de sessió basat en text)
  • rescue.target (indicador de sulogin, inicialització bàsica del sistema)
  • emergency.target (indicador de sulogin, pivot initramfs complet i arrel del sistema muntat a / com a només lectura)

Per veure l'objectiu d'arrencada predeterminat actual, utilitzeu el següent:

systemctl get-default

Tingueu en compte que podeu canviar-ho en temps d'execució aïllant l'objectiu. Això iniciarà/aturarà tots els serveis associats amb el nou objectiu, així que tingueu precaució (vegeu systemctl isolate new.target).

Mode d'usuari únic

Hi ha moments en què haureu d'arrencar en mode d'usuari únic per solucionar un problema amb el sistema operatiu. Per a aquest exemple, us mostraré com utilitzar el rescue.target"mode d'usuari únic" a RHEL/CentOS 7.

  1. Interrompeu el menú grub2 prement "e" per editar quan se us demani amb el menú grub.
  2. Cerqueu la línia que especifica la versió del nucli ( vmlinuz ) i afegiu-hi el següent:systemd.unit=rescue.target
  3. Premeu "Ctrl+x" per començar.
  4. A continuació, se us demanarà la contrasenya d'arrel per continuar, un cop sortiu del shell de rescat, el procés d'arrencada continuarà carregant el vostre objectiu predeterminat.

Recuperació de la contrasenya root

Aquest procés és una mica diferent del que hem utilitzat en versions anteriors, però és una tasca senzilla i requereix molt pocs passos per fer-ho. Si necessiteu recuperar alguna credencial, podeu utilitzar aquest mètode per accedir a una màquina virtual. Encara podeu arrencar des d'un CD en directe, muntar el sistema de fitxers arrel i editar la contrasenya, però aquest mètode està antic i requereix més esforç.

  1. Reinicieu el sistema.
  2. Interrompeu el menú grub2 prement "e" per editar quan se us demani amb el menú grub.
  3. Mou el cursor al final de la línia que especifica el nucli ( vmlinuz ). És possible que vulgueu eliminar totes les altres consoles que no siguin TTY0, però és possible que aquest pas no sigui necessari al vostre entorn.
  4. Afegiu rd.break( sense cometes ) que trencarà el procés d'arrencada just abans de passar el control des d'initramfs al sistema real.
  5. Ctrl+x per arrencar.

En aquest punt, es presenta un shell arrel amb el sistema de fitxers arrel muntat en mode de només lectura a /sysroot. Haurem de tornar-lo a muntar amb privilegis d'escriptura.

Torneu a muntar /sysroot.

# mount -oremount,rw /sysroot

Canvia a una presó chroot.

# chroot /sysroot

Canviar la contrasenya de l'usuari en què tenim les credencials no actualitzades.

# passwd <username>

Si utilitzeu SElinux, hauríeu de considerar tornar a etiquetar tots els fitxers abans de continuar el procés d'arrencada. Aquesta part es pot saltar si no feu servir SElinux.

# touch /.autorelabel

Sortiu dues vegades i el sistema arrencarà netament des del punt que l'hem interromput.

Revisant els registres d'arrencades anteriors

Pot ser útil veure els registres dels intents d'arrencada fallits anteriors. Si els registres del diari s'han fet persistents (normalment s'emmagatzemen a la memòria i s'alliberen a l'arrencada), això es pot fer amb l' journalctleina. Seguiu aquests passos si necessiteu configurar el registre d'arrencada persistent.

Com a root, creeu el fitxer de registre per emmagatzemar aquesta informació.

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

Per inspeccionar els registres d'un arrencada anterior, utilitzeu l' -bopció amb journalctl. Sense cap argument, -bfiltrarà la sortida només als missatges relacionats amb l'últim arrencada. Un nombre negatiu a aquest argument es filtrarà a les arrencades anteriors. Per exemple:

# journalctl -b-1 -p err

Això us mostrarà els registres d'error de l'arrencada que es van produir abans del més recent. Hauríeu de canviar el valor numèric per reflectir l'arrencada que necessiteu veure.

Reparació d'errors del disc i del sistema de fitxers

Un dels errors d'arrencada més freqüents és un /etc/fstabfitxer mal configurat . Vostè NO pot utilitzar el rescue.targetde fixar un /etc/fstaberror. La majoria d'aquests problemes requeriran que utilitzem el emergency.targetja que el "rescat" requereix un sistema més funcional.

Els següents són exemples de problemes que requereixen emergency.target:

  1. Sistema de fitxers corrupte.
  2. UUID inexistent a /etc/fstab.
  3. Punt de muntatge inexistent a /etc/fstab.
  4. Opció de muntatge incorrecta a /etc/fstab.

Important : després d'editar el /etc/fstabfitxer en mode d'emergència, heu d'executar el següent per a les mesures de seguretat:

# systemctl daemon-reload

Aquí teniu un exemple de guia. Anem a arrencar en mode d'emergència per eliminar una entrada falsa a /etc/fstab.

  1. Interrompeu el menú grub2 prement "e" per editar quan se us demani amb el menú grub.
  2. Cerqueu la línia que especifica la versió del nucli ( vmlinuz ) i afegiu-hi el següent:systemd.unit=emergency.target
  3. Premeu "Ctrl+x" per arrencar.
  4. Se us demanarà la contrasenya d'arrel per continuar.
  5. Torneu a muntar /perquè puguem fer canvis al fstabfitxer:# mount -oremount,rw /
  6. Podem utilitzar l' mountordre per veure quina entrada està causant l'error:# mount -a
  7. Elimina l'entrada ofensiva del fstabfitxer.
  8. mount -aTorna-ho a utilitzar per assegurar-te que l'error s'ha resolt.
  9. Utilitzeu-lo systemctl daemon-reloadcom he esmentat anteriorment per tornar a carregar tots els fitxers de la unitat i recrear tot l'arbre de dependències.

Un cop sortiu de l'intèrpret d'emergència, el sistema acabarà d'arrencar des de l'objectiu d'emergència, llavors podreu continuar com de costum des d'aquest punt. Aquest exemple només s'ha utilitzat per mostrar-vos el procés d'utilitzar l'objectiu d'emergència per fer canvis persistents als fitxers del sistema.

Problemes del carregador d'arrencada amb Grub 2

El /boot/grub2/grub.cfgfitxer és el fitxer de configuració principal. NO editeu mai aquest fitxer manualment. En comptes d'això, utilitzeu grub2-mkconfigper generar la nova configuració de grub2 utilitzant un conjunt de fitxers de configuració diferents i la llista dels nuclis instal·lats. L' grub2-mkconfigordre buscarà /etc/default/grubopcions com ara el temps d'espera del menú predeterminat i la línia d'ordres del nucli que cal utilitzar, i després utilitzarà un conjunt d'scripts /etc/grub.d/per generar el fitxer de configuració resultant.

Aquí teniu un diagrama textual d'aquesta relació.

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

Important: per editar el fitxer grub.cfg principal, haureu de fer els canvis desitjats /etc/default/grubals fitxers /etc/grub.d/i, a continuació, crear-ne un de nou grub.cfgexecutant:

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

Resolució de problemes de grub

És important entendre la sintaxi del /boot/grub2/grub.cfgfitxer abans de resoldre problemes.

  • En primer lloc, les entrades d'arrencada es codifiquen dins dels blocs "menuentry". En aquests blocs, linux16i les initrd16línies apunten al nucli que s'ha de carregar des del disc (juntament amb la línia d'ordres del nucli) i els initramfs a carregar. Durant l'edició interactiva a l'arrencada, la pestanya s'utilitza per trobar aquestes línies.
  • Les línies "establir arrel" dins d'aquests blocs no apunten al sistema de fitxers arrel del sistema RHEL/CentOS 7, sinó que apunten al sistema de fitxers des del qual grub2 hauria de carregar el nucli i els fitxers initramfs. La sintaxi és harddrive.partitionon hd0es troba el primer disc dur del sistema i hd1és el segon. Les particions s'indiquen com msdos1per a la primera partició MBR o gpt1per a la primera partició GPT.

Exemple de /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

Si necessiteu tornar a instal·lar el carregador d'arrencada en un dispositiu, utilitzeu l'ordre següent.

# grub2-install <device>

Arreglar una instal·lació de grub trencada

Per als casos en què el sistema no arrencarà després d'arribar al menú grub2.

  • Hauríeu de començar editant el menú grub i cercant errors de sintaxi. Si en trobeu un, corregiu-lo i entreu al sistema per fer canvis persistents per solucionar el problema.
  • Si no trobeu cap error, consulteu la secció anterior on arrenquem a l'objectiu d'emergència. Haureu de tornar a muntar root ( /).
  • Visualitzeu la configuració actual de grub2 amb l'ordre següent: # grub2-mkconfig
  • Si no veieu cap error, és probable que algú hagi editat el /boot/grub2/grub.cfgfitxer. No modifiqueu aquest fitxer. Reconstrueix la configuració amb l'ordre següent:# grub2-mkconfig > /boot/grub2/grub.cfg

Un cop hàgiu reconstruït la configuració de grub, hauríeu de poder reiniciar sense tenir cap problema.


Instal·leu Plesk a CentOS 7

Instal·leu Plesk a CentOS 7

Utilitzeu un sistema diferent? Plesk és un tauler de control d'amfitrió web propietari que permet als usuaris administrar els seus llocs web personals i/o de clients, bases de dades

Com instal·lar Squid Proxy a CentOS

Com instal·lar Squid Proxy a CentOS

Squid és un popular programa Linux gratuït que us permet crear un servidor intermediari web de reenviament. En aquesta guia, veureu com instal·lar Squid a CentOS per convertir-vos-hi

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Introducció Lighttpd és una bifurcació d'Apache destinada a ser molt menys intensiu en recursos. És lleuger, d'aquí el seu nom, i és bastant senzill d'utilitzar. Instal·lant

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Recentment, VULTR ha fet canvis al seu extrem, i ara tot hauria de funcionar bé des de la caixa amb NetworkManager habilitat. Si voleu desactivar

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Icinga2 és un sistema de supervisió potent i, quan s'utilitza en un model de client mestre, pot substituir la necessitat de controls de monitoratge basats en NRPE. El mestre-client

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Utilitzeu un sistema diferent? Apache Cassandra és un sistema de gestió de bases de dades NoSQL gratuït i de codi obert dissenyat per proporcionar escalabilitat, alta

Com instal·lar Microweber a CentOS 7

Com instal·lar Microweber a CentOS 7

Utilitzeu un sistema diferent? Microweber és un CMS d'arrossegar i deixar anar de codi obert i una botiga en línia. El codi font de Microweber està allotjat a GitHub. Aquesta guia us mostrarà

Com instal·lar Vanilla Forum a CentOS 7

Com instal·lar Vanilla Forum a CentOS 7

Utilitzeu un sistema diferent? Vanilla Forum és una aplicació de fòrum de codi obert escrita en PHP. És totalment personalitzable, fàcil d'utilitzar i admet externa

Com instal·lar Mattermost 4.1 a CentOS 7

Com instal·lar Mattermost 4.1 a CentOS 7

Utilitzeu un sistema diferent? Mattermost és una alternativa autoallotjada de codi obert al servei de missatgeria Slack SAAS. En altres paraules, amb Mattermost, ca

Creació duna xarxa de servidors de Minecraft amb BungeeCord a Debian 8, Debian 9 o CentOS 7

Creació duna xarxa de servidors de Minecraft amb BungeeCord a Debian 8, Debian 9 o CentOS 7

Què necessitareu Un Vultr VPS amb almenys 1 GB de RAM. Accés SSH (amb privilegis d'arrel/administrador). Pas 1: instal·lació de BungeeCord Primer de tot

Permet xifrar a Plesk

Permet xifrar a Plesk

El tauler de control de Plesk inclou una integració molt agradable per Lets Encrypt. Lets Encrypt és un dels únics proveïdors SSL que ofereix certificats complets

Permet xifrar a cPanel

Permet xifrar a cPanel

Lets Encrypt és una autoritat de certificació dedicada a proporcionar certificats SSL de manera gratuïta. cPanel ha creat una integració perfecta perquè tu i el teu client

Com instal·lar Concrete5 a CentOS 7

Com instal·lar Concrete5 a CentOS 7

Utilitzeu un sistema diferent? Concrete5 és un CMS de codi obert que ofereix moltes característiques distintives i útils per ajudar els editors a produir continguts fàcilment i

Com instal·lar el tauler de revisió a CentOS 7

Com instal·lar el tauler de revisió a CentOS 7

Utilitzeu un sistema diferent? Review Board és una eina gratuïta i de codi obert per revisar el codi font, la documentació, les imatges i molts més. És un programari basat en web

Configura lautenticació HTTP amb Nginx a CentOS 7

Configura lautenticació HTTP amb Nginx a CentOS 7

En aquesta guia, aprendràs a configurar l'autenticació HTTP per a un servidor web Nginx que s'executa a CentOS 7. Requisits Per començar, necessitareu el

Com instal·lar GoAccess a CentOS 7

Com instal·lar GoAccess a CentOS 7

Utilitzeu un sistema diferent? GoAccess és un analitzador de registres web de codi obert. Podeu utilitzar-lo per analitzar els registres en temps real al terminal o

Com instal·lar YOURLS a CentOS 7

Com instal·lar YOURLS a CentOS 7

YOURLS (Your Own URL Shortener) és una aplicació d'anàlisi de dades i escurçament d'URL de codi obert. En aquest article, tractarem el procés d'instal·lació

Com instal·lar i configurar ArangoDB a CentOS 7

Com instal·lar i configurar ArangoDB a CentOS 7

Utilitzeu un sistema diferent? Introducció ArangoDB és una base de dades NoSQL de codi obert amb un model de dades flexible per a documents, gràfics i claus-valors. És

Utilitzant Etckeeper per al control de versions de /etc

Utilitzant Etckeeper per al control de versions de /etc

Introducció El directori /etc/ té un paper crític en el funcionament d'un sistema Linux. La raó d'això és perquè gairebé totes les configuracions del sistema

Per què hauríeu dutilitzar SSHFS? Com muntar un sistema de fitxers remot amb SSHFS a CentOS 6

Per què hauríeu dutilitzar SSHFS? Com muntar un sistema de fitxers remot amb SSHFS a CentOS 6

Molts administradors de sistemes gestionen grans quantitats de servidors. Quan s'hagi d'accedir als fitxers a través de diferents servidors, inicieu sessió a cadascun individualment ca

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

La Intel·ligència Artificial no està en el futur, és aquí mateix en el present. En aquest bloc Llegiu com les aplicacions d'Intel·ligència Artificial han afectat diversos sectors.

Atacs DDOS: una breu visió general

Atacs DDOS: una breu visió general

També ets víctima d'atacs DDOS i estàs confós sobre els mètodes de prevenció? Llegiu aquest article per resoldre les vostres consultes.

Us heu preguntat mai com guanyen diners els pirates informàtics?

Us heu preguntat mai com guanyen diners els pirates informàtics?

Potser haureu sentit que els pirates informàtics guanyen molts diners, però us heu preguntat mai com guanyen aquest tipus de diners? anem a discutir.

Invents revolucionaris de Google que us facilitaran la vida.

Invents revolucionaris de Google que us facilitaran la vida.

Vols veure els invents revolucionaris de Google i com aquests invents van canviar la vida de tots els éssers humans actuals? A continuació, llegiu al bloc per veure els invents de Google.

Divendres essencial: què va passar amb els cotxes impulsats per IA?

Divendres essencial: què va passar amb els cotxes impulsats per IA?

El concepte de cotxes autònoms per sortir a les carreteres amb l'ajuda de la intel·ligència artificial és un somni que tenim des de fa temps. Però malgrat les diverses promeses, no es veuen enlloc. Llegeix aquest blog per saber-ne més...

Singularitat tecnològica: un futur llunyà de la civilització humana?

Singularitat tecnològica: un futur llunyà de la civilització humana?

A mesura que la ciència evoluciona a un ritme ràpid, fent-se càrrec de molts dels nostres esforços, també augmenten els riscos de sotmetre'ns a una singularitat inexplicable. Llegeix, què pot significar per a nosaltres la singularitat.

Evolució de lemmagatzematge de dades – Infografia

Evolució de lemmagatzematge de dades – Infografia

Els mètodes d'emmagatzematge de les dades que han anat evolucionant poden ser des del naixement de les dades. Aquest bloc tracta l'evolució de l'emmagatzematge de dades a partir d'una infografia.

Funcionalitats de les capes darquitectura de referència de Big Data

Funcionalitats de les capes darquitectura de referència de Big Data

Llegeix el blog per conèixer de la manera més senzilla les diferents capes de l'Arquitectura Big Data i les seves funcionalitats.

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

En aquest món digital, els dispositius domèstics intel·ligents s'han convertit en una part crucial de les vides. A continuació, es mostren alguns avantatges sorprenents dels dispositius domèstics intel·ligents sobre com fan que la nostra vida valgui la pena i sigui més senzilla.

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Recentment, Apple va llançar macOS Catalina 10.15.4, una actualització de suplements per solucionar problemes, però sembla que l'actualització està causant més problemes que provoquen el bloqueig de les màquines Mac. Llegiu aquest article per obtenir més informació