Microsoft MVP성태의 닷넷 이야기
특정 시각에 프로그램 종료 또는 재시작시 오류 발생 [링크 복사], [링크+제목 복사],
조회: 23234
글쓴 사람
필승 (lovendon at gmail.com)
홈페이지
첨부 파일
 


안녕하세요.

특정 시각에 기존의 프로세서를 종료하고 재구동해야 하는 경우가 있어서 타이머 조건 내에서 application.restart()를 하거나 application.exit()를 한 후 윈도우 작업 스케쥴러에서 실행하는 방법으로 시도를 해보았는데요.

잘 될때는 잘 되다가도 간헐적으로 BEX 또는 CRL20r3 등의 에러 메시지를 포함한 메시지 박스를 띄우고 프로세서가 죽지 않은 상태로 있게 됩니다.

위 에러 메시지로 무엇을 의심 해볼 수 있는지 또 무엇이 문제인지 덤프 파일을 만들어서 볼 수 있는 방법이 궁금합니다.

사용환경은 윈도우7 x64이고 문제가 되고 있는 프로그램은 x86(32비트)로 빌드 되었습니다.



그리고,


try/catch로 조용히 사라진 예외를 파악하고 싶다면?
https://www.sysnet.pe.kr/Default.aspx?mode=2&sub=0&detail=1&pageno=0&wid=10965&rssMode=1&wtype=0


코드(C#)를 통한 풀 덤프 만드는 방법
https://www.sysnet.pe.kr/2/0/995


C# - 프로세스 스스로 풀 덤프 남기는 방법
https://www.sysnet.pe.kr/Default.aspx?mode=2&sub=0&detail=1&pageno=0&wid=1485&rssMode=1&wtype=0


등을 봤는데도 잘 이해가 안되는 부분이 있는데요.

private void button1_Click(object sender, EventArgs e)
{
    int pid = Process.GetCurrentProcess().Id;
    MinidumpWriter.MakeDump(@"c:\temp\test.dmp", pid);
}

이 부분에서

    int pid = Process.GetCurrentProcess().Id;
    MinidumpWriter.MakeDump(@"c:\temp\test.dmp", pid);

이 코드를 program.cs 에서

try
{
   메인 프로세스 실행
}
catch
{
    int pid = Process.GetCurrentProcess().Id;
    MinidumpWriter.MakeDump(@"c:\temp\test.dmp", pid);
}

이렇게 처리해줘도 상관없는 부분인가요?










[최초 등록일: ]
[최종 수정일: 11/1/2017]


비밀번호

댓글 작성자
 



2017-11-01 02시10분
예외가 거기까지 전파만 된다면 program.cs에서 해줘도 상관없습니다. 그런데, 프로세스가 BEX 또는 CRL20r3 등의 오류로 종료된다는 것은 왠지 강제 종료될 때의 상황일듯 싶은데 그런 경우 닷넷의 예외 핸들러까지 안 올 수도 있습니다.

일단 위의 코드를 넣어서 덤프 파일이 생성되는지 보고, 안 생긴다면 비정상 종료 시 덤프를 남기도록 procdump.exe나 Debug Diagnostic Tool 도구로 crash 덤프 설정을 하면 됩니다.
정성태
2017-11-01 06시15분
[guest] Program.cs에 해보았지만 덤프파일은 생성되지 않았습니다.
여기서는 최상위이기 때문에 모든 예외를 잡고 덤프를 남기는게 아닌가 보군요?

Procdump.exe나 debug diagnostic tool로 하는건 어렵나요?
[guest]
2017-11-01 06시29분
[guest] 본문의 두번째 링크를 보고도 감이 잘 안잡히던 차에 마지막 부분에 있는 직접 만드신 것을 다운로드 받아보려고 했더니 파일을 찾을 수 없다는 메시지가 뜹니다
[guest]
2017-11-01 06시54분
[guest] 두번째 링크의 마직막 링크에 대한 다운로드는 확인했습니다.

지금 외부에서 모바일로 보느라 댓글의 복원된 링크를 뒤늦게 확인 했습니다.
[guest]
2017-11-01 07시06분
procdump.exe는 다음과 같이 실행해 두면 프로세스가 종료할 때 덤프를 남기지만... 문제는 그냥 종료해도 남깁니다.

procdump -ma -t test.exe

따라서 특정 예외를 구분할 수 있다면 -e 옵션을 주고 -f 옵션으로 필터링하면 됩니다.

닷넷 응용 프로그램에서 특정 예외가 발생했을 때 풀 덤프받는 방법
; http://www.sysnet.pe.kr/2/0/1376

또는, 그외에 다음의 도구를 이용하면 됩니다.

프로세스 비정상 종료 시 "Debug Diagnostic Tool"를 이용해 덤프를 남기는 방법
; http://www.sysnet.pe.kr/2/0/1786
정성태
2017-11-01 07시59분
[guest] 답변 감사합니다.
한번 해보고 혹시 막히면 다시 여쭙겠습니다.
[guest]
2017-11-01 10시38분
[guest] 제가 알아본 바로는 Application.Exit() 호출시 FormClosing 이벤트 핸들러를 실행한다고 알고 있는데요.
현재 제 코드에서는 FormClosing 시에 e.Cancel = true; 이렇게 무시하고 this.Hide(); 폼을 숨기게 해놨는데요.

이 부분은 프로그램 작동시에 실수로 폼 우측 상단의 X버튼을 눌러 종료되는것을 막기 위함인데 혹시 이 부분 때문에 Exit 또는 Restart 시에 오류가 발생할 가능성은 없을지 궁금합니다.

오류가 매번 발생하는것이 아니라 간헐적으로 발생하니 잡기 너무 어렵네요.
[guest]
2017-11-02 12시31분
폼을 숨겼다고 그런 오류가 발생할 것 같지는 않은데요.
정성태

... 91  92  [93]  94  95  96  97 
NoWriterDateCnt.TitleFile(s)
135정성태4/6/200512760    답변글 [답변]: c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
136김용국4/6/200511551        답변글 [답변]: [답변]: c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
137정성태4/7/200510697            답변글 [답변]: [답변]: [답변]: c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
138김용국4/7/20059609                답변글 [답변]: [답변]: [답변]: [답변]: c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
139김용국4/11/200510235                    답변글 잘 해결 되었습니다... 감사합니다 [한줄답변]
129김용국3/31/200511237SmartClient 배포와 관련해서 무엇이 빠졌는지 좀 알려주시면 감사하겠습니다....!파일 다운로드2
130정성태3/31/200510298    답변글 [답변]: SmartClient 배포와 관련해서 무엇이 빠졌는지 좀 알려주시면 감사하겠습니다....!
131김용국4/1/20059799        답변글 [답변]: [답변]: SmartClient 배포와 관련해서 무엇이 빠졌는지 좀 알려주시면 감사하겠습니다....!
132정성태4/1/20059920            답변글 [답변]: [답변]: [답변]: SmartClient 배포와 관련해서 무엇이 빠졌는지 좀 알려주시면 감사하겠습니다....!
133김용국4/1/200510062                답변글 [답변]: [답변]: [답변]: [답변]: SmartClient 배포와 관련해서 무엇이 빠졌는지 좀 알려주시면 감사하겠습니다....!
126구정모3/31/200511383이홈의 효과는 어떻게???
128정성태3/31/200510490    답변글 [답변]: 이홈의 효과는 어떻게???
124배재현3/30/200510430Smart Client 문제로 이렇게 질문을 하나 올리게 됐습니다.^^;;
125정성태3/30/20059926    답변글 [답변]: Smart Client 문제로 이렇게 질문을 하나 올리게 됐습니다.^^;;
121안연준3/23/20059815이벤트 관련 문제
122정성태3/23/20059697    답변글 [답변]: 이벤트 관련 문제
120안연준3/23/20059579정성태님.... 오프라인 문제 질문 입니다. [1]
123정성태3/23/20059811    답변글 [답변]: 정성태님.... 오프라인 문제 질문 입니다. [1]
117정준명3/21/200510743COM+ 메소드 작성시...
118정성태3/29/200510246    답변글 [답변]: COM+ 메소드 작성시... [1]
109김용국3/18/200511208IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ...
112정성태3/19/200510369    답변글 [답변]: IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ...
113김용국3/19/200510337        답변글 [답변]: [답변]: IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ...
114정성태3/19/200510379            답변글 [답변]: [답변]: [답변]: IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ...
115김용국3/21/20059776                답변글 [답변]: [답변]: [답변]: [답변]: IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ... [1]
119김용국3/22/20059763                    답변글 [답변]: 정상태님 아주 잘 해결 되었습니다.... 감사합니다!
... 91  92  [93]  94  95  96  97