Nie można znaleźć nagłówków jądra dla jądra 3.10.0-229.el7.x86_64

12

Po service vboxdrv setupwpisaniu polecenia w terminalu CentOS 7 pojawia się następujący błąd:

Your kernel headers for kernel 3.10.0-229.el7.x86_64 cannot be found  

Jak mogę rozwiązać ten błąd?

Gdy otwieram plik dziennika, wpisując vi /var/log/vbox-install.log, zawartość jest:

Uninstalling modules from DKMS
  removing old DKMS module vboxhost version  5.0.4

------------------------------
Deleting module version: 5.0.4
completely from the DKMS tree.
------------------------------
Done.
Attempting to install using DKMS

Creating symlink /var/lib/dkms/vboxhost/5.0.4/source ->
                 /usr/src/vboxhost-5.0.4

DKMS: add completed.
Failed to install using DKMS, attempting to install without
Makefile:185: *** Error: unable to find the sources of your current Linux kernel. Specify KERN_DIR=<directory> and run Make again.  Stop.

Wystąpił błąd podczas instalowania VirtualBox 5.0.4 zgodnie z instrukcjami z tego samouczka . Podsumowując, do tej pory mam:

vi /etc/yum.repos.d/virtualbox.repo

Dodaj następujący tekst, a następnie zapisz i wyjdź:

[virtualbox]
name=Oracle Linux / RHEL / CentOS-$releasever / $basearch - VirtualBox
baseurl=http://download.virtualbox.org/virtualbox/rpm/el/$releasever/$basearch
enabled=1
gpgcheck=1
gpgkey=http://download.virtualbox.org/virtualbox/debian/oracle_vbox.asc

Następnie w wierszu polecenia wpisz:

# rpm -Uvh http://ftp.jaist.ac.jp/pub/Linux/Fedora/epel/7/x86_64/e/epel-release-7-5.noarch.rpm
# yum install gcc make patch  dkms qt libgomp 
# yum install kernel-headers kernel-devel fontforge binutils glibc-headers glibc-devel
...
Complete!  
# cd /usr/src/kernels
# ls -al
total 12
drwxr-xr-x.  3 root root 4096 Sep 25 16:14 .
drwxr-xr-x.  4 root root 4096 Sep 25 14:17 ..
drwxr-xr-x. 22 root root 4096 Sep 25 16:14 3.10.0-229.14.1.el7.x86_64
# export KERN_DIR=/usr/src/kernels/3.10.0-229.14.1.el7.x86_64
# yum install VirtualBox-5.0
...
Complete!  
# service vboxdrv setup
Stopping VirtualBox kernel modules                         [  OK  ]
Uninstalling old VirtualBox DKMS kernel modules            [  OK  ]
Removing old VirtualBox pci kernel module                  [  OK  ]
Removing old VirtualBox netadp kernel module               [  OK  ]
Removing old VirtualBox netflt kernel module               [  OK  ]
Removing old VirtualBox kernel module                      [  OK  ]
Trying to register the VirtualBox kernel modules using DKMSError! echo
Your kernel headers for kernel 3.10.0-229.el7.x86_64 cannot be found at
/lib/modules/3.10.0-229.el7.x86_64/build or /lib/modules/3.10.0-229.el7.x86_64/source.
                                                       [FAILED]
(Failed, trying without DKMS)
Recompiling VirtualBox kernel modules                      [FAILED]
(Look at /var/log/vbox-install.log to find out what went wrong)

Patrz wyżej zawartość vi /var/log/vbox-install.log

Z ciekawości zajrzałem /lib/modules/i znalazłem:

[root@localhost kernels]# cd /lib/modules
[root@localhost modules]# ls -al
total 16
drwxr-xr-x.  4 root root 4096 Sep 25 15:58 .
dr-xr-xr-x. 30 root root 4096 Sep 25 16:23 ..
drwxr-xr-x.  7 root root 4096 Sep 25 15:59 3.10.0-229.14.1.el7.x86_64
drwxr-xr-x.  8 root root 4096 Sep 25 16:24 3.10.0-229.el7.x86_64

Zgodnie z radą @ EricRenouf napisałem uname -ai terminal odpowiedział:

Linux localhost.localdomain 3.10.0-229.el7.x86_64 #1 SMP Fri Mar 6 11:36:42 UTC 2015 x86_64 x86_64 x86_64 GNU/Linux

Nie zrestartowałem komputera, ale w samouczku nie było mowy o ponownym uruchomieniu.

CodeMed
źródło
Czy zaktualizowałeś jądro bez restartowania się w którymś momencie lub coś takiego? Czy uname -apokazuje 3.10.0-229.el7.x86_64lub 3.10.0-229.14.1.el7.x86_64? Domyślam się, że to pierwszy, ale yum zainstalował nagłówki drugiego.
Eric Renouf,

Odpowiedzi:

12

Rozwiązanie prawdopodobnie znajdzie się w tym pytaniu, jakim jest krótka wersja, uruchom

sudo yum install "kernel-devel-uname-r == $(uname -r)"

Spowoduje to zainstalowanie nagłówków jądra dla aktualnie uruchomionej wersji jądra.

Podejrzewam, że w pewnym momencie zrobiłeś coś yum updatepodobnego i faktycznie zainstalowałeś nowe jądro, ale jeszcze go nie uruchomiłeś. Prawdopodobnie dzieje się tak, że kiedy wykonujesz yum installkroki podane w pytaniu, szuka najnowszej zainstalowanej wersji i pobiera nagłówki. Howerver po uruchomieniu vboxdrvpatrzy na działające jądro i próbuje znaleźć nagłówki.

Twoje uruchomione i zainstalowane jądra nie są zsynchronizowane (co zwykle nie jest dużym problemem), ale znalazłeś przypadek, w którym ma to znaczenie.

Eric Renouf
źródło
Nie działa dla mnie. No package kernel-devel-uname-r == 4.4.193-1.el7.elrepo.x86_64 available.
Sadik Özoguz,
@ SadikÖzoguz, jeśli używasz wersji jądra, chcesz zainstalować nagłówki, bo możesz po prostu spróbować, yum install kernel-develmoże to by działało łatwiej? Jeśli nie, możesz spróbować zadać nowe pytanie (być może powołując się na to i udzielając więcej informacji na temat twojej sytuacji)
Eric Renouf
Zadam nowe pytanie.
Sadik Özoguz