๋ณธ๋ฌธ ๋ฐ”๋กœ๊ฐ€๊ธฐ

๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ199

[์šด์˜์ฒด์ œ] 5. CPU Scheduling ํ”„๋กœ์„ธ์Šค์˜ ํŠน์„ฑ ๋ถ„๋ฅ˜ CPU-bound process CPU๋ฅผ ์ฃผ๋กœ ์‚ฌ์šฉํ•˜๋Š” ํ”„๋กœ์„ธ์Šค(high CPU) ๊ณ„์‚ฐ ์œ„์ฃผ์˜ job few very long CPU burst(CPU-intensive) I/O-bound process CPU๋ฅผ ์žก๊ณ  ๊ณ„์‚ฐํ•˜๋Š” ์‹œ๊ฐ„๋ณด๋‹ค I/O์— ๋งŽ์€ ์‹œ๊ฐ„์ด ํ•„์š”ํ•œ process(low CPU) interactive program many short CPU bursts(์ค‘๊ฐ„์— I/O๊ฐ€ ๋ผ์–ด๋“ฆ) CPU-burst Time์˜ ๋ถ„ํฌ ์—ฌ๋Ÿฌ ์ข…๋ฅ˜์˜ job/process์ด ์„ž์—ฌ์žˆ๊ธฐ ๋•Œ๋ฌธ์— CPU ์Šค์ผ€์ค„๋ง์ด ํ•„์š”ํ•˜๋‹ค interactive job(I/O bound job)์—๊ฒŒ ์ ์ ˆํ•œ response๋ฅผ ์šฐ์„ ์ ์œผ๋กœ ์ œ๊ณต CPU์™€ I/O ์žฅ์น˜ ๋“ฑ ์‹œ์Šคํ…œ ์ž์›์„ ๊ณจ๊ณ ๋ฃจ ํšจ์œจ์ ์œผ๋กœ ์‚ฌ์šฉ CPU Schedul.. 2022. 11. 27.
[์šด์˜์ฒด์ œ] 4. Process Management ํ”„๋กœ์„ธ์Šค ์ƒ์„ฑ Process Creation ๋ถ€๋ชจ ํ”„๋กœ์„ธ์Šค๊ฐ€ ์ž์‹ ํ”„๋กœ์„ธ์Šค ์ƒ์„ฑ ๋ณต์ œ ์ƒ์„ฑ : process context - code, data, stack / CPU context - PCB์„ ๋ชจ๋‘ ๋ณต์‚ฌ ํ”„๋กœ์„ธ์Šค์˜ ํŠธ๋ฆฌ(๊ณ„์ธต ๊ตฌ์กฐ) ํ˜•์„ฑ ํ”„๋กœ์„ธ์Šค๋Š” ์ž์›์„ ํ•„์š”๋กœ ํ•จ : ์šด์˜์ฒด์ œ๋กœ๋ถ€ํ„ฐ ๋ฐ›๊ฑฐ๋‚˜ ๋ถ€๋ชจ์™€ ๊ณต์œ  ์ž์›์˜ ๊ณต์œ  ๋ถ€๋ชจ์™€ ์ž์‹์ด ๋ชจ๋“  ์ž์›์„ ๊ณต์œ ํ•˜๋Š” ๋ชจ๋ธ : Copy-on-write(COW) copy ์ž์ฒด๋Š” ๋น„ํšจ์œจ์ ์ด๊ณ  ๋ฉ”๋ชจ๋ฆฌ๋ฅผ ๋‚ญ๋น„ํ•˜๋Š” ํ–‰์œ„ ๋ฆฌ๋ˆ…์Šค ๋“ฑ ํšจ์œจ์ ์ธ OS์—์„œ๋Š” ๊ณต์œ ํ•  ์ˆ˜ ์žˆ๋Š” ๊ฒƒ์€ ๊ณต์œ ํ•˜๊ณ  ๋‹ฌ๋ผ์ง€๋Š” ๊ฒƒ๋งŒ ์ผ๋ถ€ copy(write) ์ผ๋ถ€๋ฅผ ๊ณต์œ ํ•˜๋Š” ๋ชจ๋ธ ์ „ํ˜€ ๊ณต์œ ํ•˜์ง€ ์•Š๋Š” ๋ชจ๋ธ(์ผ๋ฐ˜์  : ๋ณ„๊ฐœ์˜ ํ”„๋กœ์„ธ์Šค์ด๊ธฐ ๋•Œ๋ฌธ์— ๋ถ€๋ชจ-์ž์‹ ๊ฒฝ์Ÿ) ์ˆ˜ํ–‰ Execution ๋ถ€๋ชจ์™€ ์ž์‹์ด ๊ณต์กดํ•˜๋ฉฐ ์ˆ˜ํ–‰๋˜๋Š” ๋ชจ.. 2022. 11. 27.
[์šด์˜์ฒด์ œ] 3. Process ํ”„๋กœ์„ธ์Šค์˜ ๊ฐœ๋… a program in execution ํ”„๋กœ์„ธ์Šค์˜ ๋ฌธ๋งฅ(context) ํŠน์ • ์‹œ์ ์—์„œ ํ•ด๋‹น ํ”„๋กœ์„ธ์Šค๊ฐ€ ์–ด๋””๊นŒ์ง€ ์‹คํ–‰์„ ํ–ˆ๋Š”์ง€ ๊ทœ๋ช…ํ•˜๋Š” ์š”์†Œ 1) CPU ์ˆ˜ํ–‰ ์ƒํƒœ๋ฅผ ๋‚˜ํƒ€๋‚ด๋Š” ํ•˜๋“œ์›จ์–ด ๋ฌธ๋งฅ : Program Counter, ๊ฐ์ข… register register๊ฐ€ ํ˜„์žฌ ์–ด๋–ค ๊ฐ’์„ ๊ฐ€์ง€๋Š”๊ฐ€ 2) ํ”„๋กœ์„ธ์Šค์˜ ์ฃผ์†Œ ๊ณต๊ฐ„ : code, data, stack code : ํ˜„์žฌ ์–ด๋””๊นŒ์ง€ ์ˆ˜ํ–‰ํ–ˆ๋Š”๊ฐ€ data : ํ˜„์žฌ ๋ณ€์ˆ˜์˜ ๊ฐ’์ด ๋ฌด์—‡์ธ๊ฐ€ stack : ๋ฌด์Šจ ๋‚ด์šฉ์„ ์–ด๋””๊นŒ์ง€ ์ €์žฅํ–ˆ๋Š”๊ฐ€ 3) ํ”„๋กœ์„ธ์Šค ๊ด€๋ จ ์ปค๋„ ์ž๋ฃŒ ๊ตฌ์กฐ : PCB(Process Control Block), Kernel stack process ์ƒ์„ฑ๋  ๋•Œ๋งˆ๋‹ค pcb๋ฅผ ๋‘์–ด ๊ด€๋ฆฌ kernel stack : system call ์‹œ kerne.. 2022. 11. 20.
[์šด์˜์ฒด์ œ] 2. System Structure & Program Execution 2 ๋™๊ธฐ์‹ ์ž…์ถœ๋ ฅ๊ณผ ๋น„๋™๊ธฐ์‹ ์ž…์ถœ๋ ฅ 1) ๋™๊ธฐ์‹ ์ž…์ถœ๋ ฅ synchronous I/O I/O ์š”์ฒญ ํ›„ ์ž…์ถœ๋ ฅ ์ž‘์—…์ด ์™„๋ฃŒ๋œ ํ›„์—์•ผ ์ œ์–ด๊ฐ€ ์‚ฌ์šฉ์ž ํ”„๋กœ๊ทธ๋žจ์— ๋„˜์–ด๊ฐ. ํ”„๋กœ์„ธ์Šค๊ฐ€ ์ž…์ถœ๋ ฅ์„ ์ˆ˜ํ–‰ํ•˜๋Š” ๋™์•ˆ ๊ธฐ๋‹ค๋ฆฌ๊ธฐ / ์ž…์ถœ๋ ฅ์ด ๋๋‚  ๋•Œ๊นŒ์ง€ ์•„๋ฌด๊ฒƒ๋„ ํ•˜์ง€ ์•Š๊ณ  ๊ธฐ๋‹ค๋ ค์•ผ ํ•จ ๊ตฌํ˜„ ๋ฐฉ๋ฒ•1 : ์ผ์„ ๋ชปํ•˜๋Š” ๋™์•ˆ CPU๋ฅผ ๊ฐ€์ง€๊ณ  ์žˆ I/O๊ฐ€ ๋๋‚  ๋•Œ๊นŒ์ง€ CPU๋ฅผ ๋‚ญ๋น„์‹œํ‚ด ๋งค์‹œ์  ํ•˜๋‚˜์˜ I/O๋งŒ ์ผ์–ด๋‚  ์ˆ˜ ์žˆ์Œ ๊ตฌํ˜„ ๋ฐฉ๋ฒ•2 : ์ผ์„ ๋ชปํ•˜๋Š” ๋™์•ˆ ๋‹ค๋ฅธ ํ”„๋กœ์„ธ์Šค์—๊ฒŒ CPU๋ฅผ ๋„˜๊ฒจ์คŒ I/O๊ฐ€ ์™„๋ฃŒ๋  ๋•Œ๊นŒ์ง€ ํ•ด๋‹น ํ”„๋กœ๊ทธ๋žจ์—๊ฒŒ์„œ CPU๋ฅผ ๋นผ์•—์Œ I/O ์ฒ˜๋ฆฌ๋ฅผ ๊ธฐ๋‹ค๋ฆฌ๋Š” ์ค„์— ๊ทธ ํ”„๋กœ๊ทธ๋žจ์„ ์ค„ ์„ธ์›€ ๋‹ค๋ฅธ ํ”„๋กœ๊ทธ๋žจ์— CPU๋ฅผ ์คŒ -> ํ˜„์žฌ ์ž‘์—… ๋๋‚˜๋ฉด interrupt ๊ฑธ์–ด์„œ CPU ๋‹ค์‹œ ๊ฐ€์ ธ์˜ด 2) ๋น„๋™๊ธฐ์‹ ์ž…์ถœ๋ ฅ asynchronous .. 2022. 11. 20.