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

(시리즈 글이 2개 있습니다.)
Linux: 29. 리눅스 환경에서 C/C++ 프로그램이 Segmentation fault 에러가 발생한 경우
; https://www.sysnet.pe.kr/2/0/12208

오류 유형: 614. 리눅스 환경에서 C/C++ 프로그램이 Segmentation fault 에러가 발생한 경우 (2)
; https://www.sysnet.pe.kr/2/0/12209




리눅스 환경에서 C/C++ 프로그램이 Segmentation fault 에러가 발생한 경우

리눅스 환경에 낯설다 보니 ^^ 회사 동료가 빠르게 오류 원인을 파악하는 방법을 알려줬습니다. 우선, (아마도 container 환경이라면 거의 없을 텐데) gdb를 설치하고,

apt-get update && apt-get install -y --no-install-recommends gdb

gdb를 대상 실행 모듈을 로드하도록 실행한 후, (이 글에서는 dotnet 프로그램으로 가정)

$ gdb dotnet
GNU gdb (Debian 7.12-6) 7.12.0.20161007-git
Copyright (C) 2016 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
and "show warranty" for details.
This GDB was configured as "x86_64-linux-gnu".
Type "show configuration" for configuration details.
For bug reporting instructions, please see:
<http://www.gnu.org/software/gdb/bugs/>.
Find the GDB manual and other documentation resources online at:
<http://www.gnu.org/software/gdb/documentation/>.
For help, type "help".
Type "apropos word" to search for commands related to "word"...
Reading symbols from dotnet...(no debugging symbols found)...done.

명령행 인자가 있다면 함께 명시하면서 "r"로 실행을 시키면,

(gdb) r "razor21_sample.dll"
Starting program: /usr/bin/dotnet "razor21_sample.dll"
warning: Error disabling address space randomization: Operation not permitted
[Thread debugging using libthread_db enabled]
Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
[New Thread 0x7fe676029700 (LWP 745)]
...[생략]...
[New Thread 0x7fe667fff700 (LWP 790)]

Thread 1 "dotnet" received signal SIGSEGV, Segmentation fault.
0x00007f0a363b5c0c in construct<unsigned char, unsigned char const&> ()
    at /usr/bin/../lib/gcc/x86_64-linux-gnu/8/../../../../include/c++/8/ext/new_allocator.h:136
136     /usr/bin/../lib/gcc/x86_64-linux-gnu/8/../../../../include/c++/8/ext/new_allocator.h: No such file or directory.

Segmentation fault 오류가 발생한 시점에 서게 되고, 이때 bt 명령을 통해 호출 스택을 살필 수 있습니다.

(gdb) bt
#0  0x00007fe6740bfc0c in construct<unsigned char, unsigned char const&> ()
    at /usr/bin/../lib/gcc/x86_64-linux-gnu/8/../../../../include/c++/8/ext/new_allocator.h:136
#1  construct<unsigned char, unsigned char const&> ()
    at /usr/bin/../lib/gcc/x86_64-linux-gnu/8/../../../../include/c++/8/bits/alloc_traits.h:475
#2  push_back ()
    at /usr/bin/../lib/gcc/x86_64-linux-gnu/8/../../../../include/c++/8/bits/stl_vector.h:1079
#3  TestSegFaultMethod ()
    at /home/testusr/projects/libTest/shared/TestInfo.cpp:2315
#4  0x00007fe6740bf6d8 in TestResolve ()
    at /home/testusr/projects/libTest/shared/TestInfo.cpp:2155
#5  0x00007fe6740e3d4d in TestCall ()
    at /home/testusr/projects/libTest/shared/TestApp.cpp:1391
#6  0x00007fe6740e3439 in TestMethod ()
    at /home/testusr/projects/libTest/shared/TestApp.cpp:1273
#7  0x00007fe6740e2e49 in TestJIT ()
    at /home/testusr/projects/libTest/shared/TestApp.cpp:1178
#8  0x00007fe677132f3c in EEToProfInterfaceImpl::TestJIT(unsigned long, int) ()
   from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libcoreclr.so
#9  0x00007fe67726d222 in MethodDesc::JitCompileCodeLockedEventWrapper(PrepareCodeConfig*, ListLockEntryBase<NativeCodeVersion>*) ()
   from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libcoreclr.so
#10 0x00007fe67726cbb0 in MethodDesc::JitCompileCode(PrepareCodeConfig*) ()
   from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libcoreclr.so
#11 0x00007fe67726c937 in MethodDesc::PrepareILBasedCode(PrepareCodeConfig*) ()
   from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libcoreclr.so
#12 0x00007fe67726ef15 in MethodDesc::DoPrestub(MethodTable*) ()
   from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libcoreclr.so
#13 0x00007fe67726e844 in PreStubWorker ()
   from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libcoreclr.so
#14 0x00007fe6771f0bc4 in ThePreStub ()
   from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libcoreclr.so
#15 0x00007fe6771efedf in CallDescrWorkerInternal ()
   from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libcoreclr.so
#16 0x00007fe67711060c in MethodDescCallSite::CallTargetWorker(unsigned long const*, unsigned long*, int) ()
   from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libcoreclr.so
#17 0x00007fe677211076 in RunMain(MethodDesc*, short, int*, PtrArray**) ()
   from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libcoreclr.so
#18 0x00007fe677211315 in Assembly::ExecuteMainMethod(PtrArray**, int) ()
   from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libcoreclr.so
#19 0x00007fe677059ec2 in CorHost2::ExecuteAssembly(unsigned int, char16_t const*, int, char16_t const**, unsigned int*) ()
   from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libcoreclr.so
