Microsoft MVP성태의 닷넷 이야기
사파리 웹 브라우저의 메모리 leak 현상 [링크 복사], [링크+제목 복사]
조회: 15147
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

사파리 웹 브라우저의 메모리 leak 현상

사파리 웹 브라우저는 safari.exe 뿐만 아니라 별도로 WebKit2WebProcess.exe를 띄워서 렌더링을 분리하는 것 같습니다.

아래의 화면에 보이는 IE, Chrome, Safari 프로세스는 모두 같은 웹 사이트를 방문했을 때의 상황을 보여주고 있습니다.

memory_leak_1.png

그런데, 유독 사파리의 WebKit2WebProcess.exe는 점점 더 메모리가 커지더니 급기야 다음과 같이 오류를 내버리고 죽고 맙니다.

memory_leak_2.png

WebKit2WebProcess.exe만 문제가 있는 것이 아니고, Safari.exe 자체도 메모리가 다소 증가한 상태이고 더욱 심각한 것은 GDI 리소스가 676에서 7,244개로 어마어마하게 새고 있다는 것입니다.

같은 사이트를 방문 중인 IE와 Chrome의 경우에는 시간은 지났지만 안정적인 리소스 유지를 하고 있는 것을 볼 수 있고.

사파리로 SPA(Single-Page Application)같은 것을 만들 때는 주의를 하셔야겠습니다.




그러게요. ^^ 혹시나 맥용 사파리에서는 홈 그라운드이니만큼 이런 문제가 없을 수도 있겠다 싶어 테스트 해보았는데요. 아래는 역시 같은 응용 프로그램을 방문했을 때의 처음 메모리 사용량입니다.

mac_safari_leak_1.png

시간이 지나자 메모리가 2배 이상으로 뛰었습니다.

mac_safari_leak_2.png

게다가, CPU 사용량이 심상치 않습니다. 같은 사이트를 방문 중인 Chrome은 17.5%이지만 사파리는 42.9%를 치고 있습니다.

mac_safari_leak_3.png




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







[최초 등록일: ]
[최종 수정일: 11/6/2013]

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

비밀번호

댓글 작성자
 



2013-11-05 02시13분
[땡초] 이게 윈도우용만 이럴거에요.
윈도에선 사파리와 크롬은 친척사이 ㅡㅡㅋ
[guest]
2013-11-05 03시11분
테스트를 맥용으로도 해본 결과를 추가했어요. ^^
정성태
2015-02-27 04시41분
[JOE] 맥에서 사파리를 메인 웹브라우저로 쓰고 있습니다. 2년간 아무 문제 없이 사용했습니다만. 바로 어제 친구가 비슷한 증상을 호소하면서 몇 개의 스크린샷을 보내왔습니다. 겨우 한개의 탭과 메모 앱 한개를 사용할 뿐이었는데, 사용가능한 메모리가 1기가 미만이더군요.. 그래서 일단 재부팅후 같은 증상이 나타나면 다시 스크린샷을 보내달라고 했는데, 아주 빈번히 일어나는 문제였습니다.

[guest]
2015-02-28 12시11분
@JOE 사실 개발자 입장에서는 이해가 되긴 합니다. ^^ Javascript 인터프리터, Garbage Collector, CSS 처리, HTML 처리(HTML4 이하는 물론이고 HTML5 처리), WebGL처리, SVG처리... 등등 이미 웹 브라우저에 포함된 구성요소가 너무나 많기 때문에 개발사 입장에서도 수용한계를 넘어섰는지도 모르겠습니다. 어찌보면, 현대의 웹 브라우저 프로그램은 간략화된 운영체제 수준이니까요. ^^;
정성태

1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...
NoWriterDateCnt.TitleFile(s)
175정성태10/6/200714704BBC 뉴스를 파일로 녹음하는 방법 [2]
174정성태10/3/200712748x64 비스타에서 YBM 폰트 설치
172정성태10/1/200713674The Secret [2]
171정성태9/28/200711870구글의 차세대 사업 승부수는 ‘3D 가상현실’(?) [1]
170정성태9/28/200712413정작 마이크로소프트 스스로는 .NET Framework 을 얼마나 적용하고 있을까? [2]
169정성태9/20/200711863SyncToy 1.4와 비스타 64비트에서의 문제
166정성태9/7/200712335텍스트 편집기로서의 Visual Studio 사용 [2]
165정성태8/27/2007115466.4GB 하드 2개 처분
164정성태8/20/200713003D820 지문 인식 드라이버 - Vista x64
163정성태7/30/200712262에버런 출시일 8월 20일 [4]
162정성태7/18/200712457SSD(Solid State Drive) 의 성능 향상이 얼마나 될까? [2]
161정성태7/18/200712064Vista for x64에서의 페이징 파일 관리 문제
160정성태7/18/200712787지름의 자세가 이 정도는 되어야.
159정성태7/18/200715396D820 - 그래픽 카드 오버 클럭
158정성태7/12/200712876고민... 고민... UMPC... [4]
157정성태7/10/200712909주당 16시간 일하기
156정성태7/8/200713392Vista와 KTF iPlug: 메시지 관리
155정성태6/28/200711989백업! [1]
154정성태6/19/200712777Summer Nights
153정성태6/17/200712313내 직업...! [2]
152정성태6/15/200712059한글 IME 쓰는 방법.
151정성태6/15/200711748끌리는 UMPC들...
150정성태6/11/200711579donga.com[뉴스]-‘중퇴생’ 빌 게이츠 32년 만에 졸업장
149정성태6/10/2007120616.4GB 하드 2개 및 단면 512MB 메모리 처분
146정성태5/26/200711990일반인을 위한 프로그래밍
145정성태5/18/20071367522" LCD 모니터 사용 [4]
1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...