Microsoft MVP성태의 닷넷 이야기
사파리 웹 브라우저의 메모리 leak 현상 [링크 복사], [링크+제목 복사],
조회: 15285
글쓴 사람
정성태 (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처리... 등등 이미 웹 브라우저에 포함된 구성요소가 너무나 많기 때문에 개발사 입장에서도 수용한계를 넘어섰는지도 모르겠습니다. 어찌보면, 현대의 웹 브라우저 프로그램은 간략화된 운영체제 수준이니까요. ^^;
정성태

... 16  17  [18]  19 
NoWriterDateCnt.TitleFile(s)
87정성태7/10/200610203머리 좀 식히시지요. 파일 다운로드1
86정성태7/4/200610864검색 엔진에서의 "정성태"
84정성태6/20/200610830Is it wrong to Love Microsoft?
81정성태5/21/200610506S-ATA II 300GB 하드 디스크 장착. ^^
78정성태5/5/200610698Introduction to Programming LEGO MINDSTORMS
76정성태4/9/200611487DevDays 2006 행사에서... [4]
75정성태3/29/200611035노트북 메모리 2GB로 업그레이드 [1]
80정성태5/18/200611755    답변글 Insufficient System Resources Exist to Complete the API
74정성태3/25/200612341재미있는 로그들.
73정성태3/27/200610663This Page Is Valid XHTML 1.0 Transitional!
71정성태3/16/200611601영어 공부 열심히. [1]
70정성태3/13/200610642MSDN Magazine 2006년 2월호의 표지에 실린 멋진 코드. ^^ [1]
69정성태3/10/200610796휴대폰 컬러링 변경. ^^v - "난 나직이 그의 이름을 불러 보았어"
68정성태3/2/200611863우리집 무선 Access Point - GN-B49G
67정성태3/1/200610226지금은 서울역... ^^
66정성태2/27/200610218MS, 윈도 XP용 웹 콘텐츠 필터링 SW 개발
63정성태2/12/200610345서비스 불안정 [2]
61정성태2/4/200611707새로나온 calc.exe
60정성태2/4/200610414FW: 멋진 시도 그리고 멋진 작품
59정성태1/26/20069992질문은 이렇게 해주십시오.
54정성태12/3/20059866블로그의 출처...
53정성태11/20/200510369내 모든 토픽의 꼬리말로 달고 싶은 말
51정성태11/5/20059900저는... 모든 사람들이... [1]
48정성태10/19/200510083VSTS 와 함께 나온 "개발자 송" - .NETXPERT 5명 참가. ^^; [2]
47정성태10/10/200510216(일기는 아니지만) MSDN Magazine 같이 공부하실 분... 2차 모집합니다. ^^ [8]
46정성태11/14/200510478사진 2장.^^ [1]
... 16  17  [18]  19