glibc 的 malloc per thread arenas 特性

本文准确性有待深究,只查阅过部分资料和进行过一些简单讨论,并未在代码层面进行过研究。如有纠错或补充,请在本文留言,感谢!

从 RHEL5 迁移到 RHEL6 的用户会有这样的发现:多线程程序在 RHEL6 中占用的*虚拟内存*,要比在 RHEL5 上的多。这种情况在 JAVA 程序中尤为突出,尽管 JAVA 应用是单线程的。
其中的一个原因,是 glibc 2.12 中的新特性 malloc per thread arenas 造成的。

Java 占用较多虚拟内存

通常,Java 应用会运行在 JVM 上。JVM 有自己的一套内存调用方式,一般不会使用到 glibc. 但某些对象还是会调用 malloc,从而使用使用到 per thread arenas 这个特性。

为何有 per thread arenas?

在过去的 malloc 实现中,每个程序会有一个 main arenas 供 malloc 申请使用。对于多线程的程序,每个线程调用 malloc 的时候,都需要事先检查是否有锁,确认没有锁后,才能拿到内存空间。这影响了程序的性能。

在现在的实现中,每一个线程都会有自己的 arenas,这就避免了线程之间的竞争,从而提高性能。

另外,我们可以看到 arenas 是一些大约为 64MB 的无权限匿名页(64位系统中)。
继续阅读“glibc 的 malloc per thread arenas 特性”

吉隆坡马六甲5日摆拍游

这5天基本是帮 Becky 摆拍。

在 KLIA2 的6小时闲逛

2015年3月,亚航搞了一次大促。我买了 北京->吉隆坡->澳门 的机票,含税约人民币810元。Becky 买了 澳门< =>吉隆坡 的机票,含税约人民币560元。
提前了将近9个月买的机票,于是我们在2015年12月各自出发了。
我比 Becky 早到6个小时,只好在机场闲逛。KLIA2 是亚航的大本营,一片红。机场连接这商场 gateway@KLIA2,吃喝购物基本都能满足,价格与市区相似,可以放心吃放心买。然而并没有电影院,逛6小时很煎熬。
商场的官网 -> http://gatewayklia2.com.my/

马六甲

从 KLIA2 到马六甲

在 KLIA2 GF 有前往马六甲的巴士,印象中是22MYR一位,座位宽敞好睡觉。通常巴士都是到 Melaka Sentral,距离市区有一定距离。也有少数仁爱医院的巴士,距离景点酒店相对近些。

在 Melaka Sental 吃了个饭。那杯饮料糖浓度极高。
马六甲
继续阅读“吉隆坡马六甲5日摆拍游”

Linux 中删除正在被进程占用的文件,磁盘空间不被释放。

在 Linux 系统中,通过 rm 命令删除一个文件,实际上是在相应的目录结构中 unlink 这个文件。如果这个文件仍然被打开着,这个文件仍然可以被这个进程所使用,并将继续占用磁盘空间。等这个程序关闭该文件后,对应文件的空间才会被释放。

=== TEST STEPS ===
继续阅读“Linux 中删除正在被进程占用的文件,磁盘空间不被释放。”