Po service vboxdrv setup
wpisaniu 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 -a
i 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.
centos
terminal
kernel
linux-kernel
virtualbox
CodeMed
źródło
źródło
uname -a
pokazuje3.10.0-229.el7.x86_64
lub3.10.0-229.14.1.el7.x86_64
? Domyślam się, że to pierwszy, ale yum zainstalował nagłówki drugiego.Odpowiedzi:
Rozwiązanie prawdopodobnie znajdzie się w tym pytaniu, jakim jest krótka wersja, uruchom
Spowoduje to zainstalowanie nagłówków jądra dla aktualnie uruchomionej wersji jądra.
Podejrzewam, że w pewnym momencie zrobiłeś coś
yum update
podobnego i faktycznie zainstalowałeś nowe jądro, ale jeszcze go nie uruchomiłeś. Prawdopodobnie dzieje się tak, że kiedy wykonujeszyum install
kroki podane w pytaniu, szuka najnowszej zainstalowanej wersji i pobiera nagłówki. Howerver po uruchomieniuvboxdrv
patrzy 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.
źródło
No package kernel-devel-uname-r == 4.4.193-1.el7.elrepo.x86_64 available.
yum install kernel-devel
moż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)