JADE và mô hình tác tử

Một phần của tài liệu MÔI TRưỜNG PHÁT TRIỂN tác tử DI ĐỘNG và ỨNG DỤNG (Trang 40 - 42)

JADE là một nền tảng phần mềm cung cấp chức năng cơ bản cho tầng giữa, độc lập với các ứng dụng cụ thể và đơn giản hóa việc thực hiện của các ứng dụng phân tán – những ứng dụng khai thác sự trừu tượng của các tác tử phần mềm. Một đặc điểm đầy ý nghĩa của JADE là nó thực thi sự trừu tượng này trên ngôn ngữ hướng đối tượng, Java, cung cấp một API đơn giản và thân thiện.

Một tác tử có tính tự chủ và hướng đích: một tác tử không thể cung cấp các call - back hoặc tham chiếu đối tượng của chính nó tới các tác tử khác để làm giảm đi cơ hội điều khiển của các thực thể lên các dịch vụ của nó. Một tác tử phải có luồng thực thi của chính nó, sử dụng nó để điều khiển vòng đời của nó và tự chủ quyết định khi nào thực thi các hành động.

Các tác tử có thể nói không, và chúng được gắn kết lỏng lẻo: Việc giao tiếp không đồng bộ dựa trên thông điệp là hình thức giao tiếp cơ bản giữa các tác tử trong JADE; một tác tử muốn giao tiếp phải gửi thông điệp đến một điểm được xác định (hoặc thiết lập các điểm đến). Việc này không phụ thuộc vào thời gian giữa người gửi và người nhận: một người nhận có thể không có mặt khi người gửi gửi thông điệp đến. Cũng không cần phải lấy tham chiếu đối tượng của tác tử nhận mà cần có các định danh tên để hệ vận chuyển thông điệp có thể dựa vào đó để chuyển thông điệp đến đúng địa chỉ. Thậm chí bên gửi có thể không cần biết về định danh của bên gửi, nó có thể định nghĩa một danh sách bên nhận sử dụng intentional grouping (nhóm người nhận dự kiến) hoặc sử dụng một proxy tác tử trung gian.

Hơn nữa, dạng thức giao tiếp này cho phép bên nhận có quyền lựa chọn thông điệp sẽ xử lý hay loại bỏ, cũng như có quyền xác định các mức ưu tiên xử lý của chính nó. Cách truyền thông này còn cho phép bên gửi có thể điều khiển luồng thực thi của nó và như vậy không bị khóa cho đến khi bên nhận xử lý thông điệp.

Hệ thống có kiểu Peer-to-Peer: mỗi tác tử được xác định bởi một tên toàn cục duy nhất. Nó có thể tham gia vào và rời khỏi một nền tảng máy chủ ở bất kỳ thời điểm nào và có thể nhận ra các tác tử khác thông qua cả 2 dịch vụ white-page và yellow-page cung cấp trong JADE bởi AMS và DF mà đã được định nghĩa bởi FIPA.

Trên cơ sở những lựa chọn thiết kế này, JADE đã được cài đặt để cung cấp cho các nhà lập trình các chức năng cốt lõi sẵn sàng để sử dụng và dễ dàng để tùy biến sau đây:

Một hệ thống hoàn toàn phân tán mà các tác tử cư trú trên đó, mỗi tác tử hoạt động như là một luồng riêng biệt, và có khả năng giao tiếp một cách trong suốt với tác tử khác.

Tuân thủ đầy đủ các đặc tả của FIPA. Nền tảng tham gia thành công vào tất cả các sự kiện phối hợp hoạt động của FIPA và được sử dụng như là tầng giữa của nhiều nền tảng trong mạng lưới tác tửcities. Điều này đã tạo nên sự đóng góp lớn lao của đội JADE vào quá trình chuẩn hóa của FIPA.

Phương tiện vận chuyển hiệu quả của các thông điệp không đồng bộ thông qua một API trong suốt về vị trí. Nền tảng lựa chọn các phương tiện sẵn có tốt nhất của truyền thông và khi có thể, tránh sự sắp xếp theo thứ tự hoặc không theo thứ tự các đối tượng Java. Khi đi qua ranh giới nền tảng, các thông điệp tự động được biến đổi từ cách biểu diễn bằng Java bên trong của JADE sang các cú pháp tuân theo FIPA, cách giải mã và các giao thức vận chuyển.

Thực thi cả 2 dịch vụ white-page và yellow-page. Hệ thống có thể được cài đặt để biểu diễn các miền và các miền con như một đồ thị các thư mục. Quản lý vòng đời tác tử đơn giản nhưng hiệu quả. Khi các tác tử đã được tự động gán một định danh toàn cục duy nhất và một địa chỉ vận chuyển được sử dụng để đăng ký với dịch vụ white-page của nền tảng. Các API đơn giản và các công cụ đồ họa cũng được cung cấp để quản lý vòng đời tác tử vừa từ xa và vừa cục bộ, như tạo, đình chỉ, phục hồi, đóng băng, tan băng, di chuyển, lặp lại và xóa.

Cung cấp tính di động của tác tử. Cả mã và trạng thái của tác tử đều có thể di chuyển giữa các tiến trình và các máy. Sự di chuyển của được tạo ra để các tác tử giao tiếp một cách trong suốt mà có thể tiếp tục tương tác thậm chí là trong suốt quá trình di chuyển.

Một cơ chế đặt trước cho mỗi tác tử và thậm chí là cả các ứng dụng bên ngoài muốn đăng ký với một nền tảng để được thông báo về tất cả các sự kiện của nền tảng

Một tập các công cụ đồ họa để hỗ trợ người lập trình khi debugmonitor. Chúng đặc biệt quan trọng và phức tạp trong các hệ thống đa luồng, nhiều tiến trình, nhiều máy ví dụ như một ứng dụng JADE điển hình.

Hỗ trợ các Ontology và các ngôn ngữ nội dung. Việc kiểm tra ontology và việc mã hóa nội dung được thực hiện tự động bởi nền tảng, các nhà lập trình có thể lựa chọn các ngôn ngữ nội dung và ontologies yêu thích.

Một thư viện của các giao thức tương tác: mô hình các mẫu đặc trưng của truyền thông nhằm đạt được một hoặc nhiều mục đích. Các skeleton độc lập với ứng dụng là một tập các lớp Java có sẵn và có thể tùy chọn.

Sự tích hợp với các công nghệ khác nhau dựa trên Web bao gồm các công nghệ JSP, Servlet, applet và Web Service. Nền tảng cũng có thể được cấu hình một cách dễ dàng để xuyên qua tường lửa.

Hỗ trợ nền tảng J2ME và môi trường không dây. JADE run-time có thể dùng cho các nền tảng J2ME – CDC và J2ME-LCDC thông qua một tập không đổi của các API che phủ cả 2 môi trường J2ME và J2SE.

Một giao diện tiến trình bên trong cho việc khởi chạy và việc điều khiển một nền tảng và các thành phần phân tán của nó từ một ứng dụng bên ngoài. Một nhân có thể mở rộng được thiết kế để cho phép những người lập trình mở rộng các chức năng của nền tảng thông qua việc bổ sung các dịch vụ phân tán mức nhân.

Một phần của tài liệu MÔI TRưỜNG PHÁT TRIỂN tác tử DI ĐỘNG và ỨNG DỤNG (Trang 40 - 42)