免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123下一页
最近访问板块 发新帖
查看: 8084 | 回复: 23
打印 上一主题 下一主题

[内存管理] 请教pagecache的writeback问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-03-27 10:00 |只看该作者 |正序浏览
本帖最后由 leil 于 2013-03-27 10:16 编辑

如果一个page,正在被writeback,这时候上层应用正好又要写这个page。系统是如何保证互斥的?

上层应用写page的时候,是在page lock保护下进行。
但submit_bio()将page提交给下面后,已经不再会有page lock加/解锁操作了。
所以很纳闷。

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
24 [报告]
发表于 2013-08-08 18:46 |只看该作者
回复 23# embeddedlwp
在应用层解决,我们写操作缓冲到内存空间,另外一个独立的线程负载写,不影响主线程工作。

   

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
23 [报告]
发表于 2013-08-08 18:00 |只看该作者
回复 19# 瀚海书香

你们怎么解决了?


   

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
22 [报告]
发表于 2013-06-07 07:27 |只看该作者
回复 21# chishanmingshen


这已经各种权衡了


   

论坛徽章:
4
酉鸡
日期:2014-03-21 23:19:50狮子座
日期:2014-08-01 22:11:40酉鸡
日期:2015-01-10 21:31:442015年辞旧岁徽章
日期:2015-03-03 16:54:15
21 [报告]
发表于 2013-06-06 21:04 |只看该作者
回复 20# embeddedlwp


    我以为终极解决应该不堵塞第二个写访问吧

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
20 [报告]
发表于 2013-06-06 15:36 |只看该作者
本帖最后由 embeddedlwp 于 2013-06-06 15:38 编辑

回复 17# chishanmingshen


凡是backing device有请求的,加BDI_CAP_STABLE_WRITES标志,在写之前调用的clear_page_dirty_for_io,会设置page为protect的,这样这个page在写的过程中如果被访问会产生#PF,#PF的时候会
调用page_mkwrite,这个时候会调用wait_for_stable_page,如果backing device有请求也就是说相应的flag被设置,会block住等待writeback完成。

   

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
19 [报告]
发表于 2013-05-13 17:13 |只看该作者
回复 18# leil
由于工作关系,最近也一直在琢磨此事。
从技术上来说,确实会存在这个问题。但纯粹从技术上来考量意义不大。
那从实际业务上来考察,什么场景会出现这个问题?OLTP、OLAP、视频监控、媒资、FS,还是其他等等。


我们这边的**器就出现过这个问题。
   

论坛徽章:
0
18 [报告]
发表于 2013-05-13 17:02 |只看该作者
由于工作关系,最近也一直在琢磨此事。
从技术上来说,确实会存在这个问题。但纯粹从技术上来考量意义不大。
那从实际业务上来考察,什么场景会出现这个问题?OLTP、OLAP、视频监控、媒资、FS,还是其他等等。
恕我孤陋寡闻,那位大侠能够指教一下?

瀚海书香 发表于 2013-03-28 08:33
回复 2# blake326
正是由于这个问题,在大量写操作的时候,可能会出现一个write用时超过几十ms的情况。:m ...

论坛徽章:
4
酉鸡
日期:2014-03-21 23:19:50狮子座
日期:2014-08-01 22:11:40酉鸡
日期:2015-01-10 21:31:442015年辞旧岁徽章
日期:2015-03-03 16:54:15
17 [报告]
发表于 2013-04-27 15:52 |只看该作者
本帖最后由 chishanmingshen 于 2013-04-27 18:48 编辑

貌似仅仅是加了个标志控制,没有解决啊。

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
16 [报告]
发表于 2013-04-27 09:55 |只看该作者
回复 15# junnyg



后来有了新的解决方案

http://lwn.net/Articles/528031/

   
  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP