RDS(网易云关系数据库服务)上线已经有一段时间,陆续不断有产品迁入到了RDS中,在线上运维的过程中,也遇到了一些曾经没有考虑到,或者考虑的不全的东西。后续有时间可以分享给大家。
今天想提到的是线上一个4G的RDS实例,发生了OOM(out of memory)的问题,MySQL进程被直接Kill掉了。在解释这个问题的时候,我们首先需要从Linux系统内存分配策略讲起。
一般写C语言程序,我们习惯使用malloc动态的申请内存空间(Java由JVM负责内存管理),malloc函数会向操作
1,new 关键字和 malloc 函数区别(自己、功能、应用):
1,new 关键字是 C++ 的一部分:
1,如果是 C++ 编译器,则肯定可以用 new 申请堆空间内存;
2,malloc 是由 C 库提供的函数:
1,如果没有相应的库,malloc 将不能使用;
2,有些特殊的嵌入式开发中,少了 C 库,则就不能动态内存分配;
3,new 以具体类型为单位进行内存分配;
1,面向对象中一般用 new,不用 m