#20 0x00007fe677034fe4 in coreclr_execute_assembly ()
   from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libcoreclr.so
---Type <return> to continue, or q <return> to quit---

#21 0x00007fe67780c84d in ?? () from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libhostpolicy.so
#22 0x00007fe6777ff2cd in ?? () from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libhostpolicy.so
#23 0x00007fe6777ffb1c in corehost_main () from /usr/share/dotnet/shared/Microsoft.NETCore.App/2.1.17/libhostpolicy.so
#24 0x00007fe677ab29cf in ?? () from /usr/share/dotnet/host/fxr/2.1.17/libhostfxr.so
#25 0x00007fe677abdf8c in ?? () from /usr/share/dotnet/host/fxr/2.1.17/libhostfxr.so
#26 0x00007fe677abf0e5 in ?? () from /usr/share/dotnet/host/fxr/2.1.17/libhostfxr.so
#27 0x00007fe677abe659 in ?? () from /usr/share/dotnet/host/fxr/2.1.17/libhostfxr.so
#28 0x00007fe677ab2c1c in hostfxr_main_startupinfo () from /usr/share/dotnet/host/fxr/2.1.17/libhostfxr.so
#29 0x000000000040ac74 in ?? ()
#30 0x000000000040af05 in ?? ()
#31 0x00007fe677d232e1 in __libc_start_main () from /lib/x86_64-linux-gnu/libc.so.6
#32 0x0000000000408a54 in _start ()
(gdb) 

이 정도만 확인할 수 있어도, 어떻게 원인을 탐색 및 해결해야 할지 큰 도움이 됩니다. ^^




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







[최초 등록일: ]
[최종 수정일: 4/12/2020]

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

비밀번호

댓글 작성자
 




... 46  47  [48]  49  50  51  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12774정성태8/11/202118688.NET Framework: 1087. C# - Collection 개체의 다중 스레드 접근 시 "Operations that change non-concurrent collections must have exclusive access" 예외 발생
12773정성태8/11/202118160개발 환경 구성: 595. PyCharm - WSL과 연동해 Django App을 윈도우에서 리눅스 대상으로 개발
12772정성태8/11/202118518스크립트: 21. 파이썬 - 윈도우 환경에서 개발한 Django 앱을 WSL 환경의 uwsgi를 이용해 실행 [1]
12771정성태8/11/202117169Windows: 196. "Microsoft Windows Subsystem for Linux Background Host" / "Vmmem"을 종료하는 방법
12770정성태8/11/202117297.NET Framework: 1086. C# - Windows Forms 응용 프로그램의 자식 컨트롤 부하파일 다운로드1
12769정성태8/11/202114286오류 유형: 752. Python - ImportError: No module named pip._internal.cli.main 두 번째 이야기
12768정성태8/10/202115681.NET Framework: 1085. .NET 6에 포함된 신규 BCL API [1]파일 다운로드1
12767정성태8/10/202116595오류 유형: 752. Python - ImportError: No module named pip._internal.cli.main
12766정성태8/9/202114664Java: 32. closing inbound before receiving peer's close_notify
12765정성태8/9/202115679Java: 31. Cannot load JDBC driver class 'org.mysql.jdbc.Driver'
12764정성태8/9/202153874Java: 30. XML document from ServletContext resource [/WEB-INF/applicationContext.xml] is invalid
12763정성태8/9/202117801Java: 29. java.lang.NullPointerException - com.mysql.jdbc.ConnectionImpl.getServerCharset
12762정성태8/8/202120771Java: 28. IntelliJ - Unable to open debugger port 오류
12761정성태8/8/202117258Java: 27. IntelliJ - java: package javax.inject does not exist [2]
12760정성태8/8/202113657개발 환경 구성: 594. 전용 "Command Prompt for ..." 단축 아이콘 만들기
12759정성태8/8/202119068Java: 26. IntelliJ + Spring Framework + 새로운 Controller 추가 [2]파일 다운로드1
12758정성태8/7/202118538오류 유형: 751. Error assembling WAR: webxml attribute is required (or pre-existing WEB-INF/web.xml if executing in update mode)
12757정성태8/7/202119178Java: 25. IntelliJ + Spring Framework 프로젝트 생성
12756정성태8/6/202116706.NET Framework: 1084. C# - .NET Core Web API 단위 테스트 방법 [1]파일 다운로드1
12755정성태8/5/202117374개발 환경 구성: 593. MSTest - 단위 테스트에 static/instance 유형의 private 멤버 접근 방법파일 다운로드1
12754정성태8/5/202117931오류 유형: 750. manage.py - Your project may not work properly until you apply the migrations for app(s): admin, auth, contenttypes, sessions.
12753정성태8/5/202119036오류 유형: 749. PyCharm - Error: Django is not importable in this environment
12752정성태8/4/202115687개발 환경 구성: 592. JetBrains의 IDE(예를 들어, PyCharm)에서 Visual Studio 키보드 매핑 적용
12751정성태8/4/202118183개발 환경 구성: 591. Windows 10 WSL2 환경에서 docker-compose 빌드하는 방법
12750정성태8/3/202115496디버깅 기술: 181. windbg - 콜 스택의 "Call Site" 오프셋 값이 가리키는 위치
12749정성태8/2/202114945개발 환경 구성: 590. Visual Studio 2017부터 단위 테스트에 DataRow 특성 지원
... 46  47  [48]  49  50  51  52  53  54  55  56  57  58  59  60  ...