커널 부팅에서 dmesg AKA 커널 로그를 단일 .txt 파일로 덤프하는 방법은 무엇입니까?

커널 부팅에서 dmesg AKA 커널 로그를 단일 .txt 파일로 덤프하는 방법은 무엇입니까?

저는 SATA 호스트-장치 통신을 이해하려고 노력하고 있으며 이를 위해 커널 드라이버 코드에 많은 디버그 메시지를 넣었습니다. 이제 메시지의 양이 너무 많아서 dmesg 로그에서 장치 열거의 초기 메시지를 볼 수 없습니다. 마찬가지로 CONFIG_LOG_BUF_SHIFT(=21) 구성 변수를 수정하여 dmesg가 메시지를 가져오는 링 버퍼 크기를 늘렸지만 여전히 동일한 문제에 직면하고 있습니다.

그렇다면 커널 부팅의 모든 dmesg를 특정 파일에 기록할 수 있는 방법이 있습니까?

미리 도움을 주셔서 감사합니다.

답변1

당신이 사용할 수있는:

cat /var/log/dmesg > file.txt

그리고 다음을 사용하세요:

head /var/log/dmesg

dmesg의 첫 번째 줄을 보려면.

자세한 사양은 '남자 머리'를 참조하세요. '>' 기호는 'cat'의 출력을 'file.txt'로 리디렉션합니다.

답변2

dmesg로그를 stdout으로 인쇄하는 명령이 있습니다 . stdout을 텍스트 파일로 리디렉션할 수 있습니다.

dmesg > /path/to/dmesg.txt

이것을 연장할 수 있습니다. 정말 유용한 옵션은 ~/.profile로그인 시 dmesg의 출력을 추가하는 행을 파일(홈 디렉토리에 있음)에 추가하는 것입니다. 다음과 같은 줄을 추가하기만 하면 됩니다.

dmesg >> /path/to/dmesg.txt

처음 몇 줄(0.000000개의 메시지)만 원할 경우 파이프로 연결할 수 있습니다 head.

표준 출력을 사용하면:

dmesg | head

또는 head이미 저장된 .txt 파일을 사용합니다.

head /path/to/dmesg.txt

이상입니다. 도움이 되었기를 바랍니다.

편집하다:그런데, 여기에는 0.000000개의 메시지가 포함되어 있습니다.

관련 정보