Hệ điều hành - Chương 1: Giới thiệu hệ điều hành

Tài liệu Hệ điều hành - Chương 1: Giới thiệu hệ điều hành: HỆ ðIỀU HÀNH Chương 1 GIỚI THIỆU HỆ ðIỀU HÀNH 2Nội dung chương 1 I. ðịnh nghĩa hệ ủiều hành II. Phõn loại hệ ủiều hành III. Cỏc khỏi niệm cơ bản IV. Cấu trỳc hệ ủiều hành V. Nhắc lại về kiến trỳc mỏy tớnh 3I. ðịnh nghĩa hệ ủiều hành  Với người sử dụng (users): • HDH là chương trỡnh nạp vào mỏy ủầu tiờn • HDH quản lý tương tỏc người mỏy  Với người lập trỡnh (programmers): • HDH là mỏy tớnh mở rộng • HDH quản lý tài nguyờn, quản lý hoạt ủộng của cỏc chương trỡnh ứng dụng Mục tiờu: • Tiện lợi, hiệu quả • Dễ phỏt triển 4Cỏc lớp hoạt ủộng của mỏy tớnh 5II. Phõn loại hệ ủiều hành  Phõn loại theo thứ tự xuất hiện  Lịch sử hệ ủiều hành  Phõn loại theo hoạt ủộng 6Phõn loại theo thứ tự xuất hiện  Thế hệ 1 1945 - 1955 • ðốn ủiện tử chõn khụng – tuần tự  Thế hệ 2 1955 - 1965 • Transistors – batch systems  Thế hệ 3 1965 - 1980 • Mạch tớch hợp (ICs) – ủa chương  Thế hệ 4 1980 - nay • Mỏy vi tớnh – ủa chương hiện ủại 7Vớ dụ: batch system 8Cỏc loại hệ ủiề...

