用Tornado能异步操作文件系统IO么?

2012-09-26 15:44:18 +08:00
 zhangxiao
我想用tornado处理本地磁盘的git repo,但是不知道怎么异步完成文件系统的读写,主要是读。
4026 次点击
所在节点    问与答
4 条回复
clowwindy
2012-09-26 16:01:31 +08:00
推荐读一下 http://www.remlab.net/op/nonblock.shtml

Regular files are always readable and they are also always writeable. This is clearly stated in the relevant POSIX specifications. I cannot stress this enough. Putting a regular file in non-blocking has ABSOLUTELY no effects other than changing one bit in the file flags.
zhangxiao
2012-09-26 19:10:19 +08:00
@clowwindy 我刚刚读了一下,但是还有疑问,想确认一下我的理解:
按照文章作者的意思,磁盘读写也是会出现忙碌的,也会造成用户能感觉到的延时甚至卡死。但是使用non-blocking也不会有任何帮助。
只有尝试建立一个单独的线程去处理这个文件的读写,才能避免主线程被阻塞。

如果上述理解是对的,那么nodejs里的对文件的异步IO又是怎么实现的?
phuslu
2012-09-26 20:42:00 +08:00
torndao不能,gevent差强人意(gevent 1.0引入的fileobject)
nodejs不错(libeio)

值得关注的还有libaio
clowwindy
2012-09-26 21:32:48 +08:00
@zhangxiao 线程或者 aio。磁盘读写不像网络连接,不需要并行化,每个磁盘一个线程,控制队列长度就可以了。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/48765

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX