简介

查看操作系统配置最关键的几个命令是
lscpu 查看CPU信息
以及free 查看内存信息.
不过free信息有一个疑惑点
他的 free的值可能很小. 会让搭建产生误解.
这里简单说明一下.

free

free -m
可以简单的以 MBytes 为单位展示系统的内存使用情况.
free -m
total used free shared buff/cache available
Mem: 31867 9502 9110 241 13254 21670
Swap: 16127 0 16127 # Mem 指代是物理内存. Swap指代的是虚拟内存或者称之为在磁盘上通过换页出去的内存.
# 需要注意 Swap 与虚拟内存系统完全不一样. Swap里面的内存使用时会出现pageout的中断
# 使用Swap会导致严重的性能衰退. 访问延迟会从 120nm 升级到 10ms, 出现多个数量级的差距. # total 全部安装的内存, 一般会比2的n次方小一点.有部分保留内存.
# used 一般可以理解内 所有的程序commited 的内存数据量.
# free 就可以程序随后可以使用的量.
# shared 共享的内存
# buff/cache 是一个关键, 他一般指的 page cache,inodes缓存dentries缓存 三部分.
# available 是可以给空闲使用的内存数据量, 基本上等于free+buff/cache

清理buffer/cache

可以使用 sync &&  echo 3 >/proc/sys/vm/drop_caches 的方式进行buff/cache的清理
可以查看解释
To free pagecache:
* echo 1 > /proc/sys/vm/drop_caches
To free dentries and inodes:
* echo 2 > /proc/sys/vm/drop_caches
To free pagecache, dentries and inodes:
* echo 3 > /proc/sys/vm/drop_caches
## pagecache 可以理解为一开始说的 读缓存和写buffer. linux最新系统已经将两者进行了合并.
## inodes 指的是file 文件的缓存信息
## dentries 指的是文件系统目录的缓存信息. 注意为了防止数据丢失 最好是先使用 sync 执行一下再进行相应的 echo 操作.

内存over-commited的处理

Linux允许内存提交的数量比实际内存数量要高
有时候机器内存比较小,启动服务报错时可以临时处理一下.
但是不建议生产如此出现, 容易导致OOM
修改方法:
1. 永久生效:
vi /etc/sysctl.conf ,改vm.overcommit_memory=1,然后sysctl -p 生效
2. 临时处理:
sysctl vm.overcommit_memory=1 或
sysctl -w vm.overcommit_memory=1
echo 1 > /proc/sys/vm/overcommit_memory 参数的含义为:
0: 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,
内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1: 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
2: 表示内核允许分配超过所有物理内存和交换空间总和的内存。

减少缓存的使用

buff/cache 其实对系统的性能能够产生正向的效果.
他将缓慢磁盘里的数据暂存到内存中, 可以极大的提高系统的性能.
尤其是小白开发开发的程序写入大量日志时,能够减少IO导致的开销,提高系统性能. 但是他使用的过多, 也对java程序进行heap区域malloc产生异常.
所以也需要进行优化与调整. 可以在/etc/sysctl.conf中添加如何内容,禁止使用缓存
vm.dirty_ratio = 1
vm.dirty_background_ratio=1
vm.dirty_writeback_centisecs=2
vm.dirty_expire_centisecs=3
vm.drop_caches=3
vm.swappiness =100
vm.vfs_cache_pressure=163
vm.overcommit_memory=2
vm.lowmem_reserve_ratio=32 32 8
kern.maxvnodes=3 Study From https://blog.51cto.com/bronte/1220005
# 注意可以swapoff -a 关闭虚拟内存, 可以避免使用swap造成性能下降
# 但是会极大的提高OOM产生的概率.
vm.swappiness=0:表示最大限度使用物理内存,然后使用swap
vm.swappiness=100:表示积极的使用swap分区。
vm.swappiness=60:默认值

OOM的产生

因为linux支持可以overcommit 所以会导致应用服务器生产的内存超过总数.
系统为了保证稳定性,不得已就会杀掉部分内存大的程序就会产生OOM
查看的方法:
dmesg |grep -i oom
如果有 很明显就可以看到. Linux对大部分申请内存的请求都回复"yes",以便能跑更多更大的程序。
因为申请内存后,并不会马上使用内存。这种技术叫做 Overcommit。
当linux发现内存不足时,会发生OOM killer(OOM=out-of-memory)。
它会选择杀死一些进程(用户态进程,不是内核线程),以便释放内存。 当oom-killer发生时,linux会选择杀死哪些进程?选择进程的函数是oom_badness函数
(在mm/oom_kill.c中),该 函数会计算每个进程的点数(0~1000)。
点数越高,这个进程越有可能被杀死。
每个进程的点数跟oom_score_adj有关,而且 oom_score_adj可以被设置(-1000最低,1000最高)。
Study From https://blog.csdn.net/qq_42303254/article/details/88390730

如何防止OOM

如果用户将该进程的 oom_score_adj 设定成 -1000,表示禁止OOM killer 杀死该进程
注意不能随便这样设置, 会导致自己的服务器核心服务挂起,导致宕机.
不过你的服务绝对重要, 开发又不是很差, 你可以尝试一下. 修改方法为:
echo -1000 > /proc/$pid/oom_score_adj 注意这个数值是可以修改的 -1000 表示最重要. 他会影响. oom_score的数值.
具体可以参考:
https://www.jianshu.com/p/bbaeff371019

