데이터 베이스 MySQL 튜토리얼 探究内存泄露—Part2—分析问题

探究内存泄露—Part2—分析问题

Apr 01, 2017 pm 02:44 PM

本文由ImportNew-黄索远翻译自captaindebug ImportNew注:如果你也对Java技术翻译分享感兴趣,欢迎加入我们的Java开发小组。参与方式请查看小组简介。 如果你看过这篇博客的第一部分,就会知道在展示的内存泄露示例代码使用生产者-消费者模型创建了一个模拟

  本文由 ImportNew - 黄索远 翻译自 captaindebug

ImportNew注:如果你也对Java技术翻译分享感兴趣,欢迎加入我们的 Java开发 小组。参与方式请查看小组简介。

如果你看过这篇博客的第一部分,就会知道在展示的内存泄露示例代码使用生产者-消费者模型创建了一个模拟股票交易的应用,所有的交易命令都被存入一个虚拟的数据库中。示例代码故意留下了一个缺陷(OrderRecord线程处理一条命令后sleep一段时间),使得OrderRecord线程消费命令的速度跟不上OrderFeed线程生产命令的速度。这就意味着存储命令的队列会变得越来越长,直到最后内存溢出程序崩溃。问题是,如果只看我的代码,确实能够很轻松得看出哪里出了差错;但是如果出问题的代码你从未看过并且代码又长又复杂,加之没有监控线程来帮助你观察队列大小或者其他内部信息,这时该怎么办呢?

下面向大家介绍分析程序内存泄露问题的三个步骤:

  1. 提取发生内存泄露的服务器的转储文件。

  2. 用这个转储文件生成报告。

  3. 分析生成的报告。

有几个工具能帮你生成堆转储文件,分别是:

  • jconsole

  • Jvisualvm

  • Eclipse Memory Analyser Tool(MAT)

用jconsole提取堆转储文件

将jconsole关联你的应用:单击MBeans选项卡打开com.sun.management包,点击HotSpotDiagnostic,点击Operations选择dumpHeap。这时你将会看到dumpHeap操作:它接受两个参数p0和p1。在p0的编辑框内输入一个堆转储的文件名,然后按下DumpHeap命令。

1386.png

用jvisualvm提取堆转储文件

连接示例代码,右键点击你的应用,在左侧的“application”窗格中选择“Heap Dump”。

注意:如果你在发生内存泄露的服务器上有一个远程连接,那么jvisualvm将会把转出文件保存在远程机器(假设这是一台unix机器)上的/tmp目录下。你不得不将这个文件通过FTP传送到你的机器上,然后再进行研究。

1387.png

用MAT来提取堆转储文件

jconsole和jvisualvm本身就是JDK的一部分,而MAT或者称作“内存分析工具”,是一个基于eclipse的工具。你可以从eclipse.org下载。

最新版本的MAT需要你在电脑上安装JDk1.6。如果你用的是Java1.7版本也不用担心,因为它会自动为你安装1.6版本,并且不会和安装好了的1.7版本产生冲突。

1388.png

使用MAT的时候,只需要点击“Aquire Heap Dump”,然后遵循指示就可以了。

1389.png

远程连接

-Dcom.sun.management.jmxremote
-Dcom.sun.management.jmxremote.port=9010
-Dcom.sun.management.jmxremote.local.only=false
-Dcom.sun.management.jmxremote.authenticate=false
-Dcom.sun.management.jmxremote.ssl=false
로그인 후 복사

何时提取堆转存文件

这需要耗费一点心力和运气。如果太早提取了堆转储文件,那么你将不能发现问题。因为它们被合法,非泄露类的实例屏蔽了。不过也不能等待太久,因为提取堆转储文件需要占用内存,进行提取操作的时候可能会导致你的应用崩溃。

1390.png

最好的办法是将jconsole连接到你的应用程序并监控堆的占用情况,知道它看起来像在崩溃的边缘。这样很容易就能监控到,因为没有发生内存泄露时,三个堆部分指标都是绿色的。

1391.png

分析转储文件

现在轮到MAT发挥作用了,因为它本身就是被设计用来分析堆转储文件的。要打开和分析一个堆转储文件,选择File选项下的Heap Dump选项。选择了你要打开的文件后,你将会看到如下三个选项:

1392.png

选择Leak Suspect Report选项。在MAT翻腾几秒后,会生成这样的一个页面:

1393.png

