banner
Hi my new friend!

山河浪漫,
人间温暖。

Scroll down

背景

生产项目为java web项目,后台有多个定时任务处理数据,于2015年上线,至出现问题时已平稳运行5年,中途未出现内存溢出导致系统卡死的情况,某一天发现数据处理缓慢,连接到应用服务器(linux),监控日志发现应用报错如下:OutOfMemoryError: Java heap space

问题定位

1、执行top命令,查看java应用内存占用情况
2、导出jvm内存文件 jmap -dump:format=b,file=heap.bin pid
3、导出内存文件到本地,打开eclipse——》File——》Open File…(需安装eclipse memory analyzer插件,安装方法可百度),打开内存文件
然后就可以看到jvm内存相关的统计信息,如下:
微信图片_20210111105621.png
可以看出内存中有一个1.4G的大对象,这块是有问题的,继续分析:
微信图片_20210111110520.png
微信图片_20210111110526.png
微信图片_20210111110529.png
微信图片_20210111110531.png
微信图片_20210111110534.png
最后找到了导致产生大对象的类及方法,手动执行该方法的查询数据库语句,竟然一次查询出了超过300w条数据到内存,至此,问题找到

解决方法

产生问题的原因是一次加载过多的对象到内存,修改代码查询条件,每次只查询200条数据,完美解决

我很可爱,请给我钱

昵称
邮箱
0/200
  • 😂
  • 😀
  • 😅
  • 😊
  • 🙂
  • 🙃
  • 😌
  • 😍
  • 😘
  • 😜
  • 😝
  • 😏
  • 😒
  • 🙄
  • 😳
  • 😡
  • 😔
  • 😫
  • 😱
  • 😭
  • 💩
  • 👻
  • 🙌
  • 🖕
  • 👍
  • 👫
  • 👬
  • 👭
  • 🌚
  • 🌝
  • 🙈
  • 💊
  • 😶
  • 🙏
  • 🍦
  • 🍉
  • 😣
  • OωO
  • |´・ω・)ノ
  • ヾ(≧∇≦*)ゝ
  • (☆ω☆)
  • (╯‵□′)╯︵┴─┴
  •  ̄﹃ ̄
  • (/ω\)
  • ∠( ᐛ 」∠)_
  • (๑•̀ㅁ•́ฅ)
  • →_→
  • ୧(๑•̀⌄•́๑)૭
  • ٩(ˊᗜˋ*)و
  • (ノ°ο°)ノ
  • (´இ皿இ`)
  • ⌇●﹏●⌇
  • (ฅ´ω`ฅ)
  • (╯°A°)╯︵○○○
  • φ( ̄∇ ̄o)
  • ヾ(´・ ・`。)ノ"
  • ( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
  • (ó﹏ò。)
  • Σ(っ °Д °;)っ
  • ( ,,´・ω・)ノ"(´っω・`。)
  • ╮(╯▽╰)╭
  • o(*////▽////*)q
  • >﹏<
  • ( ๑´•ω•) "(ㆆᴗㆆ)
  • Emoji
  • 颜文字
0 条评论