Microsoft MVP성태의 닷넷 이야기
글쓴 사람
kmi
홈페이지
첨부 파일
 

예를 들어 시리얼 포트를 통해 데이터를 주고 받는 프로그램이 있습니다. 이 프로그램에는 매우많은 전역변수 (거의 30~40개 가량) 가 있고 GC 는 따로 코드로 수행하지 않으며 타이머 또한 매우 많습니다. 그리고 타이머는 모두 윈폼 타이머 이며 false 였다가 작동하는 것이 몇 개 있고, 전역변수의 30% 는 string, 5% 는 다른 클래스에서 참조한 변수 (예 : Class class = new Class()), 25% 는 string[] 이며, 그 외는 int, int[], 쓰레드 변수 들이 있습니다. 통신시 데이터 처리 이후 초기화 하는 부분은 몇 군데에 존재합니다. (Remove() 사용)
또한, 포트는 시리얼 포트는 3개가 있고 1개만 송,수신을 하며 나머지 2개는 송신만 담당합니다.

위 프로그램에서 해당 현상이 발생되었을 때 해결하고 싶은데 메모리 부족 현상 원인으로 제가 알고 있는 것으로는 "GC 가 수집하지 못해서 메모리가 누적된다" 뿐입니다. 그래서 시도할 수 있는 방법이 제한적이에요.
위 프로그램의 원인 뿐만이 아니라 메모리 부족 현상의 다른 여러 가지 원인들도 알 수 있을까요 ?? 이런 현상이 발생하면 해결하고 싶은데 원인을 많이 알지 못해서 해결 방법이 한정적이라 답답합니다. ㅜㅜ








[최초 등록일: ]
[최종 수정일: 8/17/2017]


비밀번호

댓글 작성자
 



2017-08-17 04시25분
글쎄요. OOM 상황은 프로그램에서 인스턴스 객체를 전역 변수와 같은 곳에서 들고 있는 상황이 되면 GC가 수집할 수 없는 상황이 얼마든지 다양하게 나타나므로 딱히 이거다... 라고 말할 것이 없습니다.

해당 현상이 발생했을 때 procdump.exe와 같은 것을 이용해 일정 메모리 기준 이상이 되면 풀 덤프를 남기도록 해보세요. 아니면 프로그램 내부에서 메모리 체크를 하다가 스스로 남겨도 됩니다.

풀 덤프 파일을 남기는 방법
; http://www.sysnet.pe.kr/2/0/991

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

덤프 분석을 해보면... 그래도 어느 정도는 답을 얻을 수 있을 것입니다.
정성태
2017-08-18 05시41분
[kmi] 답변 감사합니다. 한번 시도해보겠습니다.
[guest]

... 61  62  63  64  65  66  67  68  69  70  71  72  [73]  74  75  ...
NoWriterDateCnt.TitleFile(s)
704이호정9/6/200710619        답변글 답변해주신 내용 잘 봤습니다. ^_^b
705정성태9/6/20079498            답변글 [답변]: 답변해주신 내용 잘 봤습니다. ^_^b
706이호정9/7/20079989                답변글 후후... 이러다가 CardSpace 전용게시판 되는 것 아닌지 모르겠습니다. ^_^a;;
693장근배8/29/20079489매핑 구간이 열려 있습니다 [2]
710장근배9/17/20079472    답변글 [답변]: 매핑 구간이 열려 있습니다
692채영사랑8/29/20079218<질문> Ms stress tool 로 부하테스트중.
697정성태9/1/20078911    답변글 [답변]: <질문> Ms stress tool 로 부하테스트중. [1]
690한귀순8/28/20079825ClickOnce 배포 추가질문 [4]
689clev...8/27/20079441SmartClient에서도 Exe COM과 같이 여러곳에서 변수 공유가 가능한가요? [2]
688한귀순8/24/200711634ClickOnce 배포 [1]
686이상욱8/21/200710567[질문] VS.NET 2008 - WCF 를 위한 디버깅 환경 개선 테스트 중에
687정성태8/21/20079162    답변글 [답변]: [질문] VS.NET 2008 - WCF 를 위한 디버깅 환경 개선 테스트 중에
685김동진8/19/200711129Vista에서 WSDL관련 IIs7세팅 질문입니다. [4]
683조스7/31/200710106스마트 클라이언트에서 다른 어셈블리(.NET component) 사용시 에러 [1]
682정해봉7/30/200711025비스타에서 CAS설정하기... 소스 첨부 [1]파일 다운로드1
684정해봉8/14/200710990    답변글 [답변]: 비스타에서 CAS설정하기... 소스 첨부 [3]
681박희진7/27/20079521caspol로 설정된 권한집합 웹에서 읽어올 수 있나요?? [1]
680창민이7/27/200710377COM+등록시 에러 부분 때문에.. [2]
678정해봉7/24/20079315비스타에서 CAS 설정하기... [1]
677첫사랑7/24/20078849SSL에 관한 질문입니다.
679정성태7/26/20079419    답변글 [답변]: SSL에 관한 질문입니다. [1]
676kiuk7/11/20079771웹폐이지상의 이미지 상태 저장을 하고싶습니다. [1]
675안연준7/6/200710202안녕하세요 ^^ [1]
674황태욱7/5/200711302utf-8 환경에서 파라미터 값에 한글이 있을 경우 깨지는 현상이.. [1]
672땡초7/4/200710833Remoting 객체를 호출하는 순간 Timer 의 Elapsed 이벤트가 멈추는 현상 [2]
670조성택7/3/200710346.Net에서 Timer클래스.. [1]
... 61  62  63  64  65  66  67  68  69  70  71  72  [73]  74  75  ...