1. Trang chủ
  2. » Giáo án - Bài giảng

hệ điều hành thoại nam ch05 dinh thoi cpu sinhvienzone com

14 41 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 14
Dung lượng 296,55 KB

Nội dung

Chương Đònh thời CPU -6.1- Nội dung ‰ ‰ Khái niệm Các đònh thời – long-term, mid-term, short-term ‰ ‰ Các tiêu chuẩn đònh thời CPU Các giải thuật đònh thời – – – – – – – First-Come, First-Served (FCFS) Round-Robin (RR) Shortest Job First (SJF) Shortest Remaining Time First (SRTF) Highest Response Ratio Next (HRRN) Multilevel Queue Multilevel Feedback Queue Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com https://fb.com/sinhvienzonevn -6.2- Khái niệm ‰ Trong hệ thống multi-tasking – Thực thi nhiều chương trình đồng thời làm tăng hiệu suất hệ thống – Tại thời điểm, có process thực thi Do đó, cần phải giải vấn đề phân chia, lựa chọn process thực thi cho hiệu → chiến lược đònh thời CPU ‰ Đònh thời CPU – Chọn process (từ ready queue) thực thi – Với multithreaded kernel, việc đònh thời CPU OS chọn kernel thread chiếm CPU Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM -6.3- Các đònh thời new Long-Term scheduling suspended ready Long-Term scheduling M edium -Term scheduling ready Short-Term scheduling running suspended blocked M edium -Term scheduling blocked term inated Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com https://fb.com/sinhvienzonevn -6.4- Các hàng đợi đònh thời Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM -6.5- Các đònh thời ‰ Long-Term Scheduling – Xác đònh chương trình chấp nhận nạp vào hệ thống để thực thi – Điều khiển mức độ multiprogramming hệ thống – Long term scheduler thường cố gắng trì xen lẫn CPU-bound I/O-bound process ‰ Medium-Term Scheduling – Sự chuyển đổi dựa cần thiết để quản lý multiprogramming – Được thực phần quản lý nhớ thảo luận phần quản lý nhớ Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com https://fb.com/sinhvienzonevn -6.6- Short-Term Scheduling ‰ ‰ ‰ Xác đònh process ready queue chiếm CPU để thực thi (do gọi đònh thời CPUCPU scheduling) Short term scheduler gọi với tên khác dispatcher Bộ đònh thời short-term gọi có kiện/interrupt sau xảy ra: – – – – clock interrupt I/O interrupt operating system call, trap signal Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM -6.7- Các tiêu chuẩn đònh thời CPU ‰ User-oriented – Response Time: khoảng thời gian process nhận yêu cầu đến yêu cầu đáp ứng (time-sharing, interactive system) → cực tiểu – Turnaround Time: khoảng thời gian từ lúc process nạp vào hệ thống đến process kết thúc → cực tiểu – Waiting Time: tổng thời gian process đợi ready queue → cực tiểu ‰ System-oriented – processor utilization: đònh thời cho CPU bận tốt → cực đại – fairness: tất process phải đối xử – throughput: số process hoàn tất công việc đơn vò thời gian → cực đại Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com https://fb.com/sinhvienzonevn -6.8- Hai yếu tố giải thuật đònh thời ‰ Hàm chọn lựa (selection function): dùng để chọn process ready queue thực thi (thường dựa độ ưu tiên, yêu cầu tài nguyên, đặc điểm thực thi process, ), ví dụ – w = tổng thời gian đợi hệ thống – e = thời gian phục vụ – s = tổng thời gian thực thi process (bao gồm “e”) ‰ Chế độ đònh (decision mode): chọn thời điểm thực hàm chọn lựa để đònh thời Có hai chế độ – Nonpreemptive ƒ Khi trạng thái running, process thực thi kết thúc bò blocked yêu cầu I/O – Preemptive ƒ Process thực thi (trạng thái running) bò ngắt nửa chừng chuyển trạng thái Ready hệ điều hành ƒ Chi phí cao non-preemptive đánh đổi lại thời gian đáp ứng tốt trường hợp process độc chiếm CPU lâu Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM -6.9- Khảo sát giải thuật đònh thời load store add store read from file C PU burst w aitforI/O I/O burst inc store w rite to file w aitforI/O C PU burst I/O burst C PU burst w aitforI/O I/O burst Process Arrival Service Tim e Tim e 2 4 5 … load store add store read from file chu kyø CPU-I/O ‰ ‰ Service time = thời gian process cần CPU chu kỳ CPU-I/O Process có service time lớn CPU-bound process Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com -6.10- https://fb.com/sinhvienzonevn First-Come First-Served (FCFS) ‰ ‰ ‰ Hàng đợi Ready hàng đợi kiểu FIFO Selection function: process đợi lâu ready queue chọn thực thi Decision mode: non-preemptive – Process thực thi đến kết thúc bò blocked I/O 15 10 20 P1 P2 P3 P4 P5 ‰Process thực I/O độc chiếm CPU ‰Các process I/O-bound (ít CPU-burst) không ưu tiên process CPU-bound (nhiều CPU-burst) Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM -6.11- Shortest Job First (SJF) ‰ ‰ ‰ ‰ Selection function: process có độ dài CPU burst nhỏ chọn thực thi Decision mode: non-preemptive I/O-bound process ưu tiên so với CPUbound process Yêu cầu: phải ước tính CPU-burst process 10 15 20 P1 P2 P3 P4 P5 Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com -6.12- https://fb.com/sinhvienzonevn Ước tính độ dài CPU Burst ‰ Độ dài CPU Burst ước tính xấp xỉ dùng phép tính trung bình hàm mũ (exponential average) dựa độ dài CPU-burst trước tn = độ dài thực CPU burst thứ n τn+1: giá trò ước đoán CPU burst (n + 1) α, ≤ α ≤ Độ dài ước tính CPU burst thứ n+1 laø: τ n + = α tn + (1 − α )τ n Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM -6.13- Ước tính độ dài CPU Burst (t.t) ‰ Khai triển công thức: τ n +1 = α tn + (1 − α )τ n = α tn + (1 − α )α tn−1 + (1 − α ) ατ n −1 n −1 = α ∑ (1 − α )itn− i + (1 -α )nτ i= ‰ Giá trò τ1 không ước tính mà thường gán = α=0 ⇒τn+1 = τn ⇒ không quan tâm đến “quá khứ” ‰ α=1 ⇒τn+1 = tn ⇒ quan tâm đến “ngày hôm qua” ‰ α=1/2 ‰ Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com -6.14- https://fb.com/sinhvienzonevn Ví dụ ước tính độ dài CPU Burst Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM -6.15- Nhận xét giải thuật SJF ‰ ‰ ‰ ‰ Có thể xảy tình trạng “chết đói” (starvation) process có CPU-burst lớn có nhiều process với CPU-burst nhỏ đến hệ thống Cơ chế non-preemptive không phù hợp cho hệ thống time sharing (interractive) Giải thuật SJF ngầm đònh độ ưu tiên theo burst time Các CPU-bound process có độ ưu tiên thấp so với I/O-bound process, process không thực I/O thực thi độc chiếm CPU kết thúc Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com -6.16- https://fb.com/sinhvienzonevn Shortest Remaining Time First ‰ ‰ Tương tự SJF decision mode preemptive Yêu cầu: phải ước tính CPU-burst cuûa process 10 15 20 P1 P2 P3 P4 P5 Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM -6.17- Round Robin (RR) ‰ ‰ ‰ Mỗi process nhận đơn vò nhỏ thời gian CPU (time slice, quantum time), thông thường từ 10-100 msec để thực thi Sau khoảng thời gian đó, process bò đoạt quyền trở cuối hàng đợi ready Nếu có n process hàng đợi ready quantum time = q process phải chờ đợi (n-1)*q đơn vò thời gian Hiệu suất – Nếu q lớn: RR ⇒ FCFS – Nếu q nhỏ (q không nhỏ phải tốn chi phí chuyển ngữ cảnh) ‰ Thời gian chờ đợi trung bình giải thuật RR thường lớn thời gian đáp ứng nhỏ Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com -6.18- https://fb.com/sinhvienzonevn RR với Time Quantum = ¾ Thời gian turn-around trung bình cao so với SJF có thời gian đáp ứng trung bình tốt ¾ Ưu tiên CPU-bound process I/O-bound process thường sử dụng thời gian CPU, sau phải blocked đợi I/O CPU-bound process tận dụng hết quantum time, sau quay ready queue ⇒ xếp trước process bò blocked Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM -6.19- Time Quantum vaø Context Switch Process tim e = 10 C ontext Sw itch 12 1 10 10 0 Q uantum 10 6 10 Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com -6.20- https://fb.com/sinhvienzonevn 10 Quantum vaø response time ‰ ‰ Quantum time phải lớn thời gian dùng để xử lý clock interrupt (timer) thời gian dispatching Nên lớn thời gian tương tác trung bình (typical interaction) Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM -6.21- Highest Response Ratio Next 10 15 20 P1 P2 P3 P4 P5 RR = ‰ ‰ tim espentw aiting + expected servicetim e expected servicetim e Chọn process có giá trò RR (Response Ratio) lớn Các process ngắn ưu tiên (vì service time nhỏ) Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com -6.22- https://fb.com/sinhvienzonevn 11 Multilevel Queue Scheduling ‰ Hàng đợi Ready chia thành nhiều hàng đợi riêng biệt theo số tiêu chuẩn – Đặc điểm yêu cầu đònh thời process – Foreground (interactive) vaø background process ‰ ‰ Process gán cố đònh vào hàng đợi, hàng đợi sử dụng giải thuật đònh thời riêng Hệ điều hành cần phải đònh thời cho hàng đợi – Fixed priority scheduling: phục vụ từ hàng đợi có độ ưu tiên cao đến thâp Vấn đề: có starvation – Time slice : hàng đợi nhận khoảng thời gian chiếm CPU phân phối cho process hàng đợi khoảng thời gian Ví dụ: 80% cho hàng đợi foreground đònh thời RR 20% cho hàng đợi background đònh thời giải thuật FCFS Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM -6.23- Multilevel Queue Scheduling Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com -6.24- https://fb.com/sinhvienzonevn 12 Multilevel Feedback Queue ‰ Vấn đề multilevel queue – process chuyển từ hàng đợi sang hàng đợi khác ⇒ khắc phục chế feedback: cho phép process di chuyển cách thích hợp hàng đợi khác ‰ Multilevel Feedback Queue – Phân loại processes dựa đặc tính CPU-burst – Sử dụng decision mode preemptive – Sau khoảng thời gian đó, I/O-bound process interactive process hàng đợi có độ ưu tiên cao CPU-bound process queue có độ ưu tiên thấp – Một process chờ lâu hàng đợi có độ ưu tiên thấp chuyển đến hàng đợi có độ ưu tiên cao (cơ chế niên hạn - aging) Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM -6.25- Multilevel Feedback Queue (t.t) Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com -6.26- https://fb.com/sinhvienzonevn 13 Multilevel Feedback Queue (t.t) ‰ Đònh thời Multilevel-feedback-queue đòi hỏi phải giải vấn đề sau – Số lượng hàng đợi thích hợp? – Dùng giải thuật đònh thời hàng đợi? – Làm để xác đònh thời điểm cần chuyển process đến hàng đợi cao thấp hơn? – Khi process yêu cầu xử lý đưa vào hàng đợi hợp lý nhất? Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM -6.27- So sánh giải thuật ‰ ‰ Giải thuật đònh thời tốt ? Câu trả lời phụ thuộc yếu tố sau: – System workload – Sự hỗ trợ phần cứng dispatcher – Sự tương quan trọng số tiêu chuẩn đònh thời response time, hiệu suất CPU, throughput, – Phương pháp đònh lượng so sánh Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone.com -6.28- https://fb.com/sinhvienzonevn 14 ... chu kỳ CPU- I/O ‰ ‰ Service time = thời gian process cần CPU chu kỳ CPU- I/O Process có service time lớn CPU- bound process Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone. com -6.10-... Tp.HCM SinhVienZone. com -6.12- https://fb .com/ sinhvienzonevn Ước tính độ dài CPU Burst ‰ Độ dài CPU Burst ước tính xấp xỉ dùng phép tính trung bình hàm mũ (exponential average) dựa độ dài CPU- burst... qua” ‰ α=1/2 ‰ Khoa Công Nghệ Thông Tin – Đại Học Bách Khoa Tp.HCM SinhVienZone. com -6.14- https://fb .com/ sinhvienzonevn Ví dụ ước tính độ dài CPU Burst Khoa Công Nghệ Thông Tin – Đại Học Bách

Ngày đăng: 28/01/2020, 22:34