Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 

WSL + eBPF: modprobe: FATAL: Module kheaders not found in directory

다음과 같은 오류가 발생한다면?

$ sudo bpftrace -e 'BEGIN { printf("hello\n"); }'
modprobe: FATAL: Module kheaders not found in directory /lib/modules/5.15.153.1-microsoft-standard-WSL2
Attaching 1 probe...
hello

실제로 WSL의 경우 /lib/modules 디렉터리는 텅 비어 있습니다. 검색해 보니까, 해결책이 나오는데요, ^^

Enable CONFIG_IKHEADERS=m in WSL kernel #5526
; https://github.com/microsoft/WSL/issues/5526

cd /path/to/WSL2-Linux-Kernel #check out branch corresponding to uname -r tag
make KCONFIG_CONFIG=Microsoft/config-wsl
sudo ln /path/to/WSL2-Linux-Kernel -s /lib/modules/4.19.104-microsoft-standard/build


정리해 보면, (또 다른 방법이 있는지는 알 수 없으나) 현재로서는 커널 소스를 빌드하는 수밖에는 없습니다. 따라서 지난 글에 설명한 대로 (가능하다면) 현재 설치된 버전의 WSL 커널 소스를 다운로드해 빌드하시면 됩니다. 설치를 완료했으면, 이제 다음과 같은 경로가 있어야 합니다.

// 5.15.153.1 WSL 커널 소스를 빌드하면 /lib/modules/ 디렉터리 하위에 2개의 디렉터리가 생성됩니다.
// * 5.15.153.1-microsoft-standard-WSL2
// * 5.15.153.1-microsoft-standard-WSL2+
//
// 테스트를 해보면, 저 상태에서 커널을 교체하지 않아도 (디렉터리가 이미 있으므로,
// bpftrace 명령어가 잘 동작합니다.

$ ll /lib/modules/5.15.153.1-microsoft-standard-WSL2+/build
lrwxrwxrwx 1 root root 34 Oct 22 20:50 /lib/modules/5.15.153.1-microsoft-standard-WSL2+/build -> /home/testusr/temp/WSL2-Linux-Kernel/

// 이외에도 source 경로도 링크돼 있습니다.
$ ll /lib/modules/5.15.153.1-microsoft-standard-WSL2+/source
lrwxrwxrwx 1 root root 34 Oct 22 20:50 /lib/modules/5.15.153.1-microsoft-standard-WSL2+/source -> /home/testusr/temp/WSL2-Linux-Kernel/

보시면, WSL 소스코드를 다운로드해 빌드한 경로가 (아마도 "make modules_install headers_install" 명령에서) 자동으로 /lib/modules/.../build로 링크돼 있습니다.

이후 다시 bpftrace 예제를 실행하면 아무런 오류 메시지 없이 동작할 것입니다.

$ sudo bpftrace -e 'BEGIN { printf("hello\n"); }'
Attaching 1 probe...
hello
^C




참고로 "kheaders not found"와 관련해 검색해 보면,

Issue with bcc tools execution #3686
; https://github.com/iovisor/bcc/issues/3686

오류 메시지에 CONFIG_IKHEADERS 옵션을 적용하지 않고 커널 빌드를 했기 때문이라고 나옵니다.

Unable to find kernel headers. Try rebuilding kernel with CONFIG_IKHEADERS=m (module) or installing the kernel development package for your running kernel version.
chdir(/lib/modules/5.4.0-84-generic/build): No such file or directory

실제로 WSL의 경우 해당 옵션이 비활성화돼 있습니다.

// WSL + Ubuntu 20.04 LTS

$ zcat /proc/config.gz | grep CONFIG_IKHEADERS
# CONFIG_IKHEADERS is not set

$ dpkg --get-selections | grep linux-headers-$(uname -r)
$

반면, (WSL이 아닌) 별도로 설치한 Ubuntu 22.04의 경우에는 이렇게 headers가 설치돼 있습니다.

// Ubuntu 22.04 LTS (VM)

$ cat /boot/config-$(uname -r) | grep CONFIG_IKHEADERS
CONFIG_IKHEADERS=m

$ dpkg --get-selections | grep linux-headers-$(uname -r)
linux-headers-6.8.0-47-generic                  install

만약 WSL 이미지도 저렇게 CONFIG_IKHEADERS를 활성화하고 싶다면 커널 소스를 빌드하기 전에 ".config" 파일을 수정해 CONFIG_IKHEADERS 값을 "m"으로 변경하면 됩니다.

// WSL 커널 소스코드를 다운로드한 경로

$ cat .config | grep CONFIG_IKHEADERS
CONFIG_IKHEADERS=m

또는 텍스트 편집기로 직접 수정하는 것이 귀찮다면, "make menuconfig" 명령을 내려도 되지만,