pdf367 trang | Chia sẻ: Khủng Long | Lượt xem: 1131 | Lượt tải: 1download
Bạn đang xem trước 20 trang mẫu tài liệu Hệ điều hành - Chương 1: Giới thiệu hệ điều hành, để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên
HỆ ðIỀU HÀNH Chương 1 GIỚI THIỆU HỆ ðIỀU HÀNH 2Nội dung chương 1 I. ðịnh nghĩa hệ điều hành II. Phân loại hệ điều hành III. Các khái niệm cơ bản IV. Cấu trúc hệ điều hành V. Nhắc lại về kiến trúc máy tính 3I. ðịnh nghĩa hệ điều hành  Với người sử dụng (users): • HDH là chương trình nạp vào máy đầu tiên • HDH quản lý tương tác người máy  Với người lập trình (programmers): • HDH là máy tính mở rộng • HDH quản lý tài nguyên, quản lý hoạt động của các chương trình ứng dụng Mục tiêu: • Tiện lợi, hiệu quả • Dễ phát triển 4Các lớp hoạt động của máy tính 5II. Phân loại hệ điều hành  Phân loại theo thứ tự xuất hiện  Lịch sử hệ điều hành  Phân loại theo hoạt động 6Phân loại theo thứ tự xuất hiện  Thế hệ 1 1945 - 1955 • ðèn điện tử chân khơng – tuần tự  Thế hệ 2 1955 - 1965 • Transistors – batch systems  Thế hệ 3 1965 - 1980 • Mạch tích hợp (ICs) – đa chương  Thế hệ 4 1980 - nay • Máy vi tính – đa chương hiện đại 7Ví dụ: batch system 8Các loại hệ điều hành hiện đại  Hệ điều hành máy tính lớn (mainframe)  Hệ điều hành server  Hệ điều hành đa xử lý (multiprocessor)  Hệ điều hành máy vi tính  Hệ điều hành thời gian thực (real-time)  Hệ điều hành nhúng (embeded) 9Hệ thống máy tính lớn 10 PDA (Personal Digital Assistant) 11 III. Các khái niệm cơ bản 1. Process (tiến trình) và Thread (luồng) 2. File 3. System Calls – Lệnh gọi hệ thống 4. Shell – Giao diện với người sử dụng 12 1. Process và thread  Process: chương trình được cho thực thi ðược nạp vào bộ nhớ Cĩ các thơng tin trạng thái  Hệ thống đa chương: tập hợp các process tồn tại đồng thời Các process của hệ điều hành Kernel mode Các process ứng dụng User mode 13 Thread  Process cĩ 2 đặc trưng: • ðơn vị được cấp phát tài nguyên • ðơn vị được thực thi  Thread là sự trừu tượng hố đặc trưng thực thi của process • Control path • Lightweight process • Context of execution 14 Mơ hình thread a. Dạng 1-1 b. Dạng n-1 15 Ví dụ ứng dụng thread Một word processor với 3 thread 16 2. File  File: đơn vị lưu trữ trên thiết bị nhớ ngồi  Là sự trừu tượng hố dữ liệu (che dấu phần cứng)  Các thiết bị xuất nhập cĩ thể trừu tượng hố như file  Hệ điều hành tổ chức và quản lý theo hệ thống file (file system), ví dụ: FAT, NTFS, 17 3. Lệnh gọi hệ thống  Chương trình ứng dụng (user program) truyền thơng và yêu cầu dịch vụ của hệ điều hành thơng qua lệnh gọi hệ thống (system calls)  System call: Hàm thư viện của hệ điều hành Phụ thuộc từng loại hệ điều hành 18 Ví dụ: UNIX/Win32 API (Application Programming Interface) 19 Ví dụ: các bước gọi read(fd, buffer, nbytes) 20 4. Giao diện với người sử dụng  Các dạng cơ bản: • Dịng lệnh (command line) • ðồ hoạ (Graphical User Interface, GUI) 21 IV. Cấu trúc hệ điều hành 1. Các thành phần 2. Cấu trúc hệ điều hành 3. ðặc điểm của hệ điều hành hiện đại 4. Hệ thống phân bố 22 1. Các thành phần  Quản lý process • ðiều phối • Xử lý đồng thời  Quản lý bộ nhớ  Quản lý xuất nhập  Quản lý file  Hỗ trợ mạng  Bảo mật 23 Các thành phần của hệ điều hành 24 2. Cấu trúc hệ điều hành  Cấu trúc thơng dụng: Microkernel  Gồm các phần: Kernel Luơn cĩ trên bộ nhớ Thực hiện các chức năng cơ bản Hoạt động trên kernel-mode Services Hoạt động trên user-mode Linh hoạt Phù hợp cho mơi trường phân bố 25 Cấu trúc Windows 2000 26 3. ðặc điểm của hệ điều hành hiện đại Kiến trúc microkernel (Microkernel architecture) ða luồng (Multithreading) ða xử lý đối xứng (Symmytric MultiProcessing) Hệ điều hành phân bố (Distributed operating systems)  Thiết kế hướng tối tượng (Object-oriented design) 27 4. Hệ thống phân bố Hệ thống phân bố (distributed systems): • Gồm các máy tính độc lập • Kết nối mạng • Dùng phần mềm hệ thống phân bố Người sử dụng cĩ một hệ thống máy tính luận lý đơn 28 Hệ thống phân bố với middleware 29 Hệ thống phân bố với HðH mạng 30 Hệ thống phân bố với HðH mạng và middleware 31 V. Nhắc lại về tổ chức máy tính 1. Cấu trúc máy vi tính 2. Hoạt động máy vi tính 3. Giới thiệu bộ nhớ cache 32 1. Cấu trúc máy vi tính  Bộ xử lý: 1 hay nhiều  Bộ nhớ  Bus  ISA – 16 bit PCI – 32 bit PCI Express  Thiết bị xuất nhập Mạch điều khiển (controller) Thiết bị (device) 33 Cấu trúc tiêu biểu máy vi tính 34 2. Hoạt động máy vi tính  ðơn vị hoạt động: chu kỳ lệnh  Các thao tác cơ sở: Tính tốn bên trong CPU ðọc ghi bộ nhớ: Lệnh đọc ghi bộ nhớ ðịa chỉ bộ nhớ ðọc ghi thiết bị xuất nhập: Lệnh xuất nhập Các phương pháp xuất nhập 35 Chu kỳ lệnh cơ bản Lấy lệnh tiếp theo – Fetch next instruction Thực hiện lệnh – Execute instruction 36 Ví dụ: Xuất nhập dùng chương trình 37 Ví dụ: Xuất nhập dùng kỹ thuật ngắt 38 Ví dụ: Xuất nhập dùng kỹ thuật DMA 39 3. Cache a. Khái niệm b. Hoạt động c. Phân loại 40 a. Khái niệm cache  Bộ nhớ dung lượng nhỏ, tốc độ cao  Giúp CPU truy xuất bộ nhớ nhanh hơn 41 b. Hoạt động cache Giả sử CPU đọc 1 khối nhớ k lần Nếu khơng cĩ cache: CPU đọc khối trên bộ nhớ k lần Nếu cĩ cache: Lần 1: CPU đọc khối trên bộ nhớ và ghi khối vào cache k-1lần cịn lại: CPU đọc khối trên cache 42 Tỷ số thành cơng (hit ratio, h) Xét k: k >> 1: h  1, chỉ truy xuất trên cache k = 1: cache là cĩ hại  Truy xuất trên cache: cache hit Khơng truy xuất được trên cache: cache miss Số lần truy xuất thành cơng trên cache k -1 Tổng số lần truy xuất k h = 43 Hoạt động khi cĩ cache Khi CPU cần truy xuất 1 khối nhớ, CPU tìm khối trên cache. Nếu khối cĩ trên cache: CPU truy xuất khối trên cache Nếu khối chưa cĩ trên cache: CPU truy xuất khối trên bộ nhớ CPU ghi khối vào cache 44 c. Phân loại cache Cache cấp 1 – First level cache (L1) Ở trong CPU Kích thước nhỏ (vài chục KB) Cache cấp 2 – Second level cache (L2) Ở ngồi CPU Kích thước lớn (vài trăm KB) 45 Các loại cache 46 Disk cache Mở rộng khái niệm cache: giúp CPU truy xuất các loại đĩa nhanh hơn Dùng phần cứng: linh kiện nhớ trên các ổ đĩa cứng, CD Dùng phần mềm: dùng một phần bộ nhớ trong làm disk cache 47 Tài liệu tham khảo  Modern Operating Systems – Second Edition A.S.Tanenbaum – Prentice Hall  Operating System Concepts – Sixth Edition A. Silberschatz, P.B. Galvin, G. Gagne John Wiley & Sons, Inc  Help and Support (Windows)  HỆ ðIỀU HÀNH Chương 2 CÁC VẤN ðỀ VỀ PROCESS VÀ THREAD 2Nội dung chương 2 I. Process II. Thread III. Truyền thơng giữa các process IV. ðiều phối 3I. Process 1. Mơ hình process 2. Hiện thực process 41. Mơ hình process a. Khái niệm process b. Tổ chức thứ bậc các process c. Các trạng thái của process 5a. Khái niệm process  Process là chương trình được thực thi: • ðược nạp vào bộ nhớ • Cĩ các thơng tin trạng thái: thanh ghi PC, các thanh ghi, Mỗi process thực thi trên một CPU ảo Hệ thống cĩ nhiều process đồng thời: • ða chương – 1 CPU • ða xử lý – nhiều CPU trên 1 máy • Phân bố – nhiều CPU trên nhiều máy 6Process trên bộ nhớ 7Ví dụ: hệ thống đa chương với 4 process a. ða chương với 4 chương trình b. Mơ hình 4 chương trình độc lập c. Chỉ cĩ 1 chương trình được thực thi tại 1 thời điểm 8b. Tổ chức thứ bậc các process  Tạo process mới: • Hệ điều hành tạo process mới • User yêu cầu tạo process mới • Process tạo process mới Kết thúc process: • Bình thường • Lỗi • Do process khác kết thúc 9Tổ chức thứ bậc các process (tt)  Process tạo process mới: • Parent process • Child process Hệ thống thứ bậc các process • UNIX: process group Windows khơng cĩ tổ chức thứ bậc • Các process được tạo tương đương 10 c. Các trạng thái của process  Mơ hình 3 trạng thái  Chuyển trạng thái 11 Các trạng thái của process Mơ hình 5 trạng thái 12 Mơ hình 3 trạng thái 13 Các trạng thái  Thực thi – Running: • ðang thực thi (đang sử dụng CPU) • Chỉ cĩ 1 running process tại 1 thời điểm trên hệ thống đa chương  Sẵn sàng – Ready: • Sẵn sàng thực thi, tạm dừng chờ CPU • Cĩ nhiều ready process • ðược quản lý bằng ready queue  Bị chặn – Blocked: • Khơng thể thực thi cho đến khi cĩ biến cố xảy ra • Cĩ nhiều ready process • ðược quản lý bằng blocked queue 14 Chuyển trạng thái Running  Blocked (1): chờ biến cố Running  Ready (2): hết thời gian Ready  Running (3): được thực thi Blocked  Ready (4): biến cố xảy ra  Scheduler – Bộ điều phối của hệ điều hành thực hiện 15 Thời điểm chuyển trạng thái Ngắt quãng thời gian – Clock Interrupt • Dùng để kiểm sốt thời gian Ngắt quãng thiết bị – I/O Interrupt • Liên quan đến thiết bị I/O  Lệnh gọi hệ thống, lỗi – System call, trap • Khi gọi system calls, hay khi cĩ lỗi 16 Bộ điều phối (scheduler) 17 Ví dụ: chuyển trạng thái giữa P0 và P1 18 2. Hiện thực process  Hệ điều hành tổ chức và quản lý các bảng: • Bảng process – Process Table • Bảng bộ nhớ – Memory tables • Bảng File – File Tables • Bảng xuất nhập – I/O Tables  Cấu trúc các bảng phụ thuộc hệ điều hành  Process trên bộ nhớ ảnh process (process image) 19 Process và các loại tài nguyên 20 Cấu trúc tổng quát các bảng 21 Các thơng tin cơ bản quản lý process Danh hiệu (ID)  Trạng thái bộ xử lý (processor state) • Thanh ghi PC, thanh ghi Flag • Các thanh ghi  Thơng tin điều khiển: • Trạng thái • Sử dụng tài nguyên (bộ nhớ, file, I/O) • Quyền truy xuất • 22 Ví dụ: Windows process 23 Ví dụ: Windows process và tài nguyên 24 II. Thread 1. Khái niệm thread 2. Hiện thực thread 25 1. Khái niệm thread  Process cĩ 2 đặc trưng: • ðơn vị sử dụng tài nguyên • ðơn vị được thực thi (theo một dịng điều khiển, cĩ thể xen kẽ giữa các process) ðặc trưng thực thi của process được trừu tượng hố thành thread 26 Các mơ hình thread cơ bản Một thread trong một process • ðơn luồng (single thread) Nhiều thread trong một process • ða luồng (multithreaded) 27 ðơn luồng và đa luồng 28 Các đặc điểm của thread Mỗi thread cĩ stack, cĩ trạng thái riêng Việc chuyển trạng thái giữa các thread nhanh hơn giữa các process Các thread trong process dùng chung tài nguyên Các thread thực thi đồng thời trên các hệ thống SMP, siêu phân luồng, đa lõi Giữa các thread khơng cĩ sự bảo vệ 29 Ví dụ: các trạng thái của Windows thread 30 Ví dụ: các trạng thái của Java thread 31 Các ứng dụng thread Cơng việc dạng background, foreground Các xử lý bất đồng bộ  Tăng tốc độ xử lý  Tạo tính cấu trúc cho chương trình 32 2. Hiện thực thread Các dạng hiện thực Cấp user • Do các thư viện thread quản lý • Ví dụ: win32, java thread Cấp kernel • Do kernel quản lý • Ví dụ: Windows 2K/XP, Linux  Tổ hợp user-kernel • Ví dụ: Solaris 33 Hiện thực thread cấp user 34 Hiện thực thread cấp kernel 35 III. Truyền thơng giữa các process 1. Các điều kiện dẫn đến tranh chấp 2. Loại trừ tương hỗ 3. Giải quyết loại trừ tương hỗ dùng vịng lặp 4. Semaphores 5. Vấn đề đồng bộ giữa các process 36 1. Các điều kiện dẫn đến tranh chấp Các dạng tương tác giữa các process tồn tại đồng thời • Các process độc lập • Các process biết nhau gián tiếp (thơng qua tài nguyên dùng chung) • Các process biết nhau trực tiếp (các process thuộc về một phần mềm) 37 Xét ví dụ: 38 Xét ví dụ (tt) Cĩ 2 process P0, P1 Mục đích: • P0: nhập X, xuất X • P1: nhập Y, xuất Y Kết quả: • P0: nhập X, xuất Y • P1: nhập Y, xuất Y 39 ðiều kiện dẫn đến tranh chấp ðiều kiện: Các process dùng chung tài nguyên  Thứ tự truy xuất ảnh hưởng kết quả ðịnh nghĩa:  Tài nguyên tranh chấp Critical resource Vùng tranh chấp Critical region/Critical section 40 2. Loại trừ tương hỗ (mutual exclusion) a. Khái niệm b. Các yêu cầu c. Các phương pháp giải quyết 41 a. Khái niệm  Loại trừ tương hỗ: nguyên tắc giải quyết triệt để vấn đề tranh chấp tài nguyên giữa các process Khi cĩ một process vào vùng tranh chấp thì tất cả các process khác phải ở ngồi vùng tranh chấp Cĩ thể dẫn đến trạng thái deadlock hay trạng thái starvation 42 Cấu trúc một process while (TRUE) { enter_region(); // kiểm tra điều kiện critical_region(); // vùng tranh chấp leave_region(); // thơng báo trạng thái noncritcal_region();// vùng khơng tranh chấp } 43 Loại trừ tương hỗ giữa 2 process A, B 44 Trạng thái deadlock a. Process A giữ tài nguyên R b. Process B yêu cầu tài nguyên R c. Process C và D bị deadlock vì tài nguyên T và U 45 Trạng thái starvation  Trạng thái chờ mãi mãi của process Ví dụ: • 3 process A, B, C dùng chung tài nguyên R • Tài nguyên R được cấp luân phiên cho process A và process B • Process C sẽ chờ mãi mãi 46 b. Các yêu cầu (1) Khơng cĩ 2 process đồng thời vào vùng tranh chấp (2) Khơng cĩ giả sử gì về tốc độ và số lượng process (3) Khơng cĩ process nào ở ngồi vùng tranh chấp cĩ thể ảnh hưởng đến process khác (4) Khơng cĩ process nào chờ mãi mãi 47 c. Các phương pháp giải quyết  Các process phải kiểm ra điều kiện trước khi vào vùng tranh chấp và thơng báo khi rời vùng tranh chấp  Nếu điều kiện khơng thoả thì chờ  Cĩ hai dạng chờ: • Chờ bằng vịng lặp (busy-waiting) Dùng phần mềm Phần cứng hỗ trợ • Chờ bằng trạng thái blocked Hệ điều hành hỗ trợ 48 3. Giải quyết loại trừ tương hỗ dùng vịng lặp a. Phần mềm giải quyết loại trừ tương hỗ b. Phần cứng hỗ trợ giải quyết loại trừ tương hỗ 49 a. Phần mềm giải quyết loại trừ tương hỗ Giải thuật luân phiên nghiêm ngặt (Strict Alternation) Giải thuật Peterson 50 Giải thuật luân phiên nghiêm ngặt Giải quyết trường hợp 2 process (P0 và P1) và một tài nguyên Hai process dùng một biến turn để xác định đến phiên process nào vào vùng tranh chấp Khởi động turn = 0 51 Giải thuật luân phiên nghiêm ngặt (tt) P0 P1 while (TRUE) { while (TRUE) { while (turn != 0) ; while (turn != 1) ; critical_region(); critical_region(); turn = 1; turn = 0; noncritcal_region(); noncritical_region(); } } 52 Xét hoạt động P0 (tương tự cho P1) Hoạt động P0 • P0 kiểm tra biến turn P0 vào vùng tranh chấp nếu turn = 0 P0 chờ khi turn = 1 • P0 gán turn = 1 khi rời vùng tranh chấp 53 Xét hoạt động P0 (tt)  Hoạt động P0 với P1 Giả sử P0 đến vịng while: • P1 ở ngồi vùng tranh chấp turn = 0: P0 vào vùng tranh chấp • P1 ở trong vùng tranh chấp turn = 1: P0 chờ • P1 cũng đến vịng while: Do biến turn dùng chung nên chỉ cĩ 1 process được vào vùng tranh chấp, process kia chờ tại vịng while 54 ðánh giá giải thuật luân phiên nghiêm ngặt  ðạt yêu cầu (1) và yêu cầu (4)  Giả sử P0 vào vùng tranh chấp 100 lần/đơn_vị thời_gian, P1 vào vùng tranh chấp 1 lần/đơn_ vị thời_gian: • Do luân phiên nghiêm ngặt nên P0 chỉ được vào vùng tranh chấp 1 lần/đơn vị thời gian • Khơng thoả yêu cầu (2)  Giả sử P1 cĩ lỗi ngồi vùng tranh chấp: • P0 dừng mãi mãi tại vịng while • Khơng thoả yêu cầu (3) 55 Giải thuật Peterson  Xét trường hợp 2 process (P0 và P1) và một tài nguyên  Hai process dùng chung: • biến turn: xác định đến phiên process nào vào vùng tranh chấp • Mảng boolean interested[2]: thể hiện process sẵn sàng vào vùng tranh chấp, interested[0]: P0 sẵn sàng vào vùng tranh chấp • Khởi động interested[0] = interested[1] = FALSE 56 Giải thuật Peterson (tt) #define FALSE 0 #define TRUE 1 #define N 2 // s process int turn; // đ n phiên process nào int interested[N]; // process sn sàng void enter_region(int process) { int other; // process cịn li other = 1 – process; interested[process] = TRUE;//th hin process sn sàng turn = process; // đt phiên while(turn == process && interested[other] == TRUE); } 57 Giải thuật Peterson (tt) void leave_region(int process) { interested[process] = FALSE; // rời vùng tranh chấp } P0 P1 while (TRUE) { while (TRUE) { enter_region(0) ; enter_region(1); critical_region(); critical_region(); leave_region(0); leave_region(1); noncritcal_region(); noncritical_region(); } } 58 b. Phần cứng hỗ trợ giải quyết loại trừ tương hỗ  Tập lệnh CPU cĩ các lệnh đặc biệt hỗ trợ Ví dụ: • TEST SET LOCK (TSL) Kiểm tra và đặt giá trị cho một từ nhớ • SWAP ðổi giá trị hai từ nhớ • 59 Lệnh TSL ðọc giá trị một từ nhớ vào một thanh ghi, sau đĩ ghi giá trị khác 0 (thường là 1) vào từ nhớ  Thao tác đọc và ghi nêu trên là trong cùng một lệnh • Thao tác đơn vị (atomic, primitive) 60 Ứng dụng lệnh TSL trong loại trừ tương hỗ Giải quyết trường hợp n process  n process dùng chung một biến flag, khởi động flag = 0 Cấu trúc process Pi: while (TRUE) { enter_region(); // kiểm tra điều kiện critical_region(); // vùng tranh chấp leave_region(); // thơng báo trạng thái noncritcal_region();// vùng khơng tranh chấp } 61 Ứng dụng lệnh TSL (tt) enter_region: TSL register, FLAG; FLAG  register, FLAG = 1 CMP register,0; so sánh FLAG với 0 JNZ enter_region; FLAG=0, lặp RET; FLAG!=0, trở về leave_region: MOV FLAG, 0; Gán FLAG=0 RET; Trở về 62 Ví dụ: lệnh CPMXCHG (IA32) Cú pháp: CMPXCHG DEST, SRC Hoạt động: (accumulator: AL/AX/EAX) IF accumulator = DEST THEN ZF ← 1 DEST ← SRC ELSE ZF ← 0 accumulator ← DEST FI 63 4. Semaphores a. Khái niệm semaphore b. Ứng dụng semaphore xử lý loại trừ tương hỗ c. Ứng dụng semaphore trong đồng bộ giữa các process d. Khái niệm mutex 64 a. Khái niệm semaphore  Semaphore là kỹ thuật do hệ điều hành hỗ trợ: • Xử lý loại trừ tương hỗ • ðồng bộ giữa các process Dùng để báo hiệu (signaling) Khi process chờ báo hiệu thì vào trạng thái blocked, khơng chờ bằng vịng lặp 65 Semaphore  Semaphore là cấu trúc dữ liệu gồm: • Giá trị integer • Hàng đợi các process Cĩ thể xem semaphore là giá trị integer với ba thao tác dạng primitive: • Khởi động giá trị - init( ); • Giảm giá trị - down( ) / wait( ) / P( ); • Tăng giá trị - up( ) / signal( ) / V( ); 66 Semaphore (tt)  Khởi động – init( ): • Semaphore nhận giá trị khơng âm  Giảm – down( ): • Giảm giá trị semaphore 1 đơn vị • Nếu semaphore âm thì process gọi thao tác down() sẽ bị blocked, và vào hàng đợi semaphore  Tăng – up( ): • Tăng giá trị semaphore 1 đơn vị • Nếu semaphore khơng dương thì cĩ 1 process trong hàng đợi semaphore được chuyển sang trạng thái ready 67 Semaphore (tt) struct semaphore { int count; queueType queue; } void down(semaphore s) { s.count--; if (s.count < 0) { đưa process vào s.queue; block process; } } void up(semaphore s) { s.count++; if (s.count <= 0) { lấy 1 process P ra khỏi s.queue; đưa process P vào read queue; } } 68 b.Ứng dụng semaphore xử lý loại trừ tương hỗ Giải quyết trường hợp n process  n process dùng chung một semaphore s, khởi động s = 0 Cấu trúc process Pi: while (TRUE) { down(s); // kiểm tra điều kiện critical_region(); // vùng tranh chấp up(s); // thơng báo trạng thái noncritcal_region(); // vùng khơng tranh chấp } 69 c. Ứng dụng semaphore trong đồng bộ giữa các process  Bài tốn producer/consumer: • Hai process dùng chung một buffer kích thước hữu hạn • Một process ghi dữ liệu vào buffer: producer • Một process đọc dữ liệu từ buffer: consumer  Nhận xét: • Buffer cĩ dạng xoay vịng (circular buffer) • Nếu producer nhanh hơn: mất dữ liệu • Nếu consumer nhanh hơn: trùng dữ liệu 70 Buffer kích thước hữu hạn, xoay vịng 71 Giải bài tốn producer/consumer dùng semaphore #define N 100 // kích thước buffer typedef int semaphore // kiểu semaphore semaphore mutex = 1; // loại trừ tương hỗ semaphore empty = N; // số phần tử trống semaphore full = 0; // số phần tử cĩ dữ liệu 72 Giải bài tốn producer/consumer (tt) void producer(void) { int item; // phần tử dữ liệu while (TRUE) { produce_item(&item); // tạo dữ liệu down(&empty); // giảm số phần tử trống down(&mutex); // vào vùng tranh chấp enter_item(item); // ghi dữ liệu up(&mutex); // rời vùng tranh chấp up(&full); // tăng số phần tử cĩ dữ liệu } } 73 Giải bài tốn producer/consumer (tt) void consumer(void) { int item; // phần tử dữ liệu while (TRUE) { down(&full); // giảm số phần tử cĩ dữ liệu down(&mutex);// vào vùng tranh chấp remove_item(&item); // đọc dữ liệu up(&mutex); // rời vùng tranh chấp up(&empty); // tăng số phần tử trống consume_item(item); // xử lý dữ liệu } } 74 d. Khái niệm mutex Giá trị semaphore cĩ thể: • Số nguyên  counting semaphore • 0, 1  binary semaphore Binary semaphore được hiện thực đơn giản hơn, cịn gọi là biến mutex Các thao tác trên mutex • mutex_lock( ), tương đương down ( ) • mutex_unlock( ), tương đương up ( ) 75 Mutex struct mutex { enum {zero, one} value; queueType queue; } void mutex_lock(mutex m) { if (m.value == 1) m.value = 0 else { đưa process vào s.queue; block process; } } void mutex_unlock(mutex m) { if (m.queue.is_empty()) m.value = 1; else { lấy 1 process P ra khỏi s.queue; đưa process P vào read queue; } } 76 Loại trừ tương hỗ dùng mutex while (TRUE) { mutex_lock(m); // kiểm tra điều kiện critical_region(); // vùng tranh chấp mutex_unlock(m); // thơng báo trạng thái noncritcal_region();// vùng khơng tranh chấp } 77 5. Vấn đề đồng bộ giữa các process Bài tốn Dining Philosophers  Cĩ 5 triết gia ngồi quanh 1 bàn trịn  Mỗi triết gia cĩ 1 đĩa thức ăn, khi ăn cần 2 nĩa 78 Bài tốn Dining Philosophers (tt) Hoạt động của triết gia: luân phiên giữa suy nghĩ và ăn • Khi triết gia đĩi: cần nĩa trái và nĩa phải đồng thời, nếu cĩ 2 nĩa thì ăn • Sau khi ăn thì trả 2 nĩa, tiếp tục suy nghĩ Nếu 5 triết gia đồng thời cầm nĩa trái, chờ nĩa phải: deadlock Nếu 5 triết gia đồng thời trả nĩa trái, suy nghĩ, đồng thời cầm nĩa phải: starvation 79 IV. ðiều phối 1. Khái niệm 2. Các phương pháp điều phối 3. Ví dụ 4. ðiều phối thread 80 1. Khái niệm  ðiều phối (scheduling): • Xác định thời điểm và • Chọn process được thực thi  Do bộ điều phối (scheduler) thực hiện  Các dạng điều phối trên hệ thống đa chương: • Thời gian dài: liên quan việc tạo process mới • Thời gian trung bình: liên quan việc đưa process và, ra bộ nhớ • Thời gian ngắn: chọn ready process để cho thực thi 81 Các chiến lược điều phối Khơng dừng process đang thực thi • Nonpremptive scheduling • Khơng thích hợp với hệ thống cĩ tương tác (interactive system) Dừng process đang thực thi • Premptive scheduling 82 Các dạng hàng đợi và điều phối process 83 Các dạng process khi điều phối a. Chủ yếu sử dụng CPU – Processor-bound process b. Chủ yếu thực hiện I/O – I/O-bound process 84 2. Các phương pháp điều phối thời gian ngắn a. ðộ ưu tiên (Priorities) b. First-In-First-Out (FIFO) c. Round Robin (RR) d. Shortest Job First (SJF) e. Shortest Remaining Time (SRT) f. Multi-level Feedback Queues (MFQ) 85 a. ðộ ưu tiên Mỗi process cĩ độ ưu tiên  Process cĩ độ ưu tiên cao nhất được cho thực thi: • Khơng kể process mới  nonpreemptive • Kể cả process mới  preemptive  Process cĩ độ ưu tiên thấp cĩ thể chờ mãi mãi (starvation): • Tăng độ ưu tiên của process chờ theo thời gian (aging) 86 b. First-In-First-Out (FIFO) Dạng nonpreemptive • Cịn gọi là First-Come-First-Serve (FCFS) Các process được thực thi theo thứ tự xuất hiện tại hàng đợi ready RQ CPU 87 c. Round Robin (RR)  Dạng preemptive  Mỗi process được thực thi trong một đơn vị thời gian q (quantum)  Nếu process chưa kết thúc trong thời gian q thì bị dừng, đưa về cuối hàng đợi ready  Process đang ở đầu của hàng đợi được chọn để thực thi (theo FIFO) CPURQ 88 Round Robin (tt) Nếu q đủ lớn: trở thành FIFO Nếu q nhỏ: chi phí chuyển trạng thái là đáng kể 89 d. Shortest Job First (SJF) Dạng nonpreemptive Cần biết trước thời gian thực thi của các process  Process cĩ thời gian thực thi ngắn nhất được cho thực thi Giảm thời gian chờ trung bình của các process vì process ngắn chờ ít 90 e. Shortest Remaining Time (SRT) Dạng preemptive  Process cĩ thời gian thực thi đến kết thúc (remaining time) nhỏ nhất được cho thực thi, kể cả process mới Cần nhiều chi phí chuyển trạng thái Process cĩ thời gian thực thi lớn phải chờ lâu 91 f. Multi-level Feedback Queues (MFQ) Dạng preemptive Cĩ n hàng đợi RQ0..RQn-1 • RQ0..RQn-1 : theo FIFO • RQn-1: theo Round Robin Về độ ưu tiên RQi > Rqi+1 Về thời gian tqi < tqi+1 92 MFQ (tt) RQ0 RQ1 RQn-1 tq0 tq1 tqn-1 Round Robin FIFO FIFO 93 Xét hoạt động của process P  Vào hệ thống tại cuối RQ0  P được thực thi khi tiến đến đầu RQ0  Nếu P chưa kết thúc trong tq0, P bị dừng và vào cuối tq1  P sẽ được thực thi nếu: • P tiến đến đầu tq1 • tq0 rỗng  Cứ tiếp tục như vậy cho đến khi P vào RQn-1, hoạt động theo round robin 94 Nhận xét  Tự động phát hiện bản chất process: • Ưu tiên cho process cĩ thời gian ngắn Giả sử P cĩ yêu cầu I/O, P rời hệ thống tại RQi. Khi P trở lại hệ thống: • Nếu vào cuối RQ0  Ưu tiên cho process dạng I/O-bound • Nếu vào cuối RQi  Ưu tiên cho process dạng processor-bound 95 3. Ví dụ 28P5 56P4 44P3 62P2 30P1 Thời gian thực thi Thời điểm xuất hiện Process 96 Qui ước Cách biểu diễn hàng đợi  Trong phương pháp round robin: • Nếu cĩ process mới đưa vào cuối hàng đợi đồng thời với process hết thời gian thì ưu tiên cho process mới P5 P4 P3 5,4,3 RQ 97 FIFO 0 5 10 15 20 P1 P2 P3 P4 P5 2 3 4,3 5,4,3 5,4 5 P1 P2 P3 P4 P5 98 Round Robin q=4 0 5 10 15 20 P1 P2 P3 P4 P5 2 3 4,3 2,4 5,2,4 5,2 4,5 4 P1 P2 P2P3 P4 P4P5 99 SJF 0 5 10 15 20 P1 P2 P3 P4 P5 2 3 4,3 5,4,3 4,3 4 P1 P2 P5 P3 P4 100 SRT 0 5 10 15 20 P1 P2 P3 P4 P5 P1 cịn 1 P2 cịn 6 P2 cịn 5 P3 cịn 4 P2 cịn 5 P3 cịn 2 P4 cịn 5 P2 cịn 5 P4 cịn 5 P5 cịn 2 P1 P2P2 P3 P4P5 101 4. ðiều phối thread Khi các process cĩ nhiều thread  cần hai cấp điều phối: process, thread  Phụ thuộc dạng hiện thực thread: • Cấp user (user-level) • Cấp kernel (kernel-level) • Dạng tổ hợp 102 Ví dụ: điều phối thread dạng user-level Mỗi process được thực thi trong 50 milisec Mỗi thread được thực thi trong 5 milisec 103 Ví dụ: điều phối thread dạng kernel-level Mỗi process được thực thi trong 50 milisec Mỗi thread được thực thi trong 5 milisec HỆ ðIỀU HÀNH Chương 3 DEADLOCK 2Nội dung chương 3 I. Các khái niệm II. Phát hiện và phục hồi từ deadlock III. Ngăn chặn deadlock IV. Tránh deadlock 3I. Các khái niệm Deadlock là trạng thái hệ thống: • Tập hợp các process bị chờ mãi mãi • Mỗi process chờ biến cố chỉ cĩ được từ một process khác trong tập hợp Nguyên nhân tạo deadlock: • Các process cĩ dùng chung tài nguyên • Các process cĩ truyền thơng 4Ví dụ Hệ thống cĩ 2 ổ đĩa: • Mỗi process P0, P1 giữa một ổ đĩa và chờ ổ đĩa kia  Semaphore A và semaphore B khởi động là 1: P0 P1 down(A); down(B); down(B); down(A); 5Các dạng tài nguyên Cĩ thể lấy lại từ process • Preemptable resources, ví dụ: CPU, bộ nhớ Khơng lấy lại từ process • Nonpreemptable resources, ví dụ: máy in Các bước sử dụng tài nguyên • Process yêu cầu tài nguyên • Nếu được cấp phát thì sử dụng (process giữ tài nguyên), nếu khơng thì chờ • Process trả lại tài nguyên 6Các điều kiện dẫn đến deadlock  Loại trừ tương hỗ (mutual exclusion) • Chỉ 1 process được sử dụng tài nguyên chung tại một thời điểm • Tài nguyên hoặc được dùng bởi 1 process hoặc chưa cấp phát  Giữ và chờ tài nguyên (hold and wait) • Process đang giữ tài nguyên được quyền yêu cầu thêm tài nguyên khác  Khơng lấy lại tài nguyên (no preemption) • Khơng lấy lại tài nguyên đã cấp cho process  Tồn tại vịng chờ các process (circular wait) • Các process tạo thành một vịng chờ 7Các chiến lược giải quyết deadlock Khơng giải quyết • Giải thuật đà điểu (ostrich algorithm)  Phát hiện, phục hồi (detection, recovery) Ngăn chặn (prevention) • Loại bỏ các điều kiện tạo deadlock  Tránh (avoidance) • Chấp nhận các điều kiện tạo deadlock, theo dõi và kiểm sốt 8Giải thuật đà điểu Coi như khơng cĩ vấn đề deadlock Dựa trên cơ sở: • Deadlock rất ít xảy ra • Chi phí giải quyết rất cao ðược dùng trên các hệ điều hành: • UNIX • Windows 9II. Phát hiện và phục hồi từ deadlock  Phát hiện deadlock: • Dùng các giải thuật phát hiện vịng chờ các process • Do người quản trị hệ thống  Phục hồi từ deadlock: • Kết thúc các process bị deadlock • Lấy lại tài nguyên từ process • Phục hồi các điểm kiểm tra 10 Kết thúc các process bị deadlock Kết thúc tất cả các process bị deadlock  Lần lượt kết thúc các process bị deadlock cho đến khi hết deadlock  Thơng số chọn process để kết thúc: • ðộ ưu tiên • Thời gian đã thực thi • Thời gian cịn lại • Số tài nguyên đã cấp phát • Số tài nguyên đang chờ 11 Lấy lại tài nguyên từ process  Lần lượt lấy lại tài nguyên đã cấp phát cho các process cho đến khi hết deadlock • Phụ thuộc bản chất của tài nguyên • Sử dụng cơng cụ của hệ điều hành 12 Phục hồi các điểm kiểm tra ðịnh kỳ tạo các điểm kiểm tra (checkpoint) • Lưu trạng thái hệ thống tại điểm kiểm tra  Thực hiện lại (rollback) các process bị deadlock tại các điểm kiểm tra  Lần lượt thực hiện lại các process bị deadlock tại các điểm kiểm tra cho đến khi hết deadlock 13 III. Ngăn chặn deadlock  Loại bỏ các điều kiện dẫn đến deadlock Các điều kiện xem như khơng thể loại bỏ: • Loại trừ tương hỗ • Khơng lấy lại tài nguyên từ process 14 Loại bỏ điều kiện loại trừ tương hỗ Giảm số tài nguyên tranh chấp • Tăng số lượng tài nguyên Cấp phát tài nguyên dạng spool • Ví dụ: chỉ 1 printer daemon dùng máy in • Các process gởi yêu cầu cho printer daemon 15 Loại bỏ điều kiện giữ và chờ tài nguyên Nguyên tắc: process khơng được giữ tài nguyên khi yêu cầu tài nguyên mới • Process khai báo tài nguyên và được cấp phát 1 lần • Nếu process yêu cầu tài nguyên và khơng dược cấp phát thì phải trả các tài nguyên đang giữ 16 Loại bỏ điều kiện khơng lấy lại tài nguyên  Lấy lại tài nguyên từ process Khơng thể với tài nguyên như máy in 17 Loại bỏ vịng chờ các process Cĩ thể quy định số thứ tự tài nguyên • Process chỉ được yêu cầu tài nguyên theo thứ tự tăng Giả sử cĩ deadlock: • P1 giữ Ri, chờ Rj  i < j • P2 giữ Rj, chờ Ri  j < i 18 IV. Tránh deadlock Chấp nhận các điều kiện tạo deadlock  Theo dõi và tránh dẫn đến deadlock Hai hướng giải quyết: • Khơng tạo process mới nếu cĩ thể dẫn đến deadlock • Khơng cấp phát thêm tài nguyên cho process nếu cĩ thể dẫn đến deadlock 19 a. Khơng tạo process mới  Process cần khai báo số lượng tài nguyên cần sử dụng Khơng tạo process mới nếu số lượng tài nguyên hệ thống khơng đủ, cĩ thể dẫn đến deadlock 20 b. Khơng cấp phát thêm tài nguyên cho process  Liên quan đến việc sử dụng tài nguyên trong tương lai của các process ðịnh nghĩa trạng thái hệ thống với: • Vector E: tổng số các loại tài nguyên • Vector A: số tài nguyên mỗi loại chưa dùng • Ma trận C: số tài nguyên đã cấp phát cho các process • Ma trận R: số lượng tài nguyên các process sẽ tiếp tục yêu cầu 21 Hệ thống với n process và m loại tài nguyên 22 Ví dụ 23 Các điều kiện về định lượng  Tài nguyên hoặc đã cấp phát hoặc chưa sử dụng Khơng cĩ process nào yêu cầu nhiều hơn số tài nguyên hệ thống Khơng cĩ process nào được cấp phát nhiều hơn số lượng yêu cầu 24 Giải thuật ngân hàng / nhà băng  Trạng thái hệ thống (state): • Giá trị vector E, A và ma trận C, E  Trạng thái an tồn (safe state): • Tồn tại một thứ tự thực thi đến kết thúc tất cả các process  Trạng thái khơng an tồn (unsafe state): • Khơng phải là trạng thái an tồn 25 Giải thuật ngân hàng (tt)  Khi cĩ process yêu cầu thêm tài nguyên thì chỉ cấp phát nếu trạng thái hệ thống sau cấp phát là an tồn 1) Tìm một dịng trên ma trận R nhỏ hơn hay bằng A. Nếu khơng cĩ dịng nào như vậy thì hệ thống sẽ dẫn đến deadlock 2) Giả sử process tương ứng với dịng đã chọn kết thúc, thêm các tài nguyên của process này đang giữ vào A 3) Lập lại bước 1 và 2 cho đến khi mọi process kết thúc, trạng thái là an tồn. Nếu khơng thì trạng thái khơng an tồn 26 Nhận xét về giải thuật ngân hàng  Tốt về lý thuyết Khĩ cài đặt thực tế: • Khĩ xác định yêu cầu về tài nguyên của process • Số lượng process thay đổi • Số lượng tài nguyên thay đổi • Chi phí lớn HỆ ðIỀU HÀNH Chương 4 QUẢN LÝ BỘ NHỚ 2Nội dung chương 4 I. Các khái niệm II. Quản lý bộ nhớ thực III. Quản lý bộ nhớ ảo 3I. Các khái niệm 1. Tổ chức thứ bậc của bộ nhớ 2. ðịa chỉ ơ nhớ 3. Quản lý bộ nhớ 4. Liên kết động 41. Tổ chức thứ bậc của bộ nhớ  Chương trình phải được nạp vào bộ nhớ để thực thi  Tổ chức bộ nhớ: • Các thanh ghi (registers) • Thời gian truy xuất theo chu kỳ (CPU clock) • Cache • Giúp CPU truy xuất bộ nhớ nhanh hơn • Bộ nhớ trong • Thời gian truy xuất nhiều chu kỳ • Bộ nhớ ngồi • ðĩa từ, CD, • Băng từ, 52. ðịa chỉ ơ nhớ  Process cần địa chỉ của lệnh và dữ liệu trên bộ nhớ  Thời điểm tạo địa chỉ: • Khi dịch chương trình • Khi nạp chương trình • Khi thực thi chương trình 6ðịa chỉ lệnh và dữ liệu 7Các bước xử lý chương trình ứng dụng 8ðịa chỉ luận lý, địa chỉ vật lý ðịa chỉ luận lý (logical address): • Liên kết với một khơng gian địa chỉ vật lý riêng biệt • Do CPU tạo ra ðịa chỉ vật lý (physical address): • Liên kết với bộ nhớ vật lý • ðược đơn vị quản lý bộ nhớ sử dụng Chương trình của user chỉ dùng địa chỉ luận lý 93. Quản lý bộ nhớ Khối quản lý bộ nhớ của hệ điều hành: • Cấp phát/thu hồi bộ nhớ đối với process • Quản lý việc sử dụng bộ nhớ ðơn vị quản lý bộ nhớ (MMU, Memory Management Unit) của CPU: • Các mơ hình bộ nhớ • Hỗ trợ chuyển đổi địa chỉ 10 Các mơ hình bộ nhớ Bộ nhớ thực • Khơng sử dụng bộ nhớ ngồi • Cĩ sử dụng bộ nhớ ngồi Bộ nhớ ảo (virtual memory) 11 4. Liên kết động Dynamic loading • Chỉ nạp thủ tục.hàm khi được gọi • Phù hợp với các chương trình lớn • Khơng cần hỗ trợ của hệ điều hành Dynamic linking – Liên kết động • Chỉ liên kết trong thời gian thực thi • Hệ điều hành cần quản lý hàm/thủ tục trong khơng gian địa chỉ của process • Phù hợp với thư viện  shared libraries 12 II. Quản lý bộ nhớ thực 1. Dạng đơn chương 2. Dạng đa chương kích thước đoạn cố định 3. Dạng đa chương kích thước đoạn khơng cố định 13 1. Dạng đơn chương Cĩ 1 chương trình ứng dụng trên bộ nhớ Hệ điều hành nạp chương trình vào vùng nhớ xác định Khi chương trình kết thúc, hệ điều hành nạp chương trình khác thay thế Ví dụ: DOS 14 Hệ điều hành và một chương trình ứng dụng 15 16 2. Dạng đa chương kích thước đoạn cố định Bộ nhớ được chia thành các vùng (partition) kích thước cố định, khơng cần bằng nhau Cĩ nhiều process trên bộ nhớ đồng thời • Cĩ thể đưa process ra bộ nhớ ngồi (swapping) Kích thước các vùng nhớ cố định  cĩ sự phân mảnh bên trong (internal fragmentation) 17 Ví dụ: a. Dùng nhiều hàng đợi b. Dùng 1 hàng đợi 18 Swapping 19 ðịnh vị lại (relocation), bảo vệ (protection)  Process cĩ thể nạp vào vùng nhớ kích thước phù hợp Cĩ thể dùng địa chỉ dạng base+offset • Cần định vị lại khi nạp process vào vùng nhớ khác Bảo vệ bộ nhớ bằng cách dùng giới hạn kích thước vùng nhớ (limit) • Nếu process cĩ quyền dùng địa chỉ tuyệt đối thì khơng thể bảo vệ bộ nhớ 20 Base và limit 21 3. Dạng đa chương kích thước đoạn khơng cố định Các process được cấp phát vùng nhớ bằng với kích thước process • Cĩ nhiều process đồng thời trên bộ nhớ • Cĩ thể đưa process ra bộ nhớ ngồi Khơng cịn phân mảnh bên trong  Sau một thời gian hoạt động sẽ cĩ phân mảnh bên ngồi (external fragmentation) do kích thước process khác nhau 22 Ví dụ Các process được nạp và bị xĩa trên bộ nhớ 23 Giải quyết phân mảnh bên ngồi ðịnh kỳ dùng chương trình thu gom các khoảng trống (hole) đưa về một phía của bộ nhớ • Memory compaction, garbage collection 24 Quản lý tình trạng bộ nhớ Quản lý vùng nhớ đã cấp phát (partition), vùng nhớ trống (hole) Hai kỹ thuật: • Dùng bit-map • Dùng danh sách liên kết 25 Ví dụ a. 5 process và 3 khoảng trống b. Bit-map c. Danh sách liên kết 26 Nạp process vào bộ nhớ Hệ điều hành chọn khoảng trống phù hợp để nạp process vào bộ nhớ • Các phương pháp chính: First-Fit, Next-Fit, Best-Fit  First-Fit • Tìm từ vị trí đầu bộ nhớ • Chọn khoảng trống đầu tiên đạt yêu cầu • Nhanh nhất 27 Nạp process vào bộ nhớ (tt) Next-Fit • Tìm từ vị trí lần cấp phát trước • Chọn khoảng trống tiếp theo đạt yêu cầu • Cần lưu vị trí cấp phát Best-Fit • Tìm trên tồn bộ nhớ • Chọn khoảng trống nhỏ nhất đạt yêu cầu • Chậm nhất 28 Ví dụ: process mới kích thước 16M 29 III. Quản lý bộ nhớ ảo 1. Khái niệm bộ nhớ ảo 2. Bộ nhớ ảo dạng phân trang 3. Bộ nhớ ảo dạng phân đoạn 4. Bộ nhớ ảo dạng phân đoạn cĩ phân trang 30 1. Khái niệm bộ nhớ ảo  Bộ nhớ ảo (virtual memory) là kỹ thuật do hệ điều hành thực hiện với hỗ trợ của phần cứng • Phân biệt địa chỉ luận lý (địa chỉ ảo) và địa chỉ vật lý  Chương trình được viết trên khơng gian địa chỉ ảo, là thơng số của CPU và hệ điều hành • CPU IA32: 246 bytes, Windows: 232 bytes  Khi thực thi: hệ điều hành nạp chương trình vào bộ nhớ, chuyển đổi địa chỉ ảo thành địa chỉ vật lý, thực thi trên bộ nhớ vật lý 31 Các đặc điểm của bộ nhớ ảo  Khơng gian địa chỉ ảo >> khơng gian địa chỉ vật lý • Chương trình cĩ thể lớn hơn bộ nhớ • Phù hợp với hệ thống đa chương  Chỉ cần phần đang thực thi của process nạp vào bộ nhớ • Phần cịn lại đặt trên đĩa  Cho phép dùng chung khơng gian địa chỉ giữa các process • Hỗ trợ liên kết động 32 Thư viện dùng chung sử dụng bộ nhớ ảo 33 Các dạng bộ nhớ ảo Bộ nhớ ảo dạng phân trang (paging) Bộ nhớ ảo dạng phân đoạn (segmentation) Bộ nhớ ảo dạng phân đoạn cĩ phân trang (paged segmentation / segmentation with paging) 34 2. Bộ nhớ ảo dạng phân trang a. Tổ chức phân trang b. Bảng trang c. Chuyển đổi địa chỉ d. Nạp trang e. Thay thế trang 35 a. Tổ chức phân trang  Khơng gian địa chỉ ảo chia thành các trang (page) • Kích thước vài KB, vài MB  Khơng gian địa chỉ vật lý bao gồm các khung trang (page frame/ frame) • Kích thước khung trang = kích thước trang • Các trang của một process khơng cần ở trên các khung trang liên tục  Cĩ bảng trang (page table) quản lý các trang • Mỗi process cĩ một bảng trang 36 Bảng trang Cĩ N dịng, với N là số trang  mỗi dịng tương ứng với 1 trang Cấu trúc 1 dịng: • Control bits: các bit điều khiển • Valid bit/Present bit Valid = 0 nếu trang chưa cĩ trên bộ nhớ Valid = 1 nếu trang đang cĩ trên bộ nhớ • Frame Number (Frame #) Số thứ tự khung trang đang chứa trang 37 Ví dụ Bộ nhớ ảo cĩ 8 trang, bộ nhớ vật lý cĩ 4 khung Bảng trang cĩ 8 phần tử 38 Các bit điều khiển  Bit R (referenced) • R=1 nếu trang cĩ được truy xuất trên bộ nhớ  Bit M (modified) • M=1 nếu trang cĩ được ghi trên bộ nhớ  39 b. Bảng trang Bảng trang cĩ kích thước lớn • Mỗi phần tử tương ứng một trang • Mỗi process cần 1 bảng trang Giải quyết: • Bảng trang nhiều cấp, ví dụ: IA32 • Bảng trang nghịch đảo (Inverted Page Table), ví dụ: PowerPC, IA64 Bảng trang luơn được truy xuất • Cache các phần tử trong CPU Ví dụ bảng trang 2 cấp Khơng gian địa chỉ ảo 32 bit Dùng 1 bảng trang cấp 1 và 210 bảng trang cấp 2 Process 12M chỉ cần 1 bảng trang cấp 1 và 3 bảng trang cấp 2 41 Ví dụ bảng trang 2 cấp (tt) 42 Bảng trang nghịch đảo  Số phần tử bằng số khung trang • Chỉ cần 1 bảng trên hệ thống • Vị trí trong bảng là frame number  Mỗi phần tử bao gồm: • Số thứ tự trang tương ứng • Thơng tin về process sở hữu trang (pid)  Truy xuất theo cơ chế hash • Cĩ chuỗi liên kết (chain) giải quyết trường hợp cĩ nhiều trang cùng số thứ tự trên bộ nhớ 43 Bảng trang nghịch đảo (tt) 44 c. Chuyển đổi địa chỉ ðịa chỉ ảo theo phân trang • Page Number: số thứ tự trang • Offset/Displacement: địa chỉ trong trang ðịa chỉ vật lý • Page Number: số thứ tự khung trang • Offset/Displacement: địa chỉ trong khung trang OffsetPage Number OffsetFrame Number 45 Sơ đồ chuyển đổi địa chỉ 46 Truy xuất theo địa chỉ ảo  Tách page # và offset từ địa chỉ ảo  Chuyển page # thành frame # bằng cách truy xuất bảng trang A. Tìm phần tử quản lý trang B. Kiểm tra valid bit 1. Valid = 1 a. Thay page # bằng frame # b. Truy xuất dữ liệu trên khung với vị trí offset 47 Truy xuất theo địa chỉ ảo (tt) 2. Valid = 0  lỗi trang a. Tìm trang trên đĩa b. Tìm một khung trống (cĩ thể phải thay thế trang nếu các khung đầy) c. Sao chép trang vào khung trống d. Cập nhật bảng trang (valid = 1, frame # mới) e. Thực hiện truy xuất như bước 1 48 Phần cứng hỗ trợ chuyển đổi địa chỉ ảo  TLB (Translation Look-aside Buffer) • Ở trong CPU • Cache các phần tử trên bảng trang Khi chuyển đổi địa chỉ, tìm phần tử quản lý trang trên TLB trước, nếu khơng cĩ thì tìm trên bảng trang 49 Sơ đồ chuyển đổi địa chỉ với TLB 50 Xử lý lỗi trang 51 d. Nạp trang Nạp theo yêu cầu (demand paging) • Nạp trang khi cĩ lỗi trang Nạp trước(prepaging) • Nạp trước các trang của process theo một điều kiện xác định 52 Nạp trang trên Windows XP  Nạp trang theo yêu cầu với clustering • Nạp các trang xung quanh trang cĩ lỗi  Các process cĩ thơng số • Working set minimum: số trang tối thiểu được cĩ trên bộ nhớ • Working set maximum: số trang tối đa được cĩ trên bộ nhớ  Khi bộ nhớ khơng đủ thì đưa các trang của các process ra đĩa theo cơ chế automatic working set trimming 53 e. Thay thế trang Khi các khung đã đầy mà cần nạp thêm trang thì phải thay thế một trang đang cĩ trên khung • Nếu trang bị thay thế cĩ thay đổi nội dung thì phải đưa ra đĩa Cĩ các phương pháp chọn phần tử thay thế: Optimal, FIFO, LRU (thơng dụng), Second Chance, Clock 54 Các phương pháp thay thế trang Optimal • Chọn trang sẽ khơng được truy xuất khoảng thời gian xa nhất • Khơng hiện thực được • Dùng để đánh giá các phương pháp khác  FIFO • Chọn trang nạp vào bộ nhớ đầu tiên • Dùng hàng đợi quản lý số thứ tự trang: • Khi nạp trang: đưa vào cuối hàng đợi • Khi thay thế: chọn trang tại đầu hàng đợi 55 Các phương pháp thay thế trang (tt)  LRU (Least Recently Used) • Chọn trang đã khơng được truy xuất trong khoảng thời gian lớn nhất • Hiện thực: • Dùng hàng đợi: khi cĩ truy xuất trang thì đưa trang về cuối hàng đợi (tương đương trang mới) • Dùng thêm một biến counter, lưu thời điểm truy xuất. Khi thay thế chọn trang cĩ counter nhỏ nhất 56 Các phương pháp thay thế trang (tt)  Second Chance • Cải tiến FIFO • Khi cần thay thế, xét trang tại vị trí đầu hàng đợi: • Nếu bit R = 0 thì thay thế trang • Nếu bit R = 1 thì đưa trang về cuối hàng đợi, xét trang tiếp theo cho đến trang cho R=0 57 Các phương pháp thay thế trang (tt) Clock • Tương tự Second Chance • Các trang được quản lý theo danh sách liên kết xoay vịng • Cĩ 1 con trỏ chỉ đến trang đầu tiên • Khi cần thay thế thì xét trang tại vị trí con trỏ: • Nếu bit R = 0 thì đưa thay thế trang, xoay con trỏ 1 đơn vị • Nếu bit R = 1 thì xĩa R = 0, xoay con trỏ 1 đơn vị, xét trang tiếp theo cho đến trang cho R=0 58 Ví dụ các phương pháp thay thế trang Bộ nhớ cĩ 3 khung trang rỗng Các trang được truy xuất theo thứ tự: 2 3 2 1 5 2 4 5 3 2 5 2 59 Sơ đồ các trang trên các khung trang 333344111 5*5*555*555333 2*2*2*22*2*2*22*2*22CLOCK 2*22444111 55*555*555333 3333222*222*22LRU 244444111 552*22223333 33335*55522*22FIFO 55*555*5551 3333*3333333 2*224442*222*22OPT 252354251232 60 3. Bộ nhớ ảo dạng phân đoạn Tổ chức phân đoạn Bộ nhớ ảo bao gồm các đoạn (segment) cĩ kích thước khơng cố định Khi nạp đoạn vào bộ nhớ thì hệ điều hành tìm khoảng trống đủ để nạp đoạn Cĩ bảng đoạn quản lý các đoạn 61 Nhận xét về phân trang, phân đoạn  Trang trong suốt đối với người lập trình  Phân trang tránh được phân mảnh bên ngồi Người lập trình sử dụng được đoạn  Phân đoạn phù hợp với lập trình theo khối, cấu trúc dữ liệu thay đổi, dùng chung và bảo vệ bộ nhớ 62 4. Bộ nhớ ảo dạng phân đoạn cĩ phân trang Kết hợp các ưu điểm của phân đoạn và phân trang Tổ chức: Bộ nhớ ảo bao gồm các đoạn  Trong mỗi đoạn thực hiện phân trang 63 Ví dụ: bộ nhớ ảo trên Pentium ðơn vị quản lý bộ nhớ (Memory Management Unit, MMU) • ðơn vị phân đoạn, (đoạn đến 232 bytes) • ðơn vị phân trang Các mơ hình bộ nhớ • Khơng phân đoạn, khơng phân trang • Khơng phân đoạn, cĩ phân trang • Cĩ phân đoạn, khơng phân trang • Cĩ phân đoạn, cĩ phân trang 64 Chuyển đổi địa chỉ ðịa chỉ ảo dạng phân đoạn: • Selector – 16 bit • Offset – 32 bit ðịa chỉ tuyến tính (linear address) ðịa chỉ vật lý 65 Cấu trúc selector GDT (Global Descriptor Table): dùng cho HDH LDT (Local Descriptor Table): dùng cho các chương trình Privilege level: mức đặc quyền 66 Chuyển đổi địa chỉ đoạn địa chỉ tuyến tính 67 Chuyển đổi địa chỉ tuyến tính địa chỉ vật lý 68 Ứng dụng mức đặc quyền HỆ ðIỀU HÀNH Chương 5 QUẢN LÝ XUẤT NHẬP 2Nội dung chương 5 I. Nguyên lý phần cứng xuất nhập II. Tổ chức phần mềm xuất nhập III. ðĩa từ IV. Clock 3I. Nguyên lý phần cứng xuất nhập 1. Thiết bị xuất nhập (I/O devices) 2. Mạch điều khiển (controller) 3. ðịa chỉ thiết bị I/O 4. Interrupt 5. DMA (Direct Memory Access) 41. Thiết bị xuất nhập • Block devices – Thiết bị dạng khối • Thơng tin lưu theo khối, khối cĩ địa chỉ • ðọc ghi theo từng khối độc lập • Ví dụ: đĩa từ • Character devices – Thiết bị dạng ký tự • Thơng tin truyền theo chuỗi ký tự • Khơng cĩ địa chỉ • Ví dụ: bàn phím, card mạng, chuột, • Abstract devices - Các thiết bị trừu tượng • Khơng là hai dạng trên • Ví dụ: file system, clock 5Tốc độ tiêu biểu của các thiết bị I/O 62. Mạch điều khiển (controller)  Thiết bị I/O gồm cĩ: • Thành phần cơ khí • Thành phần điện  Thành phần điện  mạch điều khiển • Cĩ thể điều khiển nhiều thiết bị Nhiệm vụ mạch điều khiển: • Chuyển đổi dữ liệu (bits, streams, blocks) • Kiểm sốt lỗi (nếu cần thiết) • Tồn tại trong kiến trúc hệ thống 7Mạch điều khiển (tt) Mạch điều khiển kết nối với I/O bus  Thiết bị nối với mạch điều khiển  Thơng số: • ðịa chỉ (theo phương pháp xuất nhập) • Tập lệnh điều khiển  Phần mềm điều khiển thiết bị thơng qua mạch điều khiển với tập lệnh • Ví dụ: FDC Floppy Disk Controller cĩ các lệnh SEEK, READ, WRITE, FORMAT, 83. ðịa chỉ thiết bị I/O Memory mapped I/O • Thiết bị và bộ nhớ dùng chung một khơng gian địa chỉ • Xuất nhập tương đương đọc ghi bộ nhớ • Khơng cần lệnh I/O  Isolated I/O • Dùng khơng gian địa chỉ riêng • Cần tín hiệu điều khiển I/O riêng • Cần các lệnh I/O 9ðịa chỉ I/O (tt) a. ðịa chỉ bộ nhớ và địa chỉ I/O phân biệt b. Memory-mapped I/O c. Dạng tổ hợp (hybrid) 10 4. Interrupt Cần interrupt controller và interrupt handler CPU yêu cầu xuất nhập  Thiết bị yêu cầu ngắt quãng (interrupt) khi sẵn sàng  Thực thi chương trình xử lý ngắt  Thơng số thiết bị: • ðịa chỉ I/O • Yêu cầu ngắt (IRQ i) 11 Ví dụ 12 5. DMA  Cần cĩ DMA controller  CPU gởi yêu cầu xuất nhập cho DMAC  DMAC thực hiện trao đổi dữ liệu giữa bộ nhớ và thiết bị  Khi kết thúc, DMAC gởi tín hiệu ngắt quãng cho CPU  Thơng số thiết bị: • ðịa chỉ I/O • Yêu cầu ngắt (IRQ i) • Kênh DMA (DMA channel) 13 Ví dụ 14 II. Tổ chức phần mềm xuất nhập PHẦN CỨNG XỬ LÝ NGẮT QUÃNG CHƯƠNG TRÌNH ðiỀU KHIỂN THIẾT BỊ (Device Driver) PHẦN MỀM I/O CẤP HỆ ðIỀU HÀNH PHẦN MỀM I/O CẤP USER 15 Xử lý ngắt quãng  Process yêu cầu I/O bị blocked cho đến khi cĩ ngắt quãng Chương trình xử lý ngắt quãng thực thi, chuyển blocked process sang trạng thái ready 16 Chương trình điều khiển thiết bị Device driver chứa đoạn mã phụ thuộc từng loại thiết bị Device driver trao đổi dữ liệu với các thanh ghi trên mạch điều khiển, kiểm tra trạng thái thiết bị Ví dụ: Windows driver • Universal driver • Minidriver 17 Phần mềm I/O cấp hệ điều hành Các hàm I/O chung cho các thiết bị, tạo giao diện thống nhất cho phần mềm cấp user Giải quyết các vấn đề: • ðặt tên • Bảo vệ • Tổ chức buffer • Báo lỗi 18 Phần mềm I/O cấp user Các yêu cầu I/O được gọi thơng qua các hàm thư viện 19 Các lớp phần mềm I/O 20 III. ðĩa từ 1. Phần cứng đĩa từ 2. Các phương pháp điều phối đĩa từ 21 1. Phần cứng đĩa từ ðĩa từ • Hard drive Mạch điều khiển đĩa • Disk controller 22 ðĩa từ ðĩa cứng với 4 đĩa 23 Cấu trúc một mặt đĩa 24 Partitions 25 ðĩa từ (tt)  Track, Sector, Cylinder ðơn vị truy xuất: sector Các bước truy xuất sector: • Di chuyển hệ thống đầu từ đến cylinder chứa sector – Seek time (mili sec) • Chờ sector xoay đến vị trí đầu từ - Rotational latency (rpm) • Truy xuất sector  Thơng số tổng quát: tốc độ truy xuất (Data Transfer Rate) theo MB/sec 26 Mạch điều khiển đĩa Các chuẩn: • SCSI • IDE 27 SCSI (Small Computer System Interface) Dạng I/O bus, điều khiển nhiều loại thiết bị: đĩa cứng, CDROM, scanner, máy in .. Cĩ thể đến 15 thiết bị/cáp 28 IDE (Integrated Drive Electronics) Cịn gọi là ATA (AT Attachment)  EIDE (Extended IDE)  ATA-2 • 4 thiết bị • ðiều khiển CDROM • Hỗ trợ LBA (Logical Block Addressing) ATA-4  Ultra ATA • ATA-33/66/100 ..: tốc độ DMA là 33MHz/.. 29 Serial ATA (SATA)  Tốc độ cao, từ 150 MB/sec Chỉ điều khiển đĩa Dễ cài đặt 30 Serial ATA (tt) 31 2. Các phương pháp điều phối đĩa từ Cĩ thể cĩ nhiều yêu cầu truy xuất đĩa đồng thời • Cần chọn xử lý một yêu cầu tiếp theo Xử lý yêu cầu: di chuyển hệ thống đầu từ  ðiều phối đĩa từ Các phương pháp điều phối đĩa từ: • Random, Priority, FIFO • SSF, SCAN. C-SCAN 32 Các phương pháp điều phối đĩa từ (tt) Random: chọn yêu cầu ngẫu nhiên  Priority: chọn yêu cầu theo độ ưu tiên của process cĩ yêu cầu  FIFO: chọn yêu cầu theo thứ tự xuất hiện các yêu cầu  SSF (Shortest Seek First) • Chọn yêu cầu tiếp theo sao cho thời gian seek là ít nhất 33 Các phương pháp điều phối đĩa từ (tt)  SCAN – cịn gọi là elevator algorithm • Hệ thống đầu từ di chuyển theo 1 hướng • Xử lý các yêu cầu theo hướng này • Nếu hết yêu cầu hay đến cylinder cuối thì di chuyển theo hướng ngược lại  C-SCAN • Hệ thống đầu từ chỉ di chuyển theo 1 hướng • Xử lý các yêu cầu theo hướng này • Nếu hết yêu cầu hay đến cylinder cuối thì di chuyển nhanh về cylinder đầu tiên 34 Các phương pháp điều phối đĩa từ (tt)  Thực tế: • Nếu số yêu cầu ít: dùng SSF • Nếu số yêu cầu nhiều: dùng C-SCAN 35 Ví dụ các phương pháp điều phối đĩa từ Cĩ các yêu cầu (theo vị trí cylinder) xuất hiện theo thứ tự: 55 58 39 18 90 160 150 34 184 Vị trí hiện tại của hệ thống đầu từ là cylinder 100 36 Kết quả điều phối 9018184184 583416034 5539150150 395518160 34583490 18903918 1841845539 1601605858 1501509055 C-SCANSCANSSFFIFO 37 IV. Clock 1. Khái niệm 2. Phần cứng clock 3. Ứng dụng clock 38 1. Khái niệm Clock cịn gọi là timer • Là cơ sở cho các thao tác trên hệ thống chia sẻ thởi gian (time sharing) Clock dùng để tính thời gian, ngăn chặn việc chỉ một process sử dụng CPU Về hình thức clock là device driver • Khơng là dạng character, khơng là dạng block 39 2. Phần cứng clock Gồm các thành phần: • Bộ tạo dao động – Crystal oscillator • Bộ đếm – Counter • Thanh ghi – Holding register Cĩ hai chế độ hoạt động: • ðếm 1 lần – One-shot mode • ðếm liên tục – Square -ware mode 40 Phần cứng tạo clock - programmable clock 41 Chế độ đếm 1 lần Bộ đếm được đặt giá trị ban đầu Bộ đếm thực hiện đếm xuống Khi bộ đếm đạt 0 thì tạo ra một tín hiệu ngắt quãng 42 Chế độ đếm liên tục Bộ đếm và thanh ghi được đặt giá trị ban đầu Bộ đếm thực hiện đếm xuống Khi bộ đếm đạt 0 thì: • Tạo ra một tín hiệu ngắt quãng • Sao chép giá trị thanh ghi sang bộ đếm • Lập lại việc đếm xuống 43 3. Ứng dụng clock  Phần cứng clock tạo ra các ngắt quãng theo thời gian xác định Clock driver thực hiện các xử lý Các hệ điều hành cung cấp các thao tác về thời gian khác nhau 44 Các ứng dụng cơ bản của clock Duy trì thời gian • Khuơn dạng về thời gian phụ thuộc hệ điều hành ðiều phối process/thread • Clock tạo ra các ngắt quãng định kỳ  tương ứng với các đơn vị thời gian q  Tạo các timer cho phần mềm ứng dụng  Thực hiện các thao tác thống kê, giám sát hệ thống 45 Ví dụ: các dạng duy trì thời gian hệ thống 46 Ví dụ: tạo nhiều timer từ một clock 47 Ví dụ: Windows Task Manager 48 Ví dụ: Linux System Monitor HỆ ðIỀU HÀNH Chương 6 HỆ THỐNG FILE 2Nội dung chương 6 I. Khái niệm II. File III. Thư mục IV. Hiện thực hệ thống file V. Một số vấn đề về hệ thống file 3I. Khái niệm  File là đơn vị lưu trữ trên thiết bị nhớ ngồi: • Kích thước lớn • File tồn tại sau khi process tạo file kết thúc • File cĩ thể được truy xuất đồng thời từ nhiều process  File là sự trừu tượng hố dữ liệu khi ghi đọc đĩa • Che dấu chi tiết hoạt động trên đĩa 4Hệ thống file Hệ điều hành tổ chức và quản lý file theo hệ thống file (file system)  Thực hiện trên file: • Tạo cấu trúc • ðặt tên • Truy xuất • Bảo vệ 5Hệ thống file (tt) Một hệ điều hành thường hỗ trợ nhiều loại hệ thống file • Windows XP: FAT, NTFS, CDFS, UDF (Universal Disk Format), User quan tâm về file: • ðặt tên • Truy xuất • Bảo vệ 6II. File 1. Tên file 2. Cấu trúc file 3. Loại file 4. Thuộc tính file 5. Các thao tác trên file 71. Tên file Mỗi file cĩ tên (filename) theo quy định của hệ điều hành, ví dụ: • DOS  8.3 • Windows  long filename (<=255)  Tên file cĩ phần mở rộng (extensions) xác định loại file • Cĩ thể cĩ nhiều phần mở rộng 82. Cấu trúc file Các dạng chính (cấp thấp): • Chuỗi byte (byte sequence) • Chuỗi record (record sequence) • Cây record (record tree) Cấu trúc luận lý (cấp cao) do chương trình ứng dụng qui định • Ví dụ: field, record, file, database, 9Cấu trúc file (tt) a. Chuỗi byte b. Chuỗi record c. Cây record 10 3. Loại file  File thường (regular files) • Dạng nhị phân (binary) • Dạng văn bản (text)  Thư mục (folder, directory): file hệ thống  File đặc biệt (special files): trừu tượng hố thiết bị I/O • Dạng ký tự card mạng • Dạng khối  đĩa 11 Ví dụ: các dạng file nhị phân trên UNIX a. File thực thi b. File thư viện 12 4. Thuộc tính file  File cĩ tên, dữ liệu khi được tạo ra Hệ điều hành thêm các thuộc tính (attributes) cần thiết như date, time, • Các thuộc tính phụ thuộc hệ thống file 13 Các thuộc tính thơng dụng Name – Tên file  Identifier – Danh hiệu (Id)  Type – loại file  Location – Vị trí  Size – Kích thước  Protection – Dùng trong bảo vệ Date, Time – Các thơng tin về thời gian  14 5. Các thao tác trên file Các hệ điều hành cung cấp các thao tác trên file khác nhau • Dùng cho user  các thao tác trên File Manager • Dùng cho programmer  các lệnh gọi hệ thống (system calls) 15 Một số thao tác cơ bản trên file Ghi dữ liệu vào file tại vị trí hiện hànhWrite ðọc file tại vị trí hiện hànhRead Cần đĩng file sau khi sử dụngClose Cần mở file trước khi truy xuấtOpen Xố file. Cĩ thể xố tự động, phục hồiDelete Tạo file rỗng và đặt 1 số thuộc tínhCreate Ý nghĩaThao tác 16 Một số thao tác cơ bản trên file (tt) ðổi tên fileRename ðặt các thuộc tính của fileSet Attributes Lấy thuộc tính của fileGet Attributes Xác định nơi truy xuất fileSeek Ghi vào cuối fileAppend Ý nghĩaThao tác 17 III. Thư mục 1. Tổ chức thứ bậc của thư mục 2. Tên đường dẫn 3. Các thao tác trên thư mục 18 1. Tổ chức thứ bậc của thư mục  Thư mục (directory, folder) là file hệ thống dùng để quản lý hệ thống file  Thư mục bao gồm các phần tử (entry), tương ứng với các file trong thư mục, lưu các thơng tin: • Tên file • Các thuộc tính • 19 Tổ chức thứ bậc của thư mục (tt)  Tổ chức thơng dụng của thư mục: dạng hình cây, với thư mục gốc (root) Ví dụ • Windows: cây thư mục cho từng đĩa luận lý, hệ thống file trên mạng, • Linux chỉ cĩ 1 cây thư mục trên hệ thống • Cần phải mount các đĩa luận lý, hệ thống file trên mạng vào cây thư mục 20 Ví dụ: cây thư mục 21 Ví dụ: cây thư mục 22 Ví dụ: đồ thị thư mục 23 2. Tên đường dẫn Khi cĩ tổ chức thư mục thì cần thơng tin về vị trí file trên cây thư mục  tên đường dẫn (pathname) • Pathname = path + filename Ví dụ: • c:\windows\explorer.exe • /etc/samba/samba.conf 24 3. Các thao tác trên thư mục  Tương tự thao tác trên file, các thao tác trên thư mục khác nhau trên các hệ thống file 25 Một số thao tác cơ bản trên thư mục Cho phép file xuất hiện trong nhiều thư mục Link Trả lại phần tử tiếp theo trong thư mụcReaddir Cần đĩng thư mục sau khi sử dụngClosedir Cần mở thư mục trước khi truy xuất, tương đương liệt kê file trong thư mục Opendir Xố thư mục rỗngDelete Tạo thư mục rỗng với . và ..Create Ý nghĩaThao tác 26 IV. Hiện thực hệ thống file 1. Khái niệm 2. Hiện thực hệ thống file 27 1. Khái niệm Mỗi partition bao gồm các khối (block/cluster) gồm các sector liên tục: đơn vị cấp phát cho file • Mỗi khối cĩ địa chỉ Hiện thực hệ thống file: • Quản lý các khối thuộc về file • Quản lý khối chưa sử dụng (free blocks) • Quản lý khối khơng sử dụng được (bad blocks) 28 Ví dụ 29 Các dạng partition, logical drives 30 Các hệ thống file thơng dụng  FAT • Windows 9x, Windows 2K/XP/2K3 NTFS • Windows 2K/XP/2K3  I-node • UNIX • Linux  i-node extensions (Ext2, Ext3) 31 2. Hiện thực hệ thống file a. Dạng danh sách liên kết cĩ chỉ số (FAT) b. Dạng NTFS c. Dạng i-node 32 a. Dạng danh sách liên kết cĩ chỉ số Mỗi file gồm nhiều khối  Phần tử quản lý file trong thư mục cĩ địa chỉ khối đầu tiên của file Danh sách liên kết địa chỉ các khối của file được lưu trong 1 bảng, FAT (File Allocation Table) 33 FAT Mỗi partition theo dạng danh sách liên kết cĩ chỉ số cĩ 1 FAT: • Số phần tử bằng với số khối • Chứa danh sách liên kết các khối của tất cả các file • Quản lý các khối chưa sử dụng • Quản lý các khối khơng sử dụng được 34 Cấu trúc FAT partition Boot sector: mẩu tin khởi động • Các thơng số của partition • ðoạn chương trình khởi động  FAT  FAT2: bản sao của FAT Root folder: thư mục gốc Data • Dữ liệu các file • Các thư mục con (subfolders) 35 Cấu trúc partition theo FAT16 36 Cấu trúc partition theo FAT32 37 Ví dụ: bảng FAT File A  Cluster đầu tiên: 3  Các cluster của file A: 3  9  4  2 File B  Cluster đầu tiên: 5  Các cluster của file B: 5  7  8 38 Các thơng số Kích thước phần tử trên FAT • 16 bit: FAT16 • 32 bit: FAT32 Kích thước cluster • 512 bytes  64KB 39 Kích thước cluster mặc định FAT16 trên Windows 2000 40 Kích thước tối đa volume FAT32 trên Windows 2000 41 Các vấn đề trên FAT  Phân mảnh bên trong • Do kích thước đơn vị cấp phát cố định • Giải quyết: nén đĩa (disk compresstion)  Phân mảnh bên ngồi • Do thay thế file • Giải quyết: các chương trình cơng cụ dạng defragmentation/speeddisk 42 Thư mục trên FAT Mỗi file được quản lý bằng một phần tử trong thư mục (directory entry): • Tên, các thuộc tính • ðịa chỉ cluster đầu tiên của file 43 Phần tử trên thư mục – MSDOS  Filename, Extension: tên file và phần mở rộng  Attributes: các thuộc tính (readonly, hidden, system, archive, subdirectory)  Date, Time: ngày giờ tạo file  First block number: địa chỉ cluster đầu tiên của file  Size: kích thước file 44 Phần tử trên thư mục – Windows 98 Mở rộng phần tử trên thư mục MSDOS  NT: tương thích windows NT  ðịa chỉ cluster đầu tiên kích thước 32 bit  Sec: cĩ nhiều loại date/time  45 Ví dụ: phần tử trên thư mục với tên file dài Tên file: The quick brown fox jumps over the lazy dog 46 b. NTFS  Là hệ thống file chuẩn trên Windows NT/2K/XP/2K3 Cĩ nhiều ưu điểm: • Kích thước file, volume lớn • Cĩ khả năng phục hồi, nén, mã hố tốt • Bảo mật tốt • Truy xuất nhanh 47 Kích thước cluster mặc định NTFS trên Windows 2000 48 Cấu trúc NTFS partition  Boot sector: • Thơng tin về hệ thống file • Chương trình nạp file khởi động HDH (ntldr)  MFT: file quản lý hệ thống file  System files: các file hệ thống (metadata) 49 Các file hệ thống ðược tạo ra khi định dạng partition Gồm các file: • MFT, MFT mirror • Log file • Cluster Bitmap file (quản lý free blocks) • Boot file • Bad cluster file • 50 MFT (Master File Table) Quản lý hệ thống file trên NTFS partition Bao gồm các records (1KB) Mỗi file hay folder được quản lý bằng 1 hay nhiều MFT record • File, folder kích thước nhỏ (normal): 1 record • File, folder kích thước lớn (large): cĩ thêm các phần mở rộng 51 Cấu trúc MFT 52 Ví dụ: MFT record với file thường 9 blocks 53 Ví dụ: File kích thước lớn với 3 MFT records 54 Ví dụ: MFT record với thư mục thường 55 Tìm file trên MFT Tên file: C:\maria\web.htm 56 c. Dạng i-node Dùng trên hệ điều hành UNIX Mỗi file được quản lý bằng một bảng, gọi là i-node, lưu các thơng tin: • Loại file • Các thơng số về thời gian • Bảo vệ file • ðịa chỉ các khối của file 57 I-node (tt)  File kích thước nhỏ chỉ cần các địa chỉ khối trên i-node  File kích thước lớn cần thêm các khối gián tiếp (indirect block), chứa địa chỉ các khối của file 58 I-node (tt) 59 Kích thước UNIX file theo i-node 60 Directory và i-node 61 Cấu trúc partition theo i-node  Boot block: khối khởi động  Super block: thơng tin về hệ thống file  I-nodes: bảng các i-node  Data blocks: các khối dữ liệu 62 Ví dụ: các bước truy xuất /usr/ast/mbox 63 Hệ thống file trên Linux Xuất phát từ Minix file system  Phát triển với cấu trúc VFS trên kernel • Virtual File System Hiện thực thêm các hệ thống file theo dạng i-node: • Extended File System (Ext) • Second Extended File System (Ext2) 64 Cấu trúc VFS 65 Cấu trúc partition theo Ext2 Super block, Group descriptor: thơng tin hệ thống file Block bitmap: quản lý các khối i-node bitmap: quản lý bảng i-node I-nodes: bảng i-node Data blocks: các khối dữ liệu 66 Cấu trúc phần tử trên thư mục và ví dụ 67 V. Một số vấn đề về hệ thống file 1. Bảo vệ file 2. ðĩa luận lý 68 1. Bảo vệ file Nguyên tắc cơ bản: dùng access control list (ACL): • Liệt kê quyền truy xuất được phép của user, nhĩm user • Do người sở hữu file (owner) qui định • ACL thường được lưu trữ theo file như thuộc tính của file 69 Ví dụ: NTFS folder permissions 70 2. ðĩa luận lý Hệ thống file được hiện thực và tạo nên đĩa luận lý (logical drive) Khái niệm đĩa luận lý đa dạng theo các loại hệ điều hành 71 Một số dạng đĩa luận lý trên Windows Basic disk/volume: • 1 partition trên đĩa vật lý Dynamic disk/volume: cĩ thể tạo volume gồm nhiều đĩa vật lý • Spanned • Stripped (cịn gọl là RAID-0) • Mirrored (cịn gọl là RAID-1) • RAID-5 (Redundant Arrays of Inexpensive Disks -5) 72 Volume trên 2 đĩa – Volume set LCN: Logical Cluster Number 73 Strip Set trên 2 đĩa 74 Mirror set trên 2 đĩa 75 Strip Set with parity (RAID-5) trên 3 đĩa

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

  • pdftailieu.pdf