銝 擐隞蝝寧′蝣 I/O Scheduler' |8 S% h3 g$ g+ _$ J* y( y
' o/ _) n8 V7 W9 T' v
4 h1 F; y' c0 J7 |* W8 x5 x' P
I/O Scheduler臭暻潘Wiki隤芣:0 G/ B7 m) F3 N
Input / Output Scheduling or I/O Scheduling is a term used to describe the method computer operating systems decide the order that block I/O operations will be submitted to storage volumes. I/O Scheduling is sometimes called 'disk scheduling'.
& B( e' b1 T/ J1 N/ u J0 Z- f& y1 |5 w6 z8 r$ P9 @
6 ]8 |* q: N" w, v* }, Y$ f6 d
蝪∪桃隤迎撠望航臭誑蝬曹閮剖嚗靘啗矽渡蝣摮(I/O)璅∪銝蝔株身摰撌亙瑯% r4 D% _# s% a( ]8 B8 ~' L
- i# ?5 i" P( T. p9 D
9 k9 }' c" r- T( w( l( E. Y N: N0 S
桀Linux舀游蝔埋/O Schedule璅∪嚗亦:
5 h6 B' @$ d: [) A, r
4 Z9 z/ m6 A1 K4 N2 J# D) ]/ [9 H' E4 P" r
Noop Scheduler (蝪∠迂noop) -- RIAD SSD 撱箄降雿輻 noop
2 z! Q" I. L2 q9 g9 f3 B臭誑蝞舀箸砌蝪∪Scheduler嚗銝餉冽潔鈭頛箇孵亦頠擃蝖祇剝雿啣銝哨銝鈭頠/蝖祇撌脩瑕芸楛I/O摮璈塚銝撠潛頂蝯望詨閬瘙頛撠嚗璅Scheduler瘥頛拙典典亙啣蝟餌絞銝准
3 D. J/ T" ~& G0 E
5 `; J) P% A: C* F0 W; T: B4 p4 l" d) d0 t) B
Completely Fair Queuing (蝪∠迂cfq)
& d: s8 g6 Y& z" \/ C# S憿批蝢抬撠蝖祉蝟餌絞冽閬I/O隞餃嚗蝯衣詨雿摨(Queuing)嚗璅Scheduler拙冽潔砌蝙刻獢銝餉衣雿啣嚗芸2006撟12Linux Kernel 2.6.18銝渲喃伐CFQ Scheduler銝湔烊inux詨閮剔 I/O scheduler) V- ^3 O2 X) {4 s: W( T
% b e* { s9 `; |9 S! h
- u5 t8 Q& f- L+ HAnticipatory Scheduling (蝪∠迂anticipatory)
7 b r# ~6 y. u( r9 J/ Q3 k+ h曄銝摨行烊inux 2.6 Kernel 閮 I/O Scheduler 嚗婢nticipatory (/) 摮閫靘嚗憒蝚砌I/O箇橘銝亦蝟餌絞蝚砌I/O隢瘙雿嚗Anticipatory Scheduling撠Y銝閮剝閬6瘥怎"皜"()嚗皜穿臬函皜祉洵鈭I/O隢瘙航隞暻潛函嚗璅皜祇單芋撘函撣豢折脰冽摮蝟餌絞扳頛憭抒撱園莎撠文嗆臬鞈摨恍璅蝟餌絞啣嚗雿銋嚗Anticipatory Scheduling撠澆蝬脤隡箸券璅蝟餌絞銵函曄貊嗅末2 R+ g) h5 |9 m4 e' y+ Y; q
: r2 \0 X' d0 l" u3 W4 u
+ r" V( v" `2 s: p9 w6 ?Deadline Scheduler (蝪∠迂deadline) -- SATA 撱箄降雿輻 deadline& B9 `& @1 `7 M8 T3 H1 A% x
銝餉Scheduler撠望舫撠Anticipatory Scheduling蝻粹靘脰孵嚗摰撠蝤蝣銝剔撣賊剖啣銝函撘嚗閮銝西ˊ雿蝚血撠撱園脫雿摨嚗璅蝯撠潸摨怎頂蝯梯賣靘游摮! O, ?( H# t3 c; J8 ?
$ y" R$ s0 k! H& K& L6 j7 x% X0 `. ~8 [2 Y0 _
銝爹ed Hat Enterprise Linux 4 (2.6 Kernel) 剝Oracle10G鞈摨怨蝔埋/O Scheduler皜祈岫蝯 (鞈靘皞撅昱edhat砍豢)
9 E& U# C, q# t
4 Y o7 z5 Y1 j. e: Z
/ n8 o( u! i. s3 P1 b/ E蝪∪桃閫鈭I/O Scheduler璅∪撌桃啣嚗臭誑撠銝脣閮剖靘剝銝I/O Scheduler脰賭隤踵∴擐曉啁恣I/O Scheduler蝟餌絞瑼獢嚗瑼獢舐牢at孵靘霈:
* d2 A+ d# U/ S/ D" f( t* W' Y5 B$ A
% ^9 [1 x: n4 E, l- o#cat /sys/block/sda/queue/scheduler
2 I: a0 R1 R' y" p2 }[noop] anticipatory deadline cfq
- J2 c0 o! \$ }$ [* f* Y
/ a6 y3 D1 x/ o" y' l& j5 S* ?( z/ v1 ^0 c. N
敺銝靘嚗臭誑仿桀I/O Scheduler璅∪摸oop. (獢 [ ] )( [( o2 o0 T( q1 m ]. k% r
" x# g. z' Y2 Q" |! x
7 A& |3 M3 l Z( h+ i6 }. h仿閬脰靽格寡矽湛雿瘜拍車:
) M5 ^) |# Y" i+ x+ U/ l" A% V0 g- O8 K9 w
, e, f. g" P+ Y+ s/ s% s* |
1. 格活隤踵湛唾矽游喟嚗蝬庸cho隞支湔遐/O Scheduler璅∪) M. j, s2 x# Y4 B. Q
* [ b' N2 D+ \
: {* [+ L: l- \7 r- b
#echo Deadline>/sys/block/sda/queue/scheduler4 d( Z7 |9 [6 K6 N
, Z! ]9 I6 p1 C0 k
/ k4 U* T4 \' d$ B6 Z/ o7 L0 s銝靘箏桀sda憿蝖祉I/O Scheduler湔寧慣eadline璅∪嚗孵典喟嚗雿圈璈敺啁頂蝯望詨暺隤I/O Scheduler璅∪
2 w& z0 m& l' d9 z+ H% |6 X" U# N Q+ L3 F
, }+ U& F# N3 m) L4 U' I
2. 刻蝟餌絞璈脰隤踵渡:
; {, w# B8 X3 i" Q' g9 x隞乩215 s0 Z, s$ U |+ A* t1 ?0 L
/etc/rc.local 批乩銵: echo anticipatory > /sys/block/sdb/queue/scheduler 函頂蝯梁GRUB璈瑼獢銝哨敺銝銵銝elevator=deadline嚗喳舀潭甈⊿璈敺賭Deadline Scheduler雿璅∪嚗憒銝靘:2 y# a8 X2 }4 {6 ?: b9 D
- ^3 Z( n9 t6 _2 t! T2 g
6 `) l2 L3 ^6 t1 V' S) z蝺刻摩 /boot/grub/grub.conf7 F/ W8 M5 t' }
: m4 u8 u5 s5 n5 x+ [! c
3 N- ?5 F+ ]$ ^ W2 Ttitle Fedora Core (2.6.9-5.0.3.EL_lustre.1.4.2custom)
& U$ W4 j: E+ A" m, ]3 Oroot (hd0,0)
+ e0 P) P( |+ _6 w) Akernel /vmlinuz-2.6.9-5.0.3.EL_lustre.1.4.2custom ro% `' D f) p0 Q9 D
root=/dev/VolGroup00/LogVol00 rhgb noapic quiet elevator=deadline
5 }" j+ D3 K9 @) [
7 U8 x5 ]! q! t2 {: \$ F/ O
: ~9 Y# d# z9 H2 C3 k5 \1 ?# u9 ^$ d1 g! A
8 m3 D6 h Z" a8 [: e0 l n
鈭 乩靘舐′蝣 Readahead 敹怠1 b& w0 b% n( I6 O, g
+ g* n3 n5 D+ Q; G% W
2 l4 _; ?$ a! Z1 b其遢撠望頛摰寞閫嚗蝬梁頂蝯梁蝣霈閮剖靘霈踝蝬梯矽嵇eadahead Sectors憭批靘憓脩頂蝯梁蝣霈賢榆堆撠望航矽∠銝餉桃
3 r6 \/ d0 n/ m5 w5 v6 |
, ^4 m( ^" C8 y u4 h& ~( f7 ?" O1 g" l3 s9 V
蝬尉inux蝟餌絞隞: blockdev 靘瑼Z桀sda蝖祉Readahead Sectors憭批嚗蝭靘憒銝
, D7 ~6 h \& S) E/ d' T% W+ D) P" a' K# Q T/ E Y6 v' I
- k$ p! M H/ `# ^. r! j( d' {#blockdev --getra /dev/sda (蝟餌絞閮剜256M)! D+ N5 @$ ` @" Q! M. |2 t1 A
512
2 b& d# W7 q: _1 {4 C
% C! j/ [4 Z0 U& J; W0 A2 Q% u0 B3 F. t5 ]6 Z
蝬梯矽游訾蒂撣嗅兄ectors憭批嚗靘脰質矽湛蝭靘憒銝:5 U0 ^* b' P" o5 d3 B( }& Z2 S
; ^7 H+ _! X7 h8 y
9 q- v/ u( J; D, b' R4 @#blockdev --setra 4096 /dev/sda
2 ^4 m' s( o6 h P* I! T) |( u
0 z- }: S; ] B% U4 W* V! G
, r% S0 @7 _/ R# T7 C# M#blockdev --getra /dev/sda
! T- `, p* g9 C R9 M! ^9 Y5 a3 `# e9 Z4096
, l/ H9 N2 F* G& D1 Q9 v+ }* q& ]
刻蝟餌絞璈芸閮剖:
& a. P$ n6 @+ X) C/ e) O! ? /etc/rc.local 批乩銵:
2 z2 N4 z% @% dblockdev --setra 4096 /dev/sda) Q/ B8 Q6 F% J4 ]9 ^
/ ?' Q0 k/ u6 q5 g4 N- @: G
蝬拍車蝖祉質矽∠撠寞嚗舀賢典祈賢停瘥頛撌桃蝖祇啣銋銝嚗憭憯璁典箔鈭霈賬
; b. B# |$ `' F! L! r$ a) c撖虫:隞亙鈕erver敺憭撌乩,靘憒 ffmpeg, php(move_uploaded_file)銝喳之瑼獢 ,tar , mv 憭抒瑼獢,雿撟曆∩,摰典銝鈭,蝬銝餈啁隤踵,憿摰刻圾瘙
& L1 x5 i$ y; R/ b; b( \. \% ]3 x' [6 _* m: p* s
血,sysctl.conf隤踵銋舀撟怠拍
7 J6 [# ]. b: }$ o5 W
@/ k1 T, R4 O# k# `9 y) x7 @3 B6 x) ?' S5 `' u
靘皞:3 Q b, q+ Q5 r4 `. t! _
% J R1 ^( H; h7 z7 [http://itstorage.storageforum.tw ... eadahead-cache.html* n, L- f4 ` D* i( s
|
|