nginx+php-fpm整体上线k8s集群之后虚拟内存不断上涨原因排查_k8s容器内存突然飙升

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

背景

为了可以更好的管理我们的lnmp集群打算将原有的php环境整体打包成一个镜像然后上到k8s容器这样可以不仅使用到k8s的快速扩缩容和管理的好处而且让机器资源能更好被利用减少机器数量

问题

当我们将流量从原有的php机器集群切换到k8s集群时发现php容器的虚拟内存一直再涨然后达到一个阈值之后就会开始回落然后又继续上涨表现如下

 

 原因

一开始我们还以为内存泄露了不过内存泄露的话内存使用率只会一直往上涨这里有回落说明大概率不是内存泄露

而经验老到的运维说这很有可能是因为PHP程序写日志到所在pod上而根据linux系统的特性写文件不会立马落盘而是先写到本地缓存里等达到一定量级之后才会落盘这也就解释为什么虚拟内存会一直上涨然后又会回落最后就是这么反反复复

实验

在测试机写一个php接口这个接口的功能就是写大量的日志数据然后使用 ab来对这个接口进行压测结果如下

确实会涨这说明写日志确实会导致内存使用率的上涨

内存使用过程是如何的

既然知道这个问题的根源那接下来简单讲讲这个内存使用过程是怎么导致会出现这个情况

首先先要知道

WSS(Working Set Size和 RSS(Resident Set Size是内存管理中两个相关但不同的概念。

WSS指的是当前进程正在使用的内存包括其虚拟地址空间中已分配但未被使用的内存以及已经被使用的内存页。换句话说WSS是当前进程使用的活动内存。

而RSS则指的是当前进程使用的物理内存也就是占用了进程物理内存的内存页数。RSS是用来衡量进程实际使用的物理内存大小。

因此WSS通常比RSS要大。这是因为WSS包括了未使用但已分配的内存和已使用的内存而RSS只包括已经占用了物理内存的内存页。

另外WSS也会受到操作系统内存管理机制的影响如内存页面换入换出机制等。在这些机制的调度下可能会导致某些已使用但未活动的内存页被移出物理内存从而导致WSS的变化。

而linux自身会有个文件缓存主要作用是用来防止程序对文件的频繁操作从而导致对加大对磁盘的读写先将文件存入缓存等到合适时机再将文件写入到磁盘里

 衍生问题

从上面可以看出k8s的pod运行了linux系统而如果多个pod对同一个文件进行读写会不会导致这个文件数据不一致呢

这个问题k8s主要是使用Kubernetes Volume 的方案来保证数据的一致性多个pod挂载了同一个存储卷

从逻辑上pod本身的文件缓存是有可能导致文件的不一致不过这一点借助强大亚马逊云提供的EKS集群很好的解决了这个问题不过具体怎么解决确实难懂这里就不再进行赘述了 

 

 

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: nginxphpk8s