多线程能操作同一个同一个目录吗

2020-02-19 12:58:48 +08:00
 leosirius666a

比如多个线程 copy 文件到同一个目录里面。这样不会有什么问题吧。linux 系统

3024 次点击
所在节点    程序员
14 条回复
yicong135
2020-02-19 13:05:51 +08:00
又不能提高 IO 性能
leosirius666a
2020-02-19 13:11:14 +08:00
@yicong135 是因为 linux 系统会锁住目录吗?
rekulas
2020-02-19 13:16:18 +08:00
他说的是你线程开再多,也受限于 IO 写的上限速度,没有什么实际的意义
l4ever
2020-02-19 13:20:14 +08:00
当然可以,目录又不是文件, 不存在占用的问题.
leosirius666a
2020-02-19 13:26:42 +08:00
@l4ever linux 中不是一切都是文件吗,
szuwl
2020-02-19 13:45:48 +08:00
@rekulas 但是单线程并不能触及 IO 的上限
swulling
2020-02-19 13:47:57 +08:00
@szuwl 小文件场景下,或者随机写一般不能。顺序写可以达到上限
ujued
2020-02-19 13:49:17 +08:00
可以。比如下载多个文件到下载目录
ipwx
2020-02-19 14:04:07 +08:00
机械硬盘是你最后的瓶颈啊大哥。不是说你想并发写就能写得了,受限于硬件啊。
ipwx
2020-02-19 14:04:52 +08:00
在机械硬盘的情况下,顺序单线程写比多线程写快至少一个数量级,因为不需要寻道。SSD 会好很多,但是顺序单线程写还是最快的。
blu10ph
2020-02-19 15:09:58 +08:00
@leosirius666a 一切都是文件的意思是一切硬件设备都可以映射为一个文件,通过 io 控制设备,而不是真的是个文件,实际上很多东西也并没有映射为文件,比如 socket~
Lax
2020-02-19 15:17:02 +08:00
回复标题的问题:如果不是压测目录操作,比如批量创建空文件,不会有问题;即使压测估计你的场景也压测不出 bug。
说一说要操作的文件数量和文件大小,就知道是不是顺序读写了。另外硬盘的类型也有影响,机械硬盘的顺序读写操作速度快于随机读写,SSD 盘就不一样了
Mithril
2020-02-19 15:28:07 +08:00
没用的,多线程硬盘写入就只会更慢。
icylogic
2020-02-19 15:30:01 +08:00
…… 建议你读一下 everything is a file 的真正含义,这个 file 不是“文件”(一段存储在磁盘等介质上的数据),而是一种 common interface for I/O devices,其实可以理解成一种简单的多态

https://yarchive.net/comp/linux/everything_is_file.html

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

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

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

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

© 2021 V2EX