파일 읽기 및 쓰기 우선순위 지정

파일 읽기 및 쓰기 우선순위 지정

안녕하세요. 질문이 있지만 답변을 찾을 수 없습니다. dd를 사용하여 /media/data에 마운트된 하드 드라이브를 테스트했습니다. 몇 가지 간단한 스크립트:

쓰다:

echo "3" > /proc/sys/vm/drop_caches 
for i in {1..10}; do 
  dd if=/dev/zero of=/media/data/test/testfile-$i bs=4096 count=1310720 conv=fdatasync 
done

result: 
my-home# bash test1
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 30,7945 s, 174 MB/s
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 30,8114 s, 174 MB/s
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 30,9237 s, 174 MB/s
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 30,9386 s, 174 MB/s
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 30,8568 s, 174 MB/s

iostat:
avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           2,17    0,00    4,22   21,23    0,00   72,38
Device:            tps    kB_read/s    kB_wrtn/s    kB_read    kB_wrtn
sda               0,00         0,00         0,00          0          0
sdb             172,00         0,00    176128,00          0     176128

읽다:

echo "3" > /proc/sys/vm/drop_caches 
for i in $(ls /media/data/iso); do 
  dd if=/media/data/iso/$i of=/dev/null bs=4096 
done 

result:
my-home# bash test1_read
632291328 bytes (632 MB, 603 MiB) copy, 3,46719 s, 182 MB/s
3994091520 bytes (4,0 GB, 3,7 GiB) copy, 21,4655 s, 186 MB/s
1317427200 bytes (1,3 GB, 1,2 GiB) copy, 7,03572 s, 187 MB/s
4696938496 bytes (4,7 GB, 4,4 GiB) copy, 25,0823 s, 187 MB/s
699400192 bytes (699 MB, 667 MiB) copy, 3,77014 s, 186 MB/s

iostat:
avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           1,13    0,00    2,89   10,30    0,00   85,68

Device:            tps    kB_read/s    kB_wrtn/s    kB_read    kB_wrtn
sda               0,00         0,00         0,00          0          0
sdb            1432,00    183296,00         0,00     183296          0

속도는 좋지만 다른 터미널에서 이 스크립트를 동시에 실행하면 문제가 발생합니다. 쓰기 스크립트는 더 빠르게 실행되고 모든 디스크 리소스를 사용합니다.

my-home# bash test1
Sep 29 7:57:57 UTC 2016
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 31,9903 s, 168 MB/s
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 32,0175 s, 168 MB/s
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 32,0138 s, 168 MB/s
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 31,9956 s, 168 MB/s
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 32,0198 s, 168 MB/s
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 32,136 s, 167 MB/s
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 31,9074 s, 168 MB/s
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 32,237 s, 167 MB/s
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 32,0998 s, 167 MB/s
5368709120 bytes (5,4 GB, 5,0 GiB) copy, 32,4163 s, 166 MB/s

my-home# bash test1_read 
Sep 29 7:57:57 UTC 2016
632291328 bytes (632 MB, 603 MiB) copy, 3,46899 s, 182 MB/s
3994091520 bytes (4,0 GB, 3,7 GiB) copy, 149,177 s, 26,8 MB/
4696938496 bytes (4,7 GB, 4,4 GiB) copy, 214,307 s, 21,9 MB/s
263127040 bytes (263 MB, 251 MiB) copy, 1,44909 s, 182 MB/s

iostat:
                    Device:            tps    MB_read/s    MB_wrtn/s    MB_read    MB_wrtn
29.09.2016 08:03:17 sdb             164,00         1,38       157,03          2        314
29.09.2016 08:03:19 sdb             172,00         1,50       161,52          3        323
29.09.2016 08:03:21 sdb             163,00         1,38       156,52          2        313
29.09.2016 08:03:23 sdb             169,50         0,88       166,00          1        332
29.09.2016 08:03:25 sdb             164,50         0,38       162,01          0        324
29.09.2016 08:03:27 sdb             161,50         1,38       154,52          2        309
29.09.2016 08:03:29 sdb             168,00         0,50       165,51          1        331
29.09.2016 08:03:31 sdb             160,50         0,75       156,02          1        312
29.09.2016 08:03:33 sdb             164,00         0,38       162,00          0        324
29.09.2016 08:03:35 sdb             164,50         0,25       162,01          0        324
29.09.2016 08:03:37 sdb             277,50         0,88       156,52          1        313
29.09.2016 08:03:39 sdb             318,00         0,25       161,00          0        322
29.09.2016 08:03:41 sdb             313,50         1,00       154,35          2        308
29.09.2016 08:03:43 sdb             758,00        80,31        88,19        160        176
29.09.2016 08:03:45 sdb            1398,00       174,63         0,00        349          0
29.09.2016 08:03:47 sdb            1429,00       178,62         0,00        357          0
29.09.2016 08:03:49 sdb            1429,50       178,69         0,00        357          0
29.09.2016 08:03:51 sdb            1427,00       178,31         0,00        356          0
29.09.2016 08:03:53 sdb            1430,50       178,81         0,00        357          0
29.09.2016 08:03:55 sdb            1431,00       178,88         0,00        357          0
29.09.2016 08:03:57 sdb            1431,00       178,88         0,00        357          0
29.09.2016 08:03:59 sdb            1431,00       178,88         0,00        357          0
29.09.2016 08:04:01 sdb            1423,00       177,81         0,00        355          0
29.09.2016 08:04:03 sdb            1431,50       178,94         0,00        357          0

왜 글쓰기가 읽기보다 우선인가? 내 스케줄러는 Linux Mint 18의 기본 스케줄러입니다.

my-home# cat /sys/block/sdb/queue/scheduler 
noop [deadline] cfq 

이 스케줄러의 경우 읽기가 쓰기보다 우선순위가 높지만 그렇지 않습니다.

관련 정보