有两个程序要操作硬盘,一个读,一个写。
两个程序不同时运行时,都能达到硬盘的性能上限。180M/s。
但当两个程序同时跑起来时,读取速度却大幅下降速度大概只有60M左右。写的速度受影响要小很多平均能到120-160M/s吧。在两个同时抢占硬盘时,有哪些方法去做平衡读写速度的差异?提高读取的速度。
从硬盘的角度来说,读写访问应该是互斥的,所以是单进程/线程的。
CPU内部有task scheduler调度读写程序,微观上如果两者的优先级相同,且发生频率相同,有可能是写的速度是读的一半左右,所以按照 写-读-写-读 round-robin的时间轮转算法来安排读写程序在CPU中的执行顺序的话,最后写能占有 2/3的CPU/硬盘时间,所以带宽降为2/3左右。
试试看读写程序进行 IPC 进程间通信,通过同步互斥的方式协调两者的执行?
具体还是要看应用场景,读写的数据有没有相关性,发生的频率和profile。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。