$ make menuconfig

// 이후 뜨는 설정 창에서 "General setup" -> "Enable kernel headers through /sys/kernel/kheaders.tar.xz (NEW)" 옵션을 켜서 .config 파일에 반영

어차피 소스코드와 함께 빌드를 했다면 kheaders에 준하는 모든 파일들이 마련돼 있으므로 굳이 저 옵션을 적용해 빌드할 필요까지는 없습니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 10/23/2024]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 16  17  18  19  20  21  22  23  24  25  26  27  28  [29]  30  ...
NoWriterDateCnt.TitleFile(s)
13247정성태2/7/202314162VS.NET IDE: 180. Visual Studio - 닷넷 소스 코드 디버깅 중 "Decompile source code"가 동작하는 않는 문제
13246정성태2/6/202314014개발 환경 구성: 664. Hyper-V에 설치한 리눅스 VM의 VHD 크기 늘리는 방법 - 두 번째 이야기
13245정성태2/6/202313729.NET Framework: 2093. C# - PKCS#8 PEM 파일을 이용한 RSA 개인키/공개키 설정 방법파일 다운로드1
13244정성태2/5/202313812VS.NET IDE: 179. Visual Studio - External Tools에 Shell 내장 명령어 등록
13243정성태2/5/202314439디버깅 기술: 190. windbg - Win32 API 호출 시점에 BP 거는 방법 [1]
13242정성태2/4/202313240디버깅 기술: 189. ASP.NET Web Application (.NET Framework) 프로젝트의 숨겨진 예외 - System.UnauthorizedAccessException
13241정성태2/3/202311471디버깅 기술: 188. ASP.NET Web Application (.NET Framework) 프로젝트의 숨겨진 예외 - System.IO.FileNotFoundException
13240정성태2/1/202312921디버깅 기술: 187. ASP.NET Web Application (.NET Framework) 프로젝트의 숨겨진 예외 - System.Web.HttpException
13239정성태2/1/202311400디버깅 기술: 186. C# - CacheDependency의 숨겨진 예외 - System.Web.HttpException
13238정성태1/31/202316576.NET Framework: 2092. IIS 웹 사이트를 TLS 1.2 또는 TLS 1.3 프로토콜로만 운영하는 방법
13237정성태1/30/202315234.NET Framework: 2091. C# - 웹 사이트가 어떤 버전의 TLS/SSL을 지원하는지 확인하는 방법
13236정성태1/29/202314621개발 환경 구성: 663. openssl을 이용해 인트라넷 IIS 사이트의 SSL 인증서 생성
13235정성태1/29/202314149개발 환경 구성: 662. openssl - 윈도우 환경의 명령행에서 SAN 적용하는 방법
13234정성태1/28/202316842개발 환경 구성: 661. dnSpy를 이용해 소스 코드가 없는 .NET 어셈블리의 코드를 변경하는 방법 [1]
13233정성태1/28/202317130오류 유형: 840. C# - WebClient로 https 호출 시 "The request was aborted: Could not create SSL/TLS secure channel" 예외 발생
13232정성태1/27/202313137스크립트: 43. uwsgi의 --processes와 --threads 옵션
13231정성태1/27/202311974오류 유형: 839. python - TypeError: '...' object is not callable
13230정성태1/26/202313147개발 환경 구성: 660. WSL 2 내부로부터 호스트 측의 네트워크로 UDP 데이터가 1개의 패킷으로만 제한되는 문제
13229정성태1/25/202315481.NET Framework: 2090. C# - UDP Datagram의 최대 크기
13228정성태1/24/202316127.NET Framework: 2089. C# - WMI 논리 디스크가 속한 물리 디스크의 정보를 얻는 방법 [2]파일 다운로드1
13227정성태1/23/202314909개발 환경 구성: 659. Windows - IP MTU 값을 바꿀 수 있을까요? [1]
13226정성태1/23/202313237.NET Framework: 2088. .NET 5부터 지원하는 GetRawSocketOption 사용 시 주의할 점
13225정성태1/21/202313144개발 환경 구성: 658. Windows에서 실행 중인 소켓 서버를 다른 PC 또는 WSL에서 접속할 수 없는 경우
13224정성태1/21/202313209Windows: 221. Windows - Private/Public/Domain이 아닌 네트워크 어댑터 단위로 방화벽을 on/off하는 방법
13223정성태1/20/202312814오류 유형: 838. RDP 연결 오류 - The two computers couldn't connect in the amount of time allotted
13222정성태1/20/202312824개발 환경 구성: 657. WSL - DockerDesktop.vhdx 파일 위치를 옮기는 방법
... 16  17  18  19  20  21  22  23  24  25  26  27  28  [29]  30  ...