N: Interger; {số phần tử của Buffer}
I.6. Tiến trình trong Windows NT
Giới thiệu
Việc thiết kế tiền trình trong Windows NT được thực hiện từ nhu cầu cung cấp sự hỗ trợ cho nhiều môi trường hệ điều hành khác nhau. Các tiến trình được hỗ trợ bởi các hệ điều hành khác nhau có một số điểm khác nhau, bao gồm:
• Cách đặt tên cho các tiến trình.
• Có hay không các tiểu trình bên trong tiến trình. • Các tiến trình được thể hiện như thế nào.
• Các tài nguyên của tiến trình được bảo vệ như thế nào.
• Các chiến lược được sử dụng trong giao tiếp và đồng bộ tiến trình • Cách mà các tiến trình liên hệ với mỗi tiến trình khác
Do đó, các cấu trúc tiến trình và các dịch vụ ban đầu được cung cấp bởi kernel của windows NT là phải đạt mục tiêu đơn giản và tổng quát, cho phép mỗi hệ thống con hệ điều hành mô phỏng một cấu trúc tiến trình riêng và thiết thực. Các đặc tính quan trọng của các tiến trình windows NT là như sau:
• Các tiến trình NT được cài đặt như là các đối tượng.
• Một tiến trình có khả năng thi hành có thể chứa một hay nhiều tiểu trình. • Cả các đối tượng tiến trình và tiểu trình có sẵn khả năng đồng bộ.
• Kernel của Windows NT không duy trì mối quan hệ nào giữa các tiến trình mà nó đã tạo ra, kể cả các mối quan hệ cha con.
Hình sau đây minh hoạ cách một tiến trình liên hệ với các tài nguyên nó điều khiển hoặc sử dụng.
• Thẻ (token) truy xuất, kiểm tra xem tiến trình có thể thay đổi các đặc tính của riêng nó hay không. Trong trường hợp này, tiến trình không có một handle được mở cho token truy xuất của nó. Nếu tiến trình cố gắng mở một handle như thế, hệ thống an toàn sẽ quyết định cho phép hay không, và do đó tiến trình có thể thay đổi các đặc tính riêng của nó hay không.
Process
Access token
Hình 2.8: Tiến trình và các tài nguyên của nó Handle 1
Handle 2 Handle 3 Thread x Section x File y Object Table Available Object
Không gian địa chỉ ảo
• Liên quan đến tiến trình là một dãy các block định nghĩa không gian địa chỉ ảo đang được kết gán cho tiến trình đó. Tiến trình không thể trực tiếp sửa đổi các cấu trúc này mà phải dựa vào thành phần quản lý bộ nhớ ảo, trình quản lý bộ nhớ cung cấp dịch vụ định vị bộ nhớ cho tiến trình.
• Cuối cùng, tiến trình bao gồm một bảng đối tượng, với các handle đến các đối tượng khác liên quan đến tiến trình này. Một handle tồn tại cho mỗi tiểu trình chứa trong đối tượng này. Trong hình này, tiến trình có một tiểu trình đơn. Ngoài ra, tiến trình truy xuất đến một đối tượng file và đến một đối tượng section mà nó xác định một section bộ nhớ chia sẻ.
Các đối tượng tiến trình và tiểu trình
Cấu trúc hướng đối tượng của windows NT làm cho việc phát triển tiến trình của nó được dễ dàng hơn. Windows NT có hai kiểu đối tượng liên quan đến tiến trình:
các tiến trình và tiểu trình. Một tiến trình là một thực thể tương ứng với một công việc của người sử dụng hay ứng dụng mà nó sở hữu các tài nguyên, như bộ nhớ, và các tập tin được mở. Một tiểu trình là một đơn vị có thể điều phối, sự thực thi của nó có thể được thực hiện tuần tự hay bị ngắt, do đó processor có thể chuyển từ tiểu
trình này sang tiểu trình khác.
Mỗi tiến trình windows NT được thể hiện bởi một đối tượng, mà cấu trúc chung của nó bao gồm: loại đối tượng (Object type), các thuộc tính đối tượng (Object Attributes) và các dịch vụ (Service).
Mỗi tiến trình được định nghĩa bởi một tập các thuộc tính và các dịch vụ mà nó có thể thực hiện. Một tiến trình sẽ thực hiện một dịch vụ để nhận thông điệp thích hợp.
Khi windows NT tạo ra một tiến trình mới, nó sử dụng lớp đối tượng, hay kiểu, định nghĩa cho tiến trình windows NT như một template để tạo ra một thể hiện mới của đối tượng. Tại thời điểm tạo đó, các giá trị thuộc tính sẽ được gán.
Một tiến trình windows NT phải chứa ít nhất một tiểu trình để thực thi. Tiểu trình đó sau đó có thể tạo ra các tiểu trình khác. Trong hệ thống đa xử lý, nhiều tiểu trình của cùng tiến trình có thể thực thi song song.
Một số thuộc tính của một tiểu trình tương tự với các thuộc tính của một tiến trình. Trong những trường hợp đó, giá trị thuộc tính của tiểu trình được thừa kế từ giá trị thuộc tính của tiến trình. Ví dụ, các processor liên quan đến các tiểu trình là tập các processor trong một hệ thống multiprocessor (đa vi xử lý) mà nó có thể thực thi tiểu trình này; tập đó tương đương hay một tập con của các processor liên quan đến tiến trình.
Một trong những thuộc tính của đối tượng tiểu trình là ngữ cảnh (context) của tiểu trình. Thông tin này cho phép các tiểu trình có thể tạm dừng và tái kích hoạt trở lại được. Hơn thế nữa, nó có thể thay đổi hành vi của một tiểu trình bằng cách thay đổi ngữ cảnh của nó khi nó bị tạm dừng.
Multithreading (Đa tiểu trình)
Windows NT hỗ trợ đồng thời nhiều tiến trình bởi vì các tiểu trình trong các tiến trình khác nhau có thể thực thi đồng thời. Hơn nữa, nhiều tiểu trình bên trong cùng một tiến trình có thể định vị tách biệt các processor và thực thi đồng thời. Một tiến trình đa tiểu trình đạt được sự đồng thời mà không cần sử dụng nhiều tiến trình. Các tiểu trình bên trong cùng tiến trình có thể trao đổi thông tin thông qua bộ nhớ chia sẻ và truy xuất các tài nguyên chia sẻ của tiến trình.
Một tiến trình đa tiểu trình hướng đối tượng là một công cụ hiệu quả cho việc cung cấp các ứng dụng server. Một tiến trình server đơn lẻ có thể phục vụ một số client. Mỗi client yêu cầu khởi phát việc tạo một tiểu trình mới bên trong server.
Hỗ trợ các hệ thống con hệ điều hành
Mục tiêu chung nhất của tiến trình và tiểu trình là phải hỗ trợ các cấu trúc tiến trình và tiểu trình của các client trên các hệ điều hành khác nhau. Đó là trách nhiệm của mỗi hệ thống con hệ điều hành, để khai thác các đặc tính của tiến trình và tiểu trình windows NT, để mô phỏng dễ dàng tiến trình và tiểu trình của hệ điều hành tương ứng của nó.
Sau đây chúng ta hãy quan sát quá trình tạo tiến trình trong windows NT để thấy được sự hỗ trợ tiến trình và tiểu trình cho các hệ thống con hệ điều hành. Việc tạo tiến trình bắt đầu với một yêu cầu một tiến trình mới từ một ứng dụng hệ điều hành. Yêu cầu tạo tiến trình được phát ra từ một ứng dụng đến hệ thống con được bảo vệ tương ứng. Đến lượt nó, hệ thống con phát ra một yêu cầu tiến trình cho thành phần Executive của windows NT. Windows NT tạo một đối tượng tiến trình và trả ra một handle của đối tượng đó đến cho hệ thống con. Khi windows NT tạo một tiến trình, nó không tự động tạo một tiểu trình. Do đó, đối với các hệ điều hành này, hệ thống con gọi trình quản lý tiến trình windows NT một lần nữa để tạo ra một tiểu trình cho tiến trình mới, mà nó nhận được một handle của tiểu trình từ windows NT. Thông tin tiểu trình và tiến trình thích hợp sau đó được trả lại cho ứng dụng. Trong Windows 16-bit và POSIX, các tiểu trình không được hỗ trợ. Do đó, đối với các hệ điều hành như thế này, hệ thống con có một tiểu trình cho tiến trình mới từ windows NT, cho nên tiến trình có thể được kích hoạt, nhưng chi trả lại thông tin tiến trình cho ứng dụng. Trong thực tế, tiến trình ứng dụng được cài đặt bằng cách sử dụng một tiểu trình không thấy cho ứng dụng.
Khi một tiến trình mới được tạo trong Win32 hay OS/2, tiến trình mới thừa kế nhiều đặc tính của nó từ tiến trình tạo. Tuy nhiên, trong môi trường hệ điều hành windows NT, việc tạo tiến trình này không được thực hiện trực tiếp. Một tiến trình client ứng dụng phát ra yêu cầu tạo tiến trình của nó đến cho hệ thống con hệ điều hành; sau đó một tiến trình trong hệ thống con đến lượt nó phát ra một yêu cầu tiến trình cho thành phần Executive của windows NT. Vì tác dụng mong đợi là tiến trình mới thừa kế các đặc tính của tiến trình client và không thừa kế từ tiến trình server, nên windows NT cho phép hệ thống con chỉ định cha của tiến trình mới. Sau đó tiến trình mới thừa kế token truy xuất, thời gian quota, độ ưu tiên cơ sở, và mối quan hệ processor mặc định của tiến trình cha.
Trong windows NT, không có quan hệ được định nghĩa trước giữa các tiến trình. Tuy nhiên, cả hệ điều hành POSIX và hệ điều hành OS/2 đều áp đặt một mối quan hệ phân cấp. Mỗi tiến trình mở rộng một tiến trình ban đầu được tạo bởi một tiến trình khác và được xem như cấp dưới tiến trình tạo ra nó. Bằng cách sử dụng các handle đối tượng, hệ thống con hệ điều hành có thể duy trì các mối quan hệ giữa các tiến trình này.