Centos7服务器内存使用过高排查
2022/2/20 7:26:22
本文主要是介绍Centos7服务器内存使用过高排查,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
Centos7服务器内存使用过高排查
查看内存使用情况
[root@VM-16-17-centos ~]# free -h total used free shared buff/cache available Mem: 3.7G 3.1G 152M 772K 413M 338M Swap: 0B 0B 0B $ free -m $ top //shift+m按内存占用比排序
-
1、total:总的物理内存
2、used:系统使用的内存,包括buff+cache。并非系统真正使用的内存。系统真正使用的内存=used-buff/cache
3、free:空闲的内存,系统未使用的内存,并不是系统启动应用程序可以真正使用的内存。
4、shared:共享内存
5、buff/cache:磁盘缓存的大小
6、available:在旧版free中,没有这个选项。这个选项指的是,系统启动程序时可以利用的内存,当这个选项很小或者不够启动程序所需的内存,会提示系统内存不足,无法启动,此时就需要处理问题,是物理内存真的不足,还是清理系统缓存。
内存占用高的前10
ps aux | head -1;ps aux |grep -v PID |sort -rn -k +4 | head -10
从上看内存使用较多的是MySQL
# 登录MySQL查看-----显示系统中正在运行的所有进程,也就是当前正在执行的查询 # 可是才刚刚部署,操。。。。然后并没有发现,就重启了服务器,内存使用就正常了我擦。。。。遇到鬼了吧 mysql> show processlist;
解决 cached 占用过高问题
buffer,cached的作用:
cached主要负责缓存文件使用, 日志文件过大造成cached区内存增大把内存占用完 . Free中的buffer和cache:(它们都是占用内存): buffer : 作为buffer cache的内存,是块设备(磁盘)的缓冲区,包括读、写磁盘 cache: 作为page cache的内存, 文件系统的cache,包括读、写文件 如果 cache 的值很大,说明cache住的文件数很多。
解决方法:
手动释放cached方法有三种(系统默认值是0,释放之后你需要再改回0值):
释放前最好sync一下,防止丢数据
sync 在启动机器或关机之前一定要运行sync命令。记住在任何情况下,慎重地执行sync命令决不会有任何坏处,sync命令强制把磁盘缓冲的所有数据写入磁盘
#常用方法是 sync echo 1 > /proc/sys/vm/drop_caches #清除后要还原系统默认配置: echo 0 > /proc/sys/vm/drop_caches #查看设置 sysctl -a | grep drop_caches
这篇关于Centos7服务器内存使用过高排查的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享
- 2024-11-23oss直传有什么好处?-icode9专业技术文章分享
- 2024-11-23如何将oss直传封装成一个组件在其他页面调用时都可以使用?-icode9专业技术文章分享
- 2024-11-23怎么使用laravel 11在代码里获取路由列表?-icode9专业技术文章分享
- 2024-11-22怎么实现ansible playbook 备份代码中命名包含时间戳功能?-icode9专业技术文章分享