记一次linux 内存占比过高

**linux内存几乎占满 **
如图
在这里插入图片描述

排查问题

使用top命令
发现 进程3034 占比非常高
在这里插入图片描述

这行命令能看出top500 的内存进程
在这里插入图片描述

发现java的进程内存 占比非常高 但cpu使用率不高

ps p 3034 -L -o pcpu,pmem,pid,tid,time,tname,cmd
查看该进程

发现该进程下好多个线程 占据内存空间
我们知道 每一个线程 都会有独自的栈空间 计数器 等 占据内存的东西

在这里插入图片描述
查看内存使用的堆栈:在这里我们挑选了TID=3051的线程进行分析,首先需要将3051这个id转换为16进制。需输入如下命令,

出错 查询堆栈信息
在这里插入图片描述

只能jstack pid为16进制的进程 先转换
在这里插入图片描述

Error attaching to remote server: java.rmi.UnknownHostException: Unknown host: bda; nested exception is:
java.net.UnknownHostException: bda

定位到具体进程 如无 代码错误 最简单就是kill -s 9 pid 号
强制杀死进程
在这里插入图片描述

立马释放了一般内存

参考文庄java排查

https://blog.csdn.net/yangfengjueqi/article/details/85756520

java 排查

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux内存用过可能是因为程序运行时用的内存过多,或者是由于系统资源的不足。建议使用linux命令top或者free查看系统内存的使用情况,找出内存最多的程序,并采取相应的措施优化。 对于Linux内存用过的问题,建议采取以下步骤进行排查和优化: 1.使用命令top或者free查看系统内存的使用情况。在终端中输入"top"或者"free -m"命令,可以查看当前系统中各个进程内存的情况,以及系统总内存、已用内存和可用内存等信息。 2.找出内存最多的进程。在top命令中,按下shift+m可以将进程按照内存用量从到低排序。在free命令中,可以查看各个内存区域的使用情况,找出内存最多的区域。 3.分析进程或者内存区域的使用情况。根据进程或者内存区域的使用情况,分析其是否存在内存泄漏或者用过多内存的情况。如果存在问题,需要对相应的程序进行优化。 4.释放不必要的内存。如果存在不必要的内存用,可以通过释放内存来缓解内存用过的问题。在终端中输入"sudo sync && sudo echo 3 > /proc/sys/vm/drop_caches"命令,可以释放系统中的缓存。 5.调整系统内存管理策略。在一些情况下,可能需要调整系统内存管理策略来优化内存的使用效率。例如,可以修改内核参数vm.swappiness的值,来控制系统使用交换分区的频率。 总之,针对Linux内存用过的问题,需要通过分析进程或者内存区域的使用情况,以及调整系统内存管理策略等措施,来优化内存的使用效率。 Linux内存用过的原因可能有很多,例如程序的内存泄漏、网络应用的频繁使用、多个应用程序同时运行等。最好的办法是检查系统进程并终止不必要的进程,以减少内存用。Linux内存使用率过可能是因为以下原因: 1. 运行的程序用了大量内存。可以使用 top 或 htop 等工具查看进程用的内存情况,并尝试关闭不必要的程序或调整它们的配置,以降低它们的内存用。 2. 内存泄漏。如果程序存在内存泄漏,它们会持续用系统内存,直到内存耗尽。可以使用 valgrind 等工具来检查程序是否存在内存泄漏,并及时修复。 3. 缓存和缓冲区。Linux 会将一部分内存用于文件缓存和网络缓冲区,以提系统性能。这些缓存并不会直接用系统内存,但会在需要时释放。如果系统内存不足,Linux 会自动清理这些缓存,释放内存空间。 4. 内存碎片。当大量进程频繁申请和释放内存时,会产生内存碎片,导致系统无法分配大块的连续内存空间。可以使用内存碎片整理工具(如 malloc_trim)来解决这个问题。 5. 系统参数设置不当。如果系统参数设置不当,可能会导致内存过度使用。可以使用 sysctl 等工具来检查和调整系统参数。 ### 回答2: Linux内存用过的原因可能很多,以下是一些常见的原因和解决方法。 1. 内存泄露:程序中存在内存泄露,导致内存用不断增加。可以使用工具如Valgrind等来检测和调试程序。 2. 进程爆炸:如果系统中有大量的进程存在,每个进程都用一些内存,就会导致整体内存用很。可以使用命令如ps、top等来查看进程情况,并对不必要的进程进行杀掉或优化。 3. 缓存和缓冲区:Linux系统会通过缓存和缓冲区等机制来提升系统的性能,但这些机制也会用一部分内存。可以通过一些命令如free、vmstat等来查看缓存和缓冲区的情况,并通过调整内核参数来优化。 4. 虚拟内存:如果物理内存不够用,系统会使用虚拟内存进行内存管理,但虚拟内存的实现会带来一定的性能损失。可以通过增加物理内存或调整虚拟内存的相关参数来优化。 5. 软件/服务:很多软件或服务本身就是内存用较的,如数据库、Web服务器等。可以通过调整软件或服务的配置来优化内存用,例如调节缓存大小、减少并发连接数等。 总之,针对Linux内存用过的问题,需要综合考虑各种因素,找到合适的解决方法来优化。常用的工具如top、ps、free、vmstat、sar等都可以帮助我们了解系统的内存使用情况。同时,也需要关注系统的物理内存、交换分区、进程数、缓存和虚拟内存等参数,并加以调整和优化。 ### 回答3: Linux内存用过可能有多种原因,以下是一些可能的解决方案: 1. 确认是否为缓存导致的内存用过。在Linux中,USED的内存不一定是真正用的内存,而有可能是被分配给缓存。可以使用命令“free -m”查看内存用情况,并注意查看buffers/cache的用情况。如果buffers/cache的用比例较,可以尝试使用“sync && echo 3 > /proc/sys/vm/drop_caches”释放缓存。 2. 关闭不必要的服务。可以使用命令“systemctl list-unit-files”查看所有已安装的服务,并关闭不必要的服务来释放内存。 3. 开启内存垃圾回收机制。如果内存用过,可以尝试开启内存垃圾回收机制,将不常用的内存删除以释放内存。 4. 限制进程内存使用。可以使用“ulimit -v”命令限制进程使用的内存大小,避免单个进程用过多内存。 5. 调整Swap空间。Swap空间可以作为虚拟内存使用,在内存不足时可以将部分数据写入Swap空间。可以调整Swap空间的大小来优化内存使用。 总结:如果Linux内存用过,首先需要确认是真正的内存用还是缓存用。如果是缓存用,可以释放缓存;如果是真正的内存用,可以调整服务、开启内存垃圾回收机制、限制进程内存使用等方式来优化内存使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值