Linux的free命令与OOM的简单总结的更多相关文章

  1. linux程序调试命令addr2line之入门简单介绍(本文先不聊gdb调试)

    addr2line有什么作用呢? 可别小瞧它, 它能够定位到代码出错的位置. 以下, 我们来看看这个简单的代码: #include <stdio.h> int main() { int * ...

  2. Linux下chkconfig命令详解 这个简单明了啊

    chkconfig命令主要用来更新(启动或停止)和查询系统服务的运行级信息.谨记chkconfig不是立即自动禁止或激活一个服务,它只是简单的改变了符号连接. 使用语法:chkconfig [--ad ...

  3. [Linux] 关于 history 命令的简单使用

    1. 如果不想记录当前 会话操作的命令的话 可以使用命令 set +o history 但是这个命令有一个坏处, 他自己被记住了... 2. 还有一个办法 就是 在退出登录之前执行命令 history ...

  4. (转)Linux 系统设置 : dmesg 命令详解

    原文:https://blog.csdn.net/yexiangCSDN/article/details/80683246 https://www.cnblogs.com/duanxz/p/34770 ...

  5. Linux下dmesg命令处理故障和收集系统信息的7种用法

    目录: <syslog之一:Linux syslog日志系统详解> <syslog之二:syslog协议及rsyslog服务全解析> <syslog之三:建立Window ...

  6. Linux下history命令用法

    如果你经常使用 Linux 命令行,那么使用 history(历史)命令可以有效地提升你的效率.本文将通过实例的方式向你介绍 history 命令的 15 个用法. 使用 HISTTIMEFORMAT ...

  7. 例解 Linux 下 Make 命令

    Linux 下 make 命令是系统管理员和程序员用的最频繁的命令之一.管理员用它通过命令行来编译和安装很多开源的工具,程序员用它来管理他们大型复杂的项目编译问题.本文我们将用一些实例来讨论 make ...

  8. Linux下who命令之C语言实现

    Linux下who命令之C语言实现 Step1:前期准备 首先要有一个清楚的认识:linux中一切皆文件 实现who命令,who命令也是Linux中的一个文件,那我们怎么找到它呢?我们可以" ...

  9. Linux下rz命令使用的实例详解

    Linux中rz命令和sz命令都可用于文件传输,而rz命令主要用于文件的上传,下面将通过几个实例来给大家详细介绍下Linux下rz命令的用法,一起来学习下吧. rz命令可以批量上传文件,当然也可上传单 ...

  10. linux下tar命令详解

     linux下tar命令详解    tar是Linux环境下最常用的备份工具之一.tar(tap archive)原意为操作磁带文件,但基于Linux的文件操作机制,同样也可适用于普通的磁盘文件.ta ...

随机推荐

  1. 华为云河图KooMap:夯实数字孪生底座,点燃燎原星火

    摘要:7月8日,华为开发者大会2023(Cloud)华为云河图KooMap技术分论坛在东莞溪村顺利举办. 7月8日,华为开发者大会2023(Cloud)华为云河图KooMap技术分论坛在东莞溪村顺利举 ...

  2. 对象存储只能按文件名搜索,你out了吧

    摘要:不少大公司的一个桶里都是几亿几十亿的对象,那他们都是怎么检索的呢? 本文分享自华为云社区<对象存储只能按文件名搜索? 用 DWR + ElasticSearch 实现文件名.文件内容.图片 ...

  3. 带你深入理解Java的IO到底是个啥

    摘要:操作系统就是管家,电脑的设备就是资源,如果进程先要操作资源,必须要进行系统调用,有操作系统去处理,然后再返回给进程,这样的代理模式是不是很常见?因此app 就是你写的程序,资源就是硬盘或者其他的 ...

  4. 解读顶会CIKM'21 Historical Inertia论文

    摘要:本文(Historical Inertia: An Ignored but Powerful Baseline for Long Sequence Time-series Forecasting ...

  5. 万字长文|Hadoop入门笔记(附资料)

    大数据迅速发展,但是Hadoop的基础地位一直没有改变.理解并掌握Hadoop相关知识对于之后的相关组件学习有着地基的作用.本文整理了Hadoop基础理论知识与常用组件介绍,虽然有一些组件已经不太常用 ...

  6. 基于C++11特性的线程池

    写在前面:本文学习自基于C++11实现线程池,代码部分均属于该博主,自己只是想记录以下自己的认知,并以这种方式加深一下自己对于多线程的理解 1 前置知识 RAII管理机制 简单来说RAII机制是一种对 ...

  7. DNS--主从

    操作系统:centos7.8 DNS-master:192.168.198.128 DNS-slave:192.168.198.129 一 主从同步过程 master修改完成重启后 将传送notify ...

  8. 微软商店上架Windows&Office破解工具,并获5星好评?

    大家好,我是DD! 最近真的除了俄乌冲突之外,其他消息似乎都被淹没了,连狗血的娱乐圈都哑火了. 但昨天在微信群(点击加入)里的这张图引起了我的注意... 据群友称Windows应用商店上架了一个破解W ...

  9. SpringBoot 项目实战 | 瑞吉外卖 Day04

    该系列将记录一份完整的实战项目的完成过程,该篇属于第四天 案例来自B站黑马程序员Java项目实战<瑞吉外卖>,请结合课程资料阅读以下内容 该篇我们将完成以下内容: 文件上传下载 新增菜品 ...

  10. 深入浅出开源监控系统Prometheus(上)

    本文首发于 vivo互联网技术 微信公众号 链接: https://mp.weixin.qq.com/s/4NC4spF6cEvXuIBKVbIU7A作者:ZhangShuo Prometheus是继 ...