멈춰진 프로세스 디버깅하기

김경태의 이미지

<부연설명>

보통 프로세스 디버깅을 하려면,

ps -ef | grep exe_code

하고서는 해당 프로세스 번호가 300번이라면,

truss -i -p 300 이라고 하게 될 것입니다.

하지만 실행되는 프로세스가 멈춰진 경우에는 위의 방법으로도 화면에 아무런
반응을 보이지 않아 프로세스의 동작 방식을 알수 없는 경우가 많습니다.

그래서 두번째 방법으로 디버깅을 하게 될때는,
실행파일이 있는 디렉토리로 가서,

gdb exe_code 300

와 같이 입력하면, 결과는

(gdb) where
#0 0xff11e464 in _read () from /lib/libc.so.1
#1 0xff16a6bc in read () from /lib/libthread.so.1
#2 0x2bd278 in ntprd ()
#3 0x2ab96c in nsprecv ()
#4 0x2b0480 in nsrdr ()
#5 0x28f290 in nsdo ()
#6 0x26e50c in nioqrc ()
#7 0x36bce8 in ttcdrv ()
#8 0x2740cc in nioqwa ()
#9 0x1f392c in upirtrc ()
#10 0x244a54 in kpurcsc ()
#11 0x21e4f0 in kpuexecv8 ()
#12 0x2206c0 in kpuexec ()
#13 0x2eb634 in OCIStmtExecute ()
#14 0x340068 in sqlcucExecute ()
#15 0x32dd68 in sqlall ()
#16 0x330850 in sqlatm ()
#17 0x1e0f50 in sqlnst ()
#18 0x1d264c in sqlcmex ()
#19 0x1d2a4c in sqlcxt ()
#20 0xe22ec in __1cMState_serverHGetMain6MnHSTAT_IN_rnFPRISMIsequence4nMSTAT_OUT_SEQdD____h_ ()
#21 0x1bac8c in __1cMStatRpt_skelGcallee6MpcpnF_args__3_ ()
#22 0x1397a0 in __1cFPRISMKserver_orbKdo_request6MipnK_secontext_I_I_ ()
#23 0x139c60 in __1cFPRISMKserver_orbKimpl_ready6Mpn0AIRegister__v_ ()
#24 0x12d464 in main ()
(gdb) list
1 ../../gcc/libgcc2.c: No such file or directory.

와 같습니다.

하지만 이 경우에도 가령 멈춰진 프로세스가 어떤 함수에서 멈춰졌는지는 알수
있지만 구체적으로 어떤 라인에서 멈춰졌는지 그때의 변수가 무엇인지와 같은
구체적인 정보는 알아낼 수가 없는 것 같습니다.

(참고: 위 프로그램은 .pc 형태의 소스를 proc를 이용하여 컴파일 한 것입니
다.)

<질문>

멈춰진 프로세스에서

1. 어떤 라인에서 멈춰졌는가?
2.멈춰졌을때의 변수값은?

을 알고 싶습니다.

어떻게 하면 될까요?

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.