如饼状图显示:在示例中,疑似有一处发生了内存泄露。也许你会想,这样的做法只有在代码受到控制的情况下才可取。毕竟这只是个例子,这又能说明什么呢?好吧,我承认在这个例子里,所有的问题都是可见的;线程a占用了98.7MB内存,其他线程用了1.5MB。在实际情况中,你得到的图表是这样的。

下一步要做的就是挖得更深一点……

1394.png

如上图所示,报告的下一部分告诉我们,有一个LinkedBlockQueue占用了98.46%的内存。想要进一步的探究,点击Details>>。

1395.png

可以看到,问题确实是出在我们的orderQueue上。这个队列里存储了所有生成的虚拟命令,并且可以被我们上篇博文里提到的三个线程OrderFeed、OrderRecord、OrderMonitor访问。

那么一切都清楚了,MAT告诉我们:示例代码中有一个LinkedBlockQueue,这个队列用尽了所有的内存,从而导致了严重的问题。不过我们不知道这个问题为什么会产生,也不能指望MAT告诉我们。这个问题,如阿加莎·克里斯蒂笔下的赫尔克里·波洛所说,得用“泽灰色小细胞”解决……

 以上就是探究内存泄露—Part2—分析问题的内容,更多相关内容请关注PHP中文网(www.php.cn)!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

win11 메모리 누수 해결 방법 win11 메모리 누수의 원인 분석 및 다양한 해결 방법. win11 메모리 누수 해결 방법 win11 메모리 누수의 원인 분석 및 다양한 해결 방법. Feb 29, 2024 am 09:58 AM

최근 win11 시스템을 사용하는 많은 친구들은 컴퓨터 바탕 화면 창에서 차지하는 메모리가 매우 크고 심각한 메모리 누수로 인해 다른 프로그램이 지연되고 원활하게 실행되지 않는다는 사실을 발견했습니다. 이 문제를 해결하기 위해. 사용자는 이를 어떻게 해결해야 할까요? 컴퓨터의 제어판을 열고 전원 버튼 기능을 클릭하여 빠른 시작 옵션을 선택 취소합니다. 컴퓨터를 다시 시작하면 문제가 해결될 수도 있습니다. 그래픽 카드 드라이버. 드라이버를 다운로드하십시오. 메모리 누수의 원인: 메모리 누수는 잘못된 메모리 할당으로 인해 컴퓨터 프로그램의 리소스가 잘못 정렬되는 것입니다. 이는 사용되지 않은 RAM 위치가 여전히 해제되지 않은 경우 발생합니다. 메모리 누수를 공간 누수 또는 메모리 누수와 혼동하지 마세요.

Golang 함수 메모리 누수 감지 및 해결 Golang 함수 메모리 누수 감지 및 해결 Apr 23, 2024 pm 05:09 PM

Go 언어에는 함수 메모리 누수가 있으며 이로 인해 애플리케이션이 지속적으로 메모리를 소비하고 충돌이 발생합니다. 감지를 위해 런타임/pprof 패키지를 사용할 수 있으며, 함수가 실수로 불필요한 리소스에 대한 참조를 보유하고 있는지 확인할 수 있습니다. 메모리 누수를 해결하려면 일반적으로 함수 코드를 검사하고 전역 변수나 클로저 참조를 찾아 누수를 일으킨 참조를 찾아야 합니다.

C++의 일반적인 메모리 관리 문제에 대한 자세한 분석 C++의 일반적인 메모리 관리 문제에 대한 자세한 분석 Oct 10, 2023 am 10:51 AM

C++는 강력한 프로그래밍 언어이지만 메모리 관리에 세심한 주의가 필요한 언어이기도 합니다. C++로 프로그램을 작성할 때 메모리 관리 문제가 자주 발생합니다. 이 기사에서는 C++의 일반적인 메모리 관리 문제를 자세히 분석하고 독자가 이러한 문제를 이해하고 해결하는 데 도움이 되는 특정 코드 예제를 제공합니다. 1. 메모리 누수(MemoryLeak) 메모리 누수란 프로그램에서 동적으로 할당된 메모리가 제대로 해제되지 않아 메모리 자원이 낭비되는 것을 의미한다. 이는 특히 대규모 또는 장기간 실행 시 흔히 발생하는 문제입니다.

PHP 애플리케이션의 메모리 누수: 원인, 감지 및 해결 방법 PHP 애플리케이션의 메모리 누수: 원인, 감지 및 해결 방법 May 09, 2024 pm 03:57 PM

