Bài giảng Hệ điều hành - Đỗ Tuấn Anh

Chương 0: Giới thiệu Hệ điều

hành

z 1. Giới thiệu về HĐH

z 1.1 Phần cứng và phần mềm

z Phần cứng:

ƒ Ngôn ngữ máy

ƒ Chương trình vi điều khiển – điều khiển trực tiếp các thiết bị

ƒ Thiết bị điện tử

z Phần mềm

ƒ Chương trình hệ thống: quản lý hoạt động của máy tính

ƒ Chương trình ứng dụng: giải quyết các bài toán của người

dùng

pdf216 trang | Chia sẻ: phuongt97 | Lượt xem: 442 | Lượt tải: 0download
Bạn đang xem trước 20 trang nội dung tài liệu Bài giảng Hệ điều hành - Đỗ Tuấn Anh, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
152 80386 - PENTUM z G = 0 - Chếđộmô đun, đơnvị tínhkíchthước khối–Byte € L = 220 = 1 MB. z G = 1 - Chếđộphân trang, đơnvị tính kích thướckhối–trang (4 KB) € L = 220 P = 220×212 = 232 = 4 GB. z D = 0 - Chếđộdữ liệu16 bit, z D = 1 - Chếđộdữ liệu32 bit. 153 80386 - PENTUM z Địachỉ tuyến tính: 48 bits. z Khả năng: z Vậtlý: AR – 32 bits 32 z Vph= 2 z = 4GB 13 1 32 z Lô gic: Vlg=2 ×2 ×2 z =246 z = 26×240 z = 64 TB 154 80386 - PENTUM z Chếđộkếthợpmôđun – phân trang: z Phân phốibộ nhớ: 155 IV – QUẢN LÝ TIẾN TRÌNH (PROCESS) z 1 - Định nghĩa tiếntrình: z 2 – Phân loại: kế tiếp và song song, z Tiến trình song song: z 156 Phân loại 157 Phân loại z a) Độclập: Bảovệ thông tin, z b)Quan hệ thông tin: z Tiếntrìnhnhận: Tồntại? Ởđâu? Giai đoạn nào? z Cơ chế truyền tin: z Hòm thư, z I/O Ports, z Monitor/ 158 Phân loại z c) Phân cấp: z Tài nguyên cho tiếntrìnhcon: z Hệ thống QL tài nguyên tập trung: từ hệ thống, z Hệ thống QL tài nguyên phân tán: từ vốn tài nguyên tiến trình chính, z QL phân tán: Tiếntrìnhchínhphảikết thúc sau tiếntrìnhcon € POST, WAIT. z d) Đồng mức: z Sử dụng chung theo nguyên tắclầnlượt, z Các hệ thống mô phỏng, trò chơi, . . . 159 3 - BIỂU DIỄN TIẾN TRÌNH SONG SONG z Giả thiết: S1, S2, . . ., Sn – các công việc thựchiện song song (Trên 1 hoặcnhiều máy). 1 2 n 160 BIỂU DIỄN z 2 cách mô tả phổ biến: PARBEGIN COBEGIN S1 ;S1 ; S2; S2; . . . . . . . . . . . . . . Sn Sn PAREND; COEND; Các công việcSi đượcmôtả chính xác bằng một ngôn ngữ lậptrìnhcụ thể. 161 4 – TÀI NGUYÊN GĂNG và ĐOẠN GĂNG z Tài nguyên găng: Khả năng phụcvụđồng thời bị hạnchế, thông thường - bằng 1. z Ví dụ: Máy in, quá trình bán vé máy bay . . . z Đoạngăng (chỗ hẹp) củatiếntrình, z Điều độ tiến trình qua đoạngăng: Tổ chứccho mọitiến trình qua đượcchổ hẹpcủamình. z Giảithuật điều độ phải đảmbảo4 yêucầu. 162 Yêu cầu z i) Đảmbảotàinguyêngăng không phảiphục vụ quá khả năng củamình, z ii) Không để tiếntrìnhnằmvôhạn trong đoạn găng, z iii) Nếucóxếp hàng chờ thì sớmhay muộntiến trình cũng qua được đoạngăng, z iv) Nếucótiếntrìnhchờđợivànếu tài nguyên găng đượcgiải phóng, thì tài nguyên găng phải phụcvụ ngay cho tiếntrìnhđang chờđợi. 163 Công cụđiều độ z Công cụđiều độ: 2 loại: z Cấpcao: do hệ thống đảmnhiệm, nằm ngoài tiến trình được điều độ, z Cấpthấp: cài đặt ngay vào trong tiếntrìnhđược điều độ. z Các giảithuật điều độ cấpthấp: 3 lớpgiảithuật: z Phương pháp khoá trong, z Phương pháp kiểmtravàxáclập, z Kỹ thuật đèn báo. 164 5 – CÁC GIẢI THUẬT ĐIỀU ĐỘ CẤP THẤP z Phương pháp khoá trong: z Nguyên lý: z Mỗitiến trình (TT) đặttương ứng tài nguyên găng với1 biến ∈ G, z TT dùng biến này để đánh dấuviệcmìnhđang sử dụng tài nguyên găng, z Trướckhivàođoạngăng TT phảikiểmtrabiến tương ứng của các TT khác và chỉ vào đoạngăng khi không có TT nào đang sử dụng tài nguyên găng. 165 Phương pháp khoá trong z Môi trường ví dụ: Xét trường hợp: z 2 tiến trình, z MỗiTT cómột đoạngăng ởđầu, z 1 tài nguyên găng vớikhả năng phụcvụ:1, z Các tiếntrìnhlặpvôhạn. z Tránh nhầmlẫngiữa 2 khái niệm: z Sơđồnguyên lý: nêu ý tưởng chung, z Giảithuật điều độ: sơđồhành động để đảmbảo điều độ. 166 zSBEGINƠ ĐỒ NGUYÊN LÝ z Ban đầu k = 0; khoá mở z PARBEGIN z tt1: while k = 1 do; <-chờđợitíchcực z k := 1; z z k := 0; z z tt2 : while k = 1 do; <-chờđợitíchcực z k := 1; z z k := 0; z z PAREND z END 167 KIỂM TRA VÀ XÁC LẬP (TEST and SET) z Cơ sở: dùng lệnh máy TS có từ các máy tính thế hệ III trởđi. 168 TEST and SET z IBM 360/370: ∃ 1 lệnh TS ( mã 92H), z IBM PC: Nhóm lệnh BTS (Binary Test and Set): L:= G ¬G G ¬G G:= 1 0 1 0 169 TEST and SET z Sơđồđiều độ: 170 TEST and SET Đặc điểm: z Đơngiản, độ phứctạp không tăng khi số tiến trình tăng. Nguyên nhân: Cụcbộ hoá biếnvà tính liên tụccủaKT & XL, z Tồntạihiệntượng chờđợi tích cực. Nguyên nhân: MỗiTT phải tựđưamìnhvàođoạngăng. 171 KỸ THUẬT ĐÈN BÁO(Semaphore) z Dijsktra đề xuất 1972. z Đề xuất: z Mỗitàinguyêngăng được đặttương ứng với một biến nguyên đặcbiệtS(Semaphore), z Ban đầu: S ← Khả năng phụcvụ t.ng. găng, z ∃ 2 lệnh máy P(S) và V(S) thay đổigiátri củaS, mỗilệnh làm 2 công việc và làm mộtcáchliên tục. 172 KỸ THUẬT ĐÈN BÁO z Nội dung lệnh P(S): * Dec(s); ** If S < 0 then ĐưaTT đixếp hàng. z Nội dung lệnh V(S): * Inc(s); ** If S ≤ 0 then Kích hoạtTT đang xếp hàng. 173 KỸ THUẬT ĐÈN BÁO z Thựchiện: z Vì nhiều lý do, không thể chế tạoMT với2 lệnh trên, z Lệnh P(S), V(S) € thủ tục tương ứng. z Đảmbảotínhliêntục: 174 KỸ THUẬT ĐÈN BÁO z Sơđồđiều độ: 175 KỸ THUẬT ĐÈN BÁO Semaphore nhị phân: z Phầnlớn các tài nguyên găng có khả năng phụcvụ = 1 € S nhị phân. z P(S): If s = 0 then Xếp_hàng Else s := 0; z V(S): If dòng_xếp_hàng ≠ NULL then Kích_hoạt Else s := 1; Vấn đề đặt tên các thủ tụcP vàV. 176 6 – CÔNG CỤ ĐIỀU ĐỘ CẤP CAO z Đoạngăng quy ước, z Biến điềukiệnquyước, z Monitor hỗ trợđiều độ: cung cấpgiátrị cho biến điềukiệnquyước. z Monitor đóng vai trò vỏ bọcbảovệ ngăncách giữa tài nguyên găng và công cụ truy nhập tớinó. 177 7 - BẾ TẮC và CHỐNG BẾ TẮC z Khái niệmbế tắc (Deadlock): z Cùng chờđợi, z Vô hạnnếu không có tác động từ bên ngoài. z Sẽ không có bế tắcnếu TT A bắt đầu đủ sớm hay đủ muộn. 178 BẾ TẮC và CHỐNG BẾ TẮC z Điềukiệnxuấthiệnbế tắc: hội đủ đồng thời 4 điềukiện: z ∃ tài nguyên găng, z Có tổ chứcxếphàngchờđợi, z Không phân phốilại tài nguyên, z ∃ hiệntượng chờđợivòngtròn. z Chống bế tắc: 3 lớpgiảithuật: z Phòng ngừa, z Dự báovàtránh, z Nhậnbiếtvàkhắcphục. 179 Phòng ngừa z Điềukiệnápdụng: z Xác xuấtxuấthiệnbế tắclớn, z Các biện phápTổnthấtlớn. z Biện pháp: tác động lên mộthoặcmộtsốđiều kiện gây bế tắc để 4 điềukiện không xuấthiện đồng thời. z Các giải pháp: đượcápdụng để nâng cao hiệu quả củahệ thống. 180 Phòng ngừa z Chống tài nguyên găng: z Tổ chứchệ thống tài nguyên lô gíc, z 2 mứctruynhập, z SPOOL. z Chống xếp hàng chờđợi: z Chếđộphân phốisơ bộ, z Trước khi ngắtTT: lưutrạng thái (Dump), z Công cụ: z Điểm gác (Control Points), z Điểmngắt (Break Points) 181 Phòng ngừa z Đặt điểmgác: z Cốđịnh trong CT, z Theo tác nhân ngoài (vd: thờigian) z Ứng dụng: z Hiệuchỉnh CT, z ThựchiệncácCT dài, z Vớitoànbộ hệ thống: Hibernating. 182 Phòng ngừa z Phân phốilại tài nguyên: z Các tài nguyên quan trọng (Bộ nhớ, Processor . . .) luôn luôn được phân phốilại, z Chủ yếu: chỉ cầnlưu ý các tài nguyên riêng, z Hệ thống tài nguyên lô gíc: giảmnhucầu phân phối lại. z Để phân phốilại: Lưuvàkhôiphụctrạng thái tài nguyên. 183 Phòng ngừa z Chống chờđợi vòng tròn: z Phân lớp tài nguyên, tạo thành hệ thống phân cấp, z Nguyên tắc phân phối: Khi chuyểnlớp-phảigiải phóng tài nguyên lớpcũ. 184 DỰ BÁO VÀ TRÁNH z Mỗilần phân phốimột tài nguyên: kiểmtraxem việc phân phốinàycóthể dẫn đến nguy cơ bế tắcchomộtsố tiến trình nào đó hay không và là những tiến trình nào? z Điềukiệnmôitrường: z Xác xuấtxẩyrabế tắcnhỏ, z Tổnthất(nếucóbế tắc) – lớn. 185 DỰ BÁO VÀ TRÁNH z Giảithuậttiêubiểu: “Ngườichủ ngân hàng”. z Giả thiết: z Xét 1 loại tài nguyên, số lượng € tstb, z n tiến trình, z Maxi, z Ffoii, z Kti – boolean, z True – chắcchắnkết thúc được, z False – trong trường hợpngượclại. 186 DỰ BÁO VÀ TRÁNH 187 DỰ BÁO VÀ TRÁNH z Tiêu chuẩndự báo: ngặt, z DựavàoKti € biết các TT có nguy cơ bế tắc, z Xử lý trước khi TT bị bế tắc. z Đặc điểmgiảithuật: z Đơngiản, z Input: Maxi –tin cậy, z Mỗiloại tài nguyên ⇔ thủ tục, z Mỗilầnphânphối € kiểmtra. 188 NHẬN BIẾT VÀ KHẮC PHỤC z Định kỳ kiểm tra các TT chờđợi để phát hiện bế tắc, z Điềukiệnápdụng: z Xác xuấtxẩyrabế tắc bé, z Tổnthất(nếucóbế tắc) – bé. z Áp dụng vớiphầnlớn OS trong thựctế, z Do OP đảmnhiệm. 189 NHẬN BIẾT VÀ KHẮC PHỤC z Lệnh OP € các nhóm lệnh phụcvụ nhậnbiết và khắcphục, z Nhóm lệnh xem trạng thái (Display Status), z Nhóm lệnh tác động lên dòng xếp hàng TT, z Nhóm lệnh tác động lên TT, z Quan trọng: các lệnh huỷ tiếntrình, z Các biện pháp hỗ trợ và ngănchặntựđộng. 190 8 - GỌI TIẾN TRÌNH z TT có thể cạnh tranh hoặctương tác với nhau, z Mối quan hệ tương tác: tuầntự hoặc song song, z Xác lậpquanhệ: z Lờigọi, z Cơ chế xử lý sự kiện(Sẽ xét ở chương sau), z Các cách gọi: z Trong phạmvi mộthệ thống, z Giữacáchệ thống: z RI (Remote Invocation), z RPC (Remote Procedure Call), z Lý thuyết chung: RMI (Remote Methods Invocation) 191 GỌI TIẾN TRÌNH z Sơđồgọi: z Không đốixứng, z Đốixứng. z Kỹ thuậttruyềnthamsố: z Theo giá trị, z Theo địachỉ, z CR (Call by Copy/Restore). 192 GỌI TIẾN TRÌNH z Thông tin tốithiểu để lưuvàkhôiphục TT: z Nội dung các thanh ghi, z Địachỉ lệnh, z Vùng bộ nhớ RAM liên quan, z Vùng bộ nhớ phụcvụ củahệ thống, z Các sự kiệnchưaxử lý. z Phân biệtsơđồgọi đốixứng và đệ quy. 193 V – QUẢN LÝ PROCESSOR z Mục đích: Giảmthời gian chếtcủa Processor € nâng cao hiệuquả hệ thống, z Vai trò thiếtbị trung tâm: liên kếtcácbộ phận đọclập(cứng và mềm) thành hệ thống hoạt động đồng bộ. z Trong phần này: xét hoạt động của 1 CPU. 194 1 – PROCESSOR LÔ GÍC 195 2 – CÁC TRẠNG THÁI CƠ BẢN CỦA TIẾN TRÌNH TT TT CT Sẵn sàng Thực hiện TT Chờ đợi z Đặctrưng các loạitrạng thái, z Vấn đề cầngiảiquyết: 3 loại. 196 VẤN ĐỀ TT TT CT Sẵn sàng Thực hiện TT Chờ đợi 197 VẤN ĐỀ a) Liên quan tới dòng TT sẵn sàng: Cách tổ chứcphụcvụ dòng xếp hàng? 198 VẤN ĐỀ z Trình tự phụcvụ tác động lên thời gian chờ đợi trung bình tw : giả thiết – 3 TT : 1 2 3 199 VẤN ĐỀ z Thờigianthựchiện tiếntrình: z Không đẩyra(Non- preemptive), 2 chế độ phục vụ (Xử lý theo lô) z Có đẩyra(Preemptive) TT TT (Phân chia thCTờigian) KT Sẵn sàng Thực hiện Lượng tử thời gian: 0.03” ÷ 0.2”. TT Chờ đợi 200 VẤN ĐỀ z c) Thời điểm đưa TT chờđợitrở lạisẵn sàng? Cơ chế sự kiện và ngắt. Thời điểm? TT TT CT Sẵn sàng Thực hiện TT Chờ đợi 201 3 - ĐIỀU ĐỘ THỰC HIỆN TT z TT ⇔ thứ tựưutiênphụcvụ, z Yêu cầu: z tw € min. z TT kếtthúc. z Chếđộ: z Một dòng xếp hàng, z Nhiều dòng xếp hàng. 202 Chếđộmột dòng xếphàng z a) FCFS (First come – First served): z Đơngiản, z ∀ TT kết thúc được, z Không cần input bổ sung, z Tw – lớn, z Non-Preemtipve. 203 Chếđộmột dòng xếphàng z b) SJN (Shortest Job – Next): z Thờigianthựchiệnít€ ưutiêncao, z Tw giảm, z TT dài có nguy cơ không kếtthúcđược, z Khó dự báo thời điểmphụcvụ TT, z Non-Preemtipve, z Input: ThờigianthựchiệnTT. 204 Chếđộmột dòng xếphàng z c) SRT (Shortest Remaining Time): z Thứ tựưutiênphụcvụ: xác định theo lượng thờigiancòn lạicầnthiết để kết thúc TT, z tw giảmmạnh, z Các đặctrưng khác: tương tự như SJN, z TT dài càng có nguy cơ không kết thúc được! z Ở các chếđộNon-Preemtipve: cầncótlim € huỹ TT hoặc đưavề thứ tựưutiênthấpnhất. 205 Chếđộmột dòng xếphàng z d) RR (Round Robin): t z (lư Preemtipve, t ợ hờ ng i g t ian ử z ∀ TT - kếtthúc ) đươc, 10% 10% 10% z Khả năng đốithoại Bổ sung TT mới với TT, 10% 10% z Ưutiênthíchđáng với TT dài: phân 10% 10% lớpphụcvụ với t 10% 10% lớnhơn. 10% 206 Chếđộnhiều dòng xếphàng 207 4 - NGẮT và XỬ LÝ NGẮT z Định nghĩangắt (Interrupt): z Cơ chế Sự kiện và Ngắt: từ MT thế hệ III, z IBM 360/370 – 7 loạisự kiện, z IBM PC – 256 loạisự kiện. 208 PHÂN LOẠI NGẮT z Ngắt trong và ngắt ngoài, z Ngắt trong: /0, tràn ô, . . . z Ngắt ngoài: I/O Int, Timer, . . . z Ngắtchắn được và không chắn được: z Chắn được: i/o Int, z Không chắc được: Timer Int. z Ngắtcứng và ngắtmềm. 209 XỬ LÝ NGẮT Mức xử lý I Mức xử lý II 210 CT con và CT xử lý ngắt 211 5 - Xử lý ngắt trong IBM PC z Ngắt ⇔ Pointer (4 bytes), z Véc tơ ngắt = {Pointers} (1 KB), z Khốibộ nhớ xử lý ngắt, z Nét đặcbiệt: z ∃ các ngắt| Pointer € Bảng tham số (Int 11, 1E, 41, . . .), z Ngắt KT CT – Int 20, Ngắtthường trú CT Int 27, z NgắtR/W đĩatheođịachỉ tuyệt đối – Int 25, 26, z ∃ ngắttương ứng vớiviệcbấm phím (Int 05, 1B), z NgătOS môphỏng xử lý các sự kiện (Int 21), z Mộtsố sự kiện: dành cho user tạongắtmềm € Lậptrình hướng sự kiện(EOP). 212 VI - CẤU HÌNH và QUẢN LÝ HỆ THỐNG z 1 - Hệ thống nhiều Processors. z Các loạicấuhình: z Cấuhìnhphâncấp, z Liên kết linh hoạt, z Đẳng cấu, z Quảnlýtiếntrình: z S – tài nguyên găng, z TS € S € điều độ, z Đảmbảotoànvẹnchứcnăng và toàn vẹncấu hình. 213 CẤU HÌNH và QUẢN LÝ HỆ THỐNG z 2 - Bảovệ hệ thống: z Nguy cơ: z Mấthoặchỏng dữ liệu, z Sử dụng tài nguyên vớimục đích xấu, z Truy nhập không đăng ký, z Dò rỉ thông tin. z Cơ chế bảovệ: z Nguyên lý ngănchặn, z Nguyên lý cho phép. z Giảithuậtvàbiệnphápbảovệ: linh hoạt, thường xuyên thay đổi. 214 CẤU HÌNH và QUẢN LÝ HỆ THỐNG z 3 – Thiếtkế và xây dựng hệ thống: z Nguyên lý tập trung: WINDOWS, UNIX, OS IBM, . . . z Nguyên lý “Thử và sai”: LINUX: z Không có đề xuấthướng chung, z Mã nguồnmở cho phép mọingườinghiêncứu, bổ sung sửa đổi, z Phát triểntheonguyênlýtựđiềuchỉnh, z Giao diện: User tự trang bị. 215 4 - Hệ thống của Microsoft z . 216

Các file đính kèm theo tài liệu này:

  • pdfbai_giang_he_dieu_hanh_do_tuan_anh.pdf
Tài liệu liên quan