Linux 查看内存使用情况

Linux 查看内存使用情况

大家好,又见面了,我是全栈君。

1 . top  : 用于实时显示 process 的动态

Linux 查看内存使用情况

  PID:进程的ID  

  USER:进程所有

       PR:进程的优先级别,越小越优先被执

       VIRT:进程占用的虚拟内

       RES:进程占用的物理内

       SHR:进程使用的共享内

       S:进程的状态,S表示休眠,R表示正在运行,Z表示僵死状态,N表示该进程优先值为负

       %CPU:进程占用CPU的使用

       %MEM:进程使用的物理内存和总内存的百分

       TIME+:该进程启动后占用的总的CPU时间,即占用CPU使用时间的累加值

       COMMAND:进程启动命令名称

2.free:查看系统内存使用情况

Linux 查看内存使用情况

total:总计物理内存的大小

used:已使用多大

free:可用有多少

shared:多个进程共享的内存总额

buff/cached:磁盘缓存的大小

free命令主要用于显示内存数量,如下图中内容所表示

free -h 命令

Linux 查看内存使用情况

free -m 命令

Linux 查看内存使用情况

3.cat /proc/meminfo: 查看RAM使用情况最简单的方法是通过/proc/meminfo

这个动态更新的虚拟文件实际上是许多其他内存相关工具(如:free / ps / top)等的组合显示。

/proc/meminfo列出了所有你想了解的内存的使用情况。

进程的内存使用信息也可以通过/proc/<pid>/statm 和 /proc/<pid>/status 来查看。

Linux 查看内存使用情况

Linux服务器CPU100%问题

背景:用户反应我们系统卡顿,开始排查步骤:

1、查消耗cpu最高的进程PID。top -c 显示进程运行信息列表,按下大P,进程按照cpu使用率排序,发现第一位使用率172%,记下PID:6846。

2、根据PID查出消耗cpu最高的线程号。top -Hp 6846,显示一个进程的线程运行信息列表。按下大P,进程按照cpu使用率排序,可以看到前面四个的cpu都是80+%,记下四个线程号,分别是:6849、6850、6851、6852。

3、把上面四个线程的十进制数转成十六进制(printf %x 6849、printf %x 6850、printf %x 6851、printf %x 6852),分别是:

1ac1、1ac2、1ac31、1ac4。

4、根据线程号查出对应的java线程,进行处理。jstack -l 6846 > ./6846.stack,然后执行grep命令,看线程1ac1做了什么Linux 查看内存使用情况

由上图可见,cpu使用率高的线程都在GC task,JVM的GC线程一直在占用大量CPU,然后再搜索一下 项目名

cat 6846.stack | grep ‘rongke’ -C 20 | lessLinux 查看内存使用情况

可以看到,这个是项目里面把用户的短信保存到 mongoDB里的方法,去排查项目代码,看到保存短信的时候,开启了一个线程池,队列给了40960个,有点大,这应该是当时给用户下发短信时,临时设置的后面加了个0,发完之后忘记改过来了,但是一般队列是不会满的。应该是并发较大,创建了很多线程,再加上GC的线程也很多,导致的cpu使用率100%了。Linux 查看内存使用情况

解决方案:

1、可以先把队列改为4096个观察下(我没试)。我是先把保存短信的方法注释掉,因为此数据可有可无。

2、接入Ribbat MQ,把每一个短信放进mq里,另外起一个监听器去监听该mq,获取数据存到MongoDB里。
 

转载:https://blog.csdn.net/qq_33101675/article/details/90374105

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/111898.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • tomcat日志乱码怎么解决_log4j日志乱码

    tomcat日志乱码怎么解决_log4j日志乱码1.首先打开tomcat的conf目录下的logging.properties根据编译码去切换,例如你的编译器是utf-8的话,你就可以不用改(里面默认的是utf-8),如果你的编译器是GBK的话,那就把utf-8全部替换成GBK。2.idea设置-Dfile.encoding=UTF-8接着打开help的VMOptions最后重启idea就可以啦!…

  • java中scanner是什么意思_java中Scanner是什么?怎么用?

    java中scanner是什么意思_java中Scanner是什么?怎么用?在java中有一种类可以获取我们输入的信息,这也是java中的新特征,有小伙伴知道这是什么类吗?小编最近在学Scanner类,发现还需要结合正则表达式一起使用,这对我们以前知识的掌握来说,得有比较好的基础才能完成。下面我们就一起看看Scanner类如何在java中使用吧。1.概念一个可以使用正则表达式来解析基本类型和字符串的简单文本扫描器。2.语法Scanners=newScanner(S…

  • U盘中毒了?教你如何删除System Volume Information这个顽固文件夹「建议收藏」

    U盘中毒了?教你如何删除System Volume Information这个顽固文件夹「建议收藏」不得不说cmd命令很好用呢。最近我的U盘中毒了,格式化都删除不了SystemVolumeInformation这个顽固的文件夹,真心伤不起哇!还好现在解决了问题。看来以后得好好对待U盘,不能乱用了。本篇文章教大家如何删除SystemVolumeInformation这个顽固文件夹。希望对你有用。我的电脑是win10,win+R搜索cmd,启用cmd命令编辑器,并输入以下命令:attrib…

  • blob视频如何下载_blob加密视频下载

    blob视频如何下载_blob加密视频下载前言网页上有些视频是直接给的视频地址,那么很多浏览器都有插件进行视频下载,比如猎豹浏览器的:浏览器中有些视频是通过blob:https://baike.baidu.com/bf834217-9442-4c98-9ef6-0bd5f3408a4e的形式给出的。blob后面的网址不能直接访问。这是分片段进行加载的。。。比如百度百科搜索中的视频:离子液体这篇博客教你如何下载此类视频。准…

    2022年10月26日
  • 详解composer的自动加载机制

    详解composer的自动加载机制

    2021年10月27日
  • T检验三种方法的区分

    T检验三种方法的区分之前的文章中SPSSAU已经给大家详细地介绍了方差分析,之后收到的一些反馈以及日常的答疑中,我们发现关于T检验三种方法的区分还有很多小伙伴搞不清楚,下面就结合着具体案例详细聊聊T检验的那点事。01.概念T检验是通过比较不同数据的均值,研究两组数据之间是否存在显著差异。02.分类不同的T检验方法适用于不同的分析场景,具体的分类如下:03….

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号