PHP 메모리 누수는 애플리케이션이 메모리를 할당하고 해제하지 못할 때 발생하며, 이로 인해 서버의 사용 가능한 메모리가 감소하고 성능이 저하됩니다. 원인에는 순환 참조, 전역 변수, 정적 변수 및 확장이 포함됩니다. 탐지 방법에는 Xdebug, Valgrind 및 PHPUnitMockObjects가 포함됩니다. 해결 단계는 누출 원인 식별, 누출 수정, 테스트 및 모니터링입니다. 실제 예제에서는 순환 참조로 인해 발생하는 메모리 누수와 소멸자를 통해 순환 참조를 중단하여 문제를 해결하는 구체적인 방법을 보여줍니다.

Linux 시스템의 과도한 메모리 및 누출 문제를 해결하는 방법 Linux 시스템의 과도한 메모리 및 누출 문제를 해결하는 방법 Jun 30, 2023 pm 02:21 PM

Linux 시스템에서 자주 발생하는 높은 메모리 사용량 및 메모리 누수 문제를 처리하는 방법 Linux 시스템을 사용하는 과정에서 때때로 높은 메모리 사용량 및 메모리 누수 문제가 발생합니다. 이러한 문제는 시스템 속도 저하, 애플리케이션 충돌, 심지어 시스템 충돌을 일으킬 수 있습니다. 이 문서에서는 이러한 문제를 해결하는 방법을 살펴봅니다. 먼저, 높은 메모리 사용량과 메모리 누수의 개념을 이해해 보겠습니다. 높은 메모리 사용량 메모리 사용량이 높다는 것은 시스템에서 사용 가능한 메모리가 거의 없고 대부분의 메모리가 사용되고 있음을 의미합니다. 메모리를 사용하는 경우

Java 함수에서 메모리 해제와 관련된 일반적인 문제를 해결하는 방법은 무엇입니까? Java 함수에서 메모리 해제와 관련된 일반적인 문제를 해결하는 방법은 무엇입니까? May 02, 2024 am 09:57 AM

Java의 메모리 관리에는 가비지 수집이 포함되지만 여전히 문제가 발생할 수 있습니다. 일반적인 문제에는 메모리 누수 및 메모리 조각화가 포함됩니다. 메모리 누수는 더 이상 필요하지 않은 참조를 보유하는 객체로 인해 발생하며 순환 참조를 피하고, 약한 참조를 사용하고, 변수 범위를 제한하여 해결할 수 있습니다. 메모리 조각화는 빈번한 할당 및 할당 해제로 인해 발생하며 메모리 풀, 대형 개체 풀 및 컴팩트 가비지 수집을 사용하여 해결할 수 있습니다. 예를 들어 약한 참조를 사용하면 메모리 누수를 처리하고 가비지 수집기가 더 이상 필요하지 않은 개체를 회수하도록 할 수 있습니다.

Golang 개발 노트: 메모리 누수 문제를 방지하는 방법 Golang 개발 노트: 메모리 누수 문제를 방지하는 방법 Nov 23, 2023 am 09:38 AM

Golang은 강력한 동시성 기능과 내장된 가비지 수집 메커니즘으로 널리 알려진 빠르고 효율적인 개발 언어입니다. 그러나 Golang으로 개발하더라도 여전히 메모리 누수가 발생할 수 있습니다. 이 문서에서는 개발자가 메모리 누수 문제를 방지하는 데 도움이 되는 몇 가지 일반적인 Golang 개발 고려 사항을 소개합니다. 순환 참조를 피하세요 순환 참조는 Golang의 일반적인 메모리 누수 문제 중 하나입니다. 두 객체가 서로를 참조할 때 이러한 객체에 대한 참조가 적시에 해제되지 않으면

Go 언어 개발의 잠재적 위험에 대해 이야기하세요. Go 언어 개발의 잠재적 위험에 대해 이야기하세요. Mar 04, 2024 pm 03:33 PM

빠르고 효율적이며 사용하기 쉬운 프로그래밍 언어인 Go 언어는 점점 더 개발자들의 선호를 받고 있습니다. 그러나 다른 프로그래밍 언어와 마찬가지로 Go 언어 개발에도 잠재적인 위험이 있습니다. 주의를 기울이지 않고 처리하지 않으면 코드 품질이 저하되고 심지어 심각한 결과를 초래할 수도 있습니다. 이 기사에서는 Go 언어 개발에서 발생할 수 있는 몇 가지 잠재적인 위험을 살펴보고 특정 코드 예제를 통해 이를 분석하고 논의합니다. 1. 동시 처리의 함정 Go 언어는 본질적으로 고루틴과 채널을 통한 동시 프로그래밍을 지원합니다.

See all articles