Thiết kế các dịch vụ SOA với Rational Software Architect, Phần 2 pptx

45 424 1
Thiết kế các dịch vụ SOA với Rational Software Architect, Phần 2 pptx

Đ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

Thiết kế các dịch vụ SOA với Rational Software Architect, Phần 2: Thiết kế các dịch vụ với lược tả UML của các dịch vụ phần mềm Lee Ackerman, Giám đốc tiếp thị, IBM Bertrand Portier, Kiến trúc IT, IBM Software Group Services Tóm tắt: Tìm hiểu cách làm thế nào để thiết kế kiến trúc hướng dịch vụ (SOA) khi sử dụng IBM® Rational® Software Architect (Kiến trúc sư phần mềm Rational của IBM). Cách tiếp cận dựa theo mô hình này (model-driven development -MDD) dựa vào Unified Modeling Language (UML - Ngôn ngữ mô hình hóa thố ng nhất) và lược tả UML 2.0 của các dịch vụ phần mềm. Trước khi bạn bắt đầu Trước hết hãy xem lại bạn có thể mong đợi những gì từ hướng dẫn này và làm thế nào để học được nhiều nhất từ nó. Về loạt bài viết này Để thu được những lợi ích của Service-Oriented Architecture (SOA - Kiến trúc hướng dịch vụ) và Model-Driven Development (MDD- Phát triển dựa theo mô hình), môi trường thiết kế và phát triển c ủa bạn cần có các đặc điểm sau: • Mô hình hóa các cách làm thực tế tốt nhất: mọi người sẽ có thể sử dụng lại các giải pháp đã được kiểm chứng để giải quyết các vấn đề xảy ra thường xuyên và cũng cung cấp các giải pháp cho những người khác sử dụng lại. • Chọn công cụ khớp với vai trò và nhiệm vụ: Các công cụ cần được nhắm đến nhiệm vụ sắp tới và đến vai trò thực hiện nhiệm vụ đó (ví dụ, nhà phân tích nghiệp vụ hoặc Kiến trúc sư CNTT). • Cung cấp sự hỗ trợ và hướng dẫn quy trình xử lý: Môi trường phát triển luôn luôn cung cấp hướng dẫn tùy bối cảnh cho các phương pháp hay các quy trình. • Đưa ra một nền tảng mở rộng được: Các nhóm làm việc sẽ có thể mở rộng hoặc tùy chỉnh môi trường sao cho ăn khớp với các nhu cầu của họ. • Cho phép tự động hóa: Các ánh xạ và siêu mô hình ở dưới khung công tác sẽ cho phép biến đổi bán tự động các mô hình, từ các mức trừu tượng hóa cao hơn đến thấp hơn và cuối cùng thành mã có thể chạy được. • Giúp theo vết sự trừu tượng hóa: Có khả năng truy ngược lại từ các mức trừu tượng hóa thấp hơn đến cao hơn. Có tất cả các đặc tính của IBM Rational Software Development Platform (Nền tảng phát triển phần mền Rational IBM) và cụ thể hơn là công cụ của IBM Rational Software Architect. Trong loạt bài viết của hướng dẫn này, bạn sẽ tìm hiểu làm thế nào để sử dụng nền tảng Rational và các khả năng của nó để thiết kế các giải pháp SOA. Hướng dẫn này mô tả một cách tiếp cận MDD từ trên xuống dưới để mô hình hóa các dịch vụ bằng cách sử dụng Rational Software Architect. Bạn sẽ học cách làm thế nào để bạn có thể biểu diễn mô hình dịch vụ theo các mức trừu tượng hóa khác nhau (từ Quy trình nghiệp vụ, Unified Modeling Language -UML- Ngôn ngữ mô hình hóa thống nhất, Web Services Description Language -WSDL- Ngôn ngữ mô tả dịch vụ Web, đến mã Java™) và làm thế nào để Rational Software Architect hỗ trợ hiển thị trực quan và chuyển đổi từ một mức trừu tượng hóa này tới mức trừu tượng hóa khác. Các tác giả cũng thảo luận về việc sử dụng các lược tả UML (UML profiles) cho các ngôn ngữ riêng cho từng lĩnh vực như SOA. Chìa khóa để thu được các lợi ích của SOA là việc tái sử dụng các tài sản hiện có. Chúng tôi chỉ ra cách làm thế nào để sử dụng các mẫu thiết kế hiện có để giải quyết các yêu cầu của các dịch vụ của bạn. Sau khi tìm hiểu hết loạt bài viết này, bạn sẽ có khả năng thiết kế các dịch vụ bằng Rational Software Architect và sử dụng các khả năng bạn được cung cấp xoay quanh các lược tả UML, các mẫu thiết kế, các tài sản có khả năng sử dụng lại, các phép biến đổi và các dịch vụ Web. Về đầu trang Về hướng dẫn này Trong Phần 1 của loạt bài viết, bạn đã làm quen với Rational Software Architect và cách nó tích hợp với các công cụ khác mà bạn sử dụng trong các giai đoạn khác nhau của vòng đời SOA như thế nào. Trong phần này, bạn tìm hiểu cách sử dụng Rational Software Architect như thế nào để thiết kế các dịch vụ bằng cách sử dụng UML và các lược tả UML 2.0 cho các dịch vụ phần mềm. Hướng dẫ n này tập trung vào việc thiết kế các dịch vụ riêng lẻ, không phải là thiết kế các tương tác hoặc hợp tác dịch vụ. Về đầu trang Các mục tiêu Sau khi hoàn tất hướng dẫn này, bạn sẽ có một sự hiểu biết tốt hơn về giá trị của MDD và mô hình hóa trực quan. Bạn cũng sẽ hiểu lược tả UML là gì, lược tả các dịch vụ là gì và sử dụng nó như thế nào. Với kiến thức đó, bạn sẽ có thể tạo ra một mô hình thiết kế dịch vụ bao gồm các thông điệp (Messages), các đặc tả dịch vụ (Service Specifications) và các dịch vụ (Services). Về đầu trang Các điều kiện cần trước Để nhận được đầy đủ những lợi ích của hướng dẫn này, sẽ rất có ích nhưng không bắt buộc nếu bạn quen thuộc với các khái niệm và sản phẩm sau: • UML, the Unified Modeling Language - Ngôn ngữ mô hình hóa thống nhất. • WSDL, the Web Services Description Language - Ngôn ngữ mô tả dịch vụ Web. • Rational Software Architect - Kiến trúc phần mềm Rational hay Rational Software Modeler - Trình mô hình hóa phần mềm Rational. • SOA, service-oriented architecture - Kiến trúc hướng dịch vụ. Xem Tài nguyên để có được các đường liên kết có ích đến các thông tin thêm nữa về các chủ đề này. Về đầu trang Các yêu cầu hệ thống Để hoàn thành hướng dẫn này, bạn cần cài đặt các phần mềm sau đây: • Rational Software Architect • Lược tả UML 2.0 cho các dịch vụ phần mềm (UML 2.0 Profile for Software Services). Sử dụng lược tả UML 2.0 cho Các dịch vụ phần mềm dành cho thiết kế SOA Các lược tả UML bổ sung thêm một cơ cấu mở rộng đơn giản cho UML độc lập với lĩnh vực. Chúng cho phép định nghĩa các quy tắc và các thực thể riêng của từng lĩnh vực. Các lược tả UML đi đôi đẹp đẽ với các quá trình phát triển. Ví dụ, có một Lược tả UML để mô hình hóa nghiệp v ụ (Business Modeling), hỗ trợ IBM Rational Unified Process® - RUP® (Quy trình thống nhất Rational của IBM) dành cho mô hình hóa nghiệp vụ. Các lược tả chủ yếu gồm có các bản mẫu (stereotypes). Một bản mẫu định nghĩa nó được kết hợp với lớp UML (siêu lớp) nào, các thuộc tính của lớp đó và các ràng buộc về cách các phần tử bản mẫu có thể được kết hợp với các phần tử khác như thế nào. Ví dụ, trong các lượ c tả UML 2.0 cho Các dịch vụ phần mềm, một bản mẫu Đặc tả dịch vụ mở rộng siêu lớp Interface. Nó định nghĩa một thuộc tính được gọi là Published (đã xuất bản) để cho biết bản mẫu Đặc tả dịch vụ ấy đã được xuất bản tới sổ đăng ký dịch vụ hay chưa. Cuối cùng, một trong những ràng buộc của nó là tất cả các hoạt động phải được đánh dấu là Public (công cộng). Trong công cụ của Rational Software Architect, các lược tả có các đặc điểm sau: • Các quy tắc mà lược tả định nghĩa có thể được xác nhận hợp lệ. • Các bản mẫu có thể có các mô tả đồ họa kết hợp với chúng. • Các lược tả được lưu trữ trong các mô hình lược tả, với phần mở rộng của tên tệp tin là .epx. • Các lược tả có số phiên bản và số phát hành. Giới thiệu về lược tả Lược tả hay không lược tả? Có thể mô hình hóa một phần các giải pháp hướng dịch vụ với UML cơ bản, sử dụng các lớp, các giao diện, các hoạt động, các thành phần và các cổng. Tuy nhiên, một số khái niệm hướng dịch vụ không thể mô tả được bằng UML (ví dụ, một dạng mã hóa của một thông báo hoặc một kết buộc dịch vụ). Tất nhiên, có thể sử dụng UML để định nghĩa một siêu mô hình (meta-model) dành cho hướng dịch vụ và đó chính là những gì mà lược tả các dịch vụ thực hiện. Ngoài ra, lược tả này cũng cung cấp một biểu diễn đồ họa hấp dẫn, trợ giúp đáng kể cho việc mô hình hóa. Như được mô tả trong một bài báo (http://www.ibm.com/developerworks/rational/library/05/419_SOA/) trên trang Web developerWorks® của IBM®, "Lược tả UML 2.0 cho Các dịch vụ phần mềm [từ đây trở đi sẽ đơ n giản gọi là lược tả dịch vụ (services profile)] là một lược tả UML" cho phép mô hình hóa các dịch vụ, kiến trúc hướng dịch vụ (SOA) và các giải pháp hướng dịch vụ Lược tả này đã được triển khai thực hiện trong IBM Rational Software Architect, đã sử dụng thành công trong các mô hình phát triển của các kịch bản khách hàng phức tạp và đã sử dụng để trợ giúp giáo dục mọi người về các mối quan tâm có liên quan đến vi ệc phát triển các giải pháp hướng dịch vụ. Về đầu trang Bước 1: Cài đặt lược tả dịch vụ Lược tả dịch vụ được đóng gói như là một trình cắm thêm của Rational Software Architect, có sẵn để tải về miễn phí trên trang Web developerWorks. (Xem "Nhận các sản phẩm và các công nghệ" trong Tài nguyên). Giữ một nền tảng Rational sạch sẽ Để giữ cho nền tảng phát triển phần mềm Rational sạch sẽ, cách tốt nhất là cài đặt các đặc tính tùy chọn trong các thư mục riêng biệt, chứ không phải trong thư mục Eclipse mặc định. Điều này làm cho dễ dàng hơn trong việc đặt cấu hình và gỡ bỏ các tính năng. Bắt đầu bằng cách cài đặt trình cắm thêm. 1. Nhấn vào liên kết tả i xuống, lưu tệp tin .zip này vào máy tính của bạn và sau đó trích xuất nó vào một thư mục tạm thời (ví dụ, C:\sftsvc). Bây giờ thư mục lược tả các dịch vụ mới của bạn có chứa một trang Web cập nhật tại chỗ. Bạn sẽ cập nhật cấu hình Rational Software Architect của bạn để thêm đặc tính lược tả các dịch vụ và trình cắm thêm. 2. Khởi chạy công cụ củ a Rational Software Architect, nếu bạn chưa làm như vậy. 3. Chọn Software Updates > Find and Install từ trình đơn Help. 4. Khi trình thủ thuật Install/Update hiển thị, chọn Search for new features to install (Tìm kiếm các tính năng mới để cài đặt) và sau đó nhấn vào Next. (Xem Hình 1). 5. Từ Update sites to visit (Các trang Web cập nhật để truy cập), nhấn vào New Local Site (Trang Web tại chỗ mới ) và duyệt đến nơi mà bạn đã trích xuất trang Web cậ p nhật của lược tả các dịch vụ (Đặt tên thư mục như bạn muốn, nhưng hướng dẫn này sử dụng tên là C:\sftsvc kể từ đây về sau). 6. Sau đó, chọn C:\sftsvc site trong Sites to include in search list (Các trang Web có bao gồm trong danh sách tìm kiếm) và nhấn vào Next. Hình 1. Trình thủ thuật cài đặt 7. Chọn com.ibm.rational.softsvc.feature trong danh sách Select features to install (Chọn các đặc tính để cài đặt) và sau đó nhấn vào Next. 8. Chọn I accept the terms in the licence agreement (Tôi chấp nhận các điều khoản trong thỏa thuận giấy phép) và sau đó nhấn vào Next. 9. Trên trang Install Location (Vị trí cài đặt), nhấn vào Add site (Xem Hình 2.) 10. Tạo một thư mục mới (ví dụ, C:\Program Files\IBM\Rational\SDP\6.0\services_profile). 11. Hãy chắc chắn rằng trang Web mới tạo ra của bạ n được chọn như là trang Web cài đặt của đặc tính lược tả các dịch vụ và sau đó nhấn vào Finish. Hình 2. Trang Web cài đặt mới của bạn 12. Khi cửa sổ kiểm tra JAR hiển thị, nhấn vào Install. 13. Cuối cùng, nhấn Yes để khởi động lại bàn làm việc (Workbench). Màn hình Rational Software Architect xuất hiện lại ngay sau đó. Lược tả UML cho các dịch vụ phần mềm bây giờ đã được cài đặt trong Rational Software Architect. Về đầu trang Làm thế nào để sử dụng Lược tả UML cho Các dịch vụ phần mềm Hiện có nhiều cách khác nhau để sử dụng lược tả này: Tùy chọn 1: Sử dụng khuôn mẫu mô hình được cung cấp trong lược tả đó [...]... Hình 20 Hình 20 Mô hình Thông báo dịch vụ Bạn sẽ sử dụng các thông báo mà bạn đã thiết kế khi bạn thiết kế đặc tả dịch vụ (Service Specification) trong phần kế tiếp Về đầu trang Thiết kế đặc tả dịch vụ Một đặc tả dịch vụ (service specification) là một giao diện hoặc là một tập hợp các hoạt động, mô tả các tương tác dịch vụ Trong phần này, bạn sẽ tạo ra hai đặc tả dịch vụ: • IClaimRecorder • IClaimValidator... kế dịch vụ của bạn Trong phần này của hướng dẫn, bạn thiết kế các thông báo sẽ được trao đổi giữa các bên cung cấp dịch vụ và các bên yêu cầu dịch vụ Thiết kế thông báo Bạn hãy bắt đầu bằng cách thiết kế một mô hình thông tin trong lĩnh vực bảo hiểm và sau đó bạn thiết kế các thông báo SOA sẽ chứa các phần tử của mô hình bảo hiểm đó Bước 7 Thiết kế mô hình thông tin lĩnh vực bảo hiểm 1 Mở sơ đồ Main... chọn Với tùy chọn này, bạn tạo ra một mô hình UML rỗng và bạn thêm vào các gói, các phần tử và các sơ đồ khi bạn cần tới chúng Các phần tử mà bạn tạo ra có thể được làm thành bản mẫu theo lược tả các dịch vụ Ví dụ, bạn có thể tạo ra các thông báo mới, các đặc tả dịch vụ mới, các dịch vụ mới v.v Bạn sử dụng cách tiếp cận này trong hướng dẫn này vì các ví dụ là đơn giản và bạn sẽ tạo ra các phần tử thiết. .. Design Model (Mô hình thiết kế dịch vụ) Lợi thế của việc sử dụng khuôn mẫu lược tả các dịch vụ là ở chỗ nó cung cấp một cấu trúc được xây dựng trước với các gói phần mềm riêng biệt cho thông báo, hợp tác hoặc các phần tử và các sơ đồ dịch vụ Ngoài ra, nó cung cấp các khối xây dựng được gọi là các phần tử thiết kế có thể sử dụng lại (reusable design elements) cho từng khái niệm (các bản mẫu) được định... bạn sẽ sử dụng các lớp mà bạn đã tạo ra cho việc thiết kế thông báo dịch vụ Bước 8 Thiết kế mô hình thông báo Với mục đích của bài tập này, giả sử rằng bạn đang thiết kế một dịch vụ để ghi lại các chi tiết của một yêu cầu Hãy bắt đầu bằng cách thiết kế các thông báo yêu cầu và thông báo trả lời cho thao tác này Lưu ý: Không phải tất cả các dịch vụ đều có các thông báo yêu cầu và thông báo trả lời 1 Vẫn... trúc và Mô hình thiết kế UML Bây giờ bạn đã sẵn sàng để tạo ra một mô hình thiết kế mẫu Tạo ra mô hình thiết kế Dịch vụ xử lý yêu cầu bồi thường (Claims Processing Service) Có ba bước để tạo ra thiết kế mẫu của bạn: 1 Trước tiên, bạn sẽ nhập khẩu dự án mà bạn đã tạo trong phần 1 của loạt bài viết này 2 Sau đó, bạn sẽ tạo ra một mô hình thiết kế mới để chứa các phần tử thiết kế dịch vụ của bạn 3 Cuối... thay đổi Rational Software Architect cung cấp khả năng để giúp bạn làm điều đó, dựa vào các mối quan hệ mà các bạn đã tạo ra và những quan hệ ngầm hiểu khác Cấu trúc dự án của bạn trong Model Explorer bây giờ trông giống như Hình 11 Hình 11 Cấu trúc dự án Trong các phần tiếp theo, bạn sẽ điền thêm các phần tử thiết kế dịch vụ vào các gói mà bạn vừa tạo ra Hoàn tất Thiết kế dịch vụ của bạn Trong phần này... bởi lược tả, ví dụ như Dịch vụ, Nhà cung cấp hoặc Thông báo Tài liệu hướng dẫn về các dịch vụ Làm thế nào để sử dụng lược tả các dịch vụ với các mô hình hiện có Để sử dụng lược tả các dịch vụ với các mô hình hiện có, hãy làm theo các bước sau: 1 Lựa chọn model trong Model Explorer và sau đó chọn thẻ Profiles trong khung nhìn Properties 2 Ở đây, bạn có thể nhìn thấy một danh sách các lược tả đã được áp... cả phần tử thiết kế có thể không bao gồm trong cùng một mô hình hoặc dự án; do vậy, bạn sẽ có thể phải tham chiếu các phần tử từ các mô hình khác Bước 5 Tạo cấu trúc dự án của bạn Trong phần này, bạn tạo ra cấu trúc của mô hình UML của bạn, bao gồm ba gói: • Các thông điệp (Messages) • Các đặc tả dịch vụ (Service Specifications) • Các dịch vụ (Services) Sau đó, bạn liên kết các gói này để chỉ ra các. .. trong Hình 23 2 Đặt tên cho hoạt động này recordClaimDetails Tạo bản mẫu cho lỗi ngoại lệ Lưu ý rằng hoạt động không được rập khuôn Điều này là do UML đã hỗ trợ khái niệm hoạt động SOA bằng phần tử hoạt động (operation element) Khi lược tả các dịch vụ này được thiết kế, chúng đã xem xét các phần tử UML 2 nào có thể hỗ trợ các khái niệm SOA và các bản mẫu nào đã được tạo ra, bởi vì UML 2 hiện không . Thiết kế các dịch vụ SOA với Rational Software Architect, Phần 2: Thiết kế các dịch vụ với lược tả UML của các dịch vụ phần mềm Lee Ackerman, Giám đốc tiếp. thế nào. Trong phần này, bạn tìm hiểu cách sử dụng Rational Software Architect như thế nào để thiết kế các dịch vụ bằng cách sử dụng UML và các lược tả UML 2. 0 cho các dịch vụ phần mềm. Hướng. cài đặt các phần mềm sau đây: • Rational Software Architect • Lược tả UML 2. 0 cho các dịch vụ phần mềm (UML 2. 0 Profile for Software Services). Sử dụng lược tả UML 2. 0 cho Các dịch vụ phần mềm

Ngày đăng: 08/08/2014, 14:20

Từ khóa liên quan

Tài liệu cùng người dùng

  • Đang cập nhật ...

Tài liệu liên quan