Microsoft MVP성태의 닷넷 이야기
사파리 웹 브라우저의 메모리 leak 현상 [링크 복사], [링크+제목 복사]
조회: 15142
글쓴 사람
정성태 (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)
395정성태3/24/201117641윈도우 7/R2 - C 드라이브 용량이 부족해 SP1 설치가 안된다면?
394정성태3/23/201144102윈도우 업데이트 다운로드 폴더를 변경하는 방법 [11]
393정성태3/23/201113571누가 정치를 해야 하는가? [1]
392정성태3/19/201116587IE 9 - 사이트 고정된 바로가기의 보안 기능
391정성태3/17/201116282파수닷컴 관련하여 인터넷 익스플로러 9 작동 중지 현상에 대해서 [1]
390정성태3/15/201114631NT 서비스 단위로 CPU 사용률을 확인하는 방법
389정성태3/10/201120756Windows 7/2008 R2 SP1 설치로 늘어난 디스크 용량 줄이기 [3]
388정성태2/27/201114218[종료] 메모리(RAM) DDR3 2GB * 2EA를 드립니다. [1]
387정성태2/26/201124376기가바이트(GIGABYTE) GA-770TA-UD3 - RAID 1 구성 [1]
386정성태2/22/201113897Windows XP를 Windows 7로 업그레이드
385정성태2/21/201122181실패한 Windows 7 SP1 설치 [2]
384정성태2/17/201114870파워 서플라이(전원공급장치)에서 어떤 부품이 중요하다고 생각하세요?
383정성태2/17/201113214트레이 윈도우가 속한 프로세스 찾기
382정성태2/16/201116823RSupport(알서포트)를 이용한 원격 지원 방법
381정성태2/16/201115083노트북 램 8GB - 페이지 파일(pagefile.sys)을 없애다.
380정성태2/16/201113623인터넷 익스플로러 9 RC - 정식 버전 때 '재설치'해야 할 생각에 망설여진다면?
379정성태2/7/201120986Windows 7 - Taskhost.exe CPU 점유 문제
378정성태1/31/201115610System 이벤트 로그 - amdkmdag
376정성태1/13/201114877모니터 - 삼성 BX2431, 알파스캔 TLED24
374정성태1/7/201114495윈도우 라이브 메신저 - Windows Server 2008 R2 에서 "Remote Assistance" 활성화 하기
373정성태12/29/201013222나니아 연대기 - 새벽 출정호의 항해 트레일러 음악
372정성태12/25/201014693내용 복사(Copy & Paste)를 막은 블로그가 줄어들길 바랍니다!!! [8]
371정성태12/22/201048970뽀모도로 타이머 - 데스크톱용 [4]
370정성태12/20/201017881노트북과 PC에서 iPad를 충전시킴 ^^ [1]
369정성태12/15/201016549Adobe Reader - 마지막으로 본 페이지 기억시키는 방법 [3]
368정성태12/12/201022514새로운 취미 ^^ - 레고 마인드스톰 (LEGO Mindstorms) [2]
1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...