把交换分区设置到zram上,空间被占用后居然还能动态回收?原理是?

内核编译和嵌入式产品的设计与开发
回复
科学之子
帖子: 2284
注册时间: 2013-05-26 6:58
系统: Debian 9

把交换分区设置到zram上,空间被占用后居然还能动态回收?原理是?

#1

帖子 科学之子 » 2016-02-23 19:23

把交换分区设置到zram上,空间被占用后居然还能动态回收?原理是?
测试方法是这样的:
我用watch跟踪free 和zram的mem_used_total的变化
然后用C语言写了一个不停申请1024*1024字节的内存块,直到被内核杀死
发现不论是手动停止还是被内核杀死,zram的内存竟然可以回收?
free显示内存占用猛跌
zram的mem_used_total文件的数值也猛跌
但根据这个链接的说法貌似应该无法回收?
https://segmentfault.com/a/1190000000380500

zswap.txt也说zsmalloc无法回收
https://www.kernel.org/doc/Documentation/vm/zswap.txt

如果我没弄错的话,zram也是用zsmalloc来管理内存吧?
就算zsmalloc这个API支持类似标准库的free
zram作为一个定长块设备居然还能在空间被使用之后回收?

Wed Feb 24 02:21:31 CST 2016补充:
硬着头皮看了看内核代码:
zram_drv.c:

代码: 全选

.swap_slot_free_notify = zram_slot_free_notify
swapfile.c:

代码: 全选

disk->fops->swap_slot_free_notify(p->bdev,
								  offset);
貌似足以说明问题了,zram上设置swap不论是测试还是看代码,似乎都可以在swap空闲时释放zram占用的内存(水平有限,释放效率无法判断,仍然无法理解"回收更困难")
上次由 科学之子 在 2016-02-24 4:58,总共编辑 3 次。
头像
astolia
论坛版主
帖子: 6454
注册时间: 2008-09-18 13:11

Re: 把交换分区设置到zram上,空间被占用后居然还能动态回收?原理是?

#2

帖子 astolia » 2016-02-23 21:47

你中文理解需要加强
而 zram 比 zswap 压缩率更高,代价是 page reclaim 更困难
回收更困难 = 无法回收?

英文阅读理解更待提高。你的“zsmalloc无法回收”应该是来自于这句
zsmalloc does not implement compressed page eviction, so once zswap fills it
cannot evict the oldest page, it can only reject new pages.
你把eviction/evict理解成free那种了。可以往前翻几段,看看它具体是怎么个evict法

在上面的先入为主下,一件很简单的事你都忘了:zram设计出来的初衷不就为了1)省内存2)减少swap次数也就是磁盘IO从而提升性能。如果按你想的那样一旦被某个进程占用了,其他进程都别再想用了,那岂不是对内存的巨大浪费?剩下更少的普通内存岂不是会导致更频繁的swap?这和设计初衷完全相悖了
zram作为一个定长块设备居然还能在空间被使用之后回收?
块设备和能不能回收空间之间没关系。磁盘一样是块设备,如果哪天填满了,又没有其他存储设备可以移动文件(eviction),需要腾空间你怎么办?
回复