我正在使用 Ubuntu 14.04LTS 服务器 (AWS EC2) 进行自定义数据库转储,但我得到了一个非常奇怪的内存行为。
我正在使用 PHP CLI 脚本循环输出到编号文件的自定义转储查询,然后cat
将该文件输入到输出文件中。由于mysql,内存使用量按预期攀升。mysql 转储文件和输出文件都被写入单独的挂载驱动器 (EBS)。
在启动脚本之前,内存使用量约为 20%。一旦该过程完成,内存使用率约为 90%,基于htop
. 我已经用free -m
. mysql 重新启动会将内存使用量降低到大约 50%。
我曾经lsof
验证过没有任何东西在使用该文件。我什至已经完成lsof
了目录,只得到了我的 bash 进程和 lsof。
真正奇怪的部分是,一旦我删除文件,内存使用量就会下降到 20%。
我尝试在不重新启动 mysql 的情况下删除文件,并且使用率下降了上述数字预期的 30%。
使用此处找到的内存查看器脚本不会显示相同的内存使用情况,因此我认为它并不完全准确。它通过保留文件显示没有内存消耗。
有没有其他方法可以告诉我是什么保存了内存?
您实际查看的是系统的磁盘缓存使用情况。所有现代系统都会缓存磁盘操作,以更快地重复访问同一磁盘区域。
这个缓存过程被认为花费很少的资源,因为它可能会在以后产生频繁的好处。由于系统知道缓存与任何其他内存需求相比并不重要,因此它会在需要时立即转储部分缓存以用于其他用途。
您还注意到 MySQL 服务器进程的内部缓存,其作用类似于操作系统的缓存,但操作系统不会将其识别为缓存,这就是它仅根据服务器进程本身的操作释放的原因,例如重新启动它。