Nếu nền công nghiệp cho ra một tiêu chuẩn UDDI để kiểm tra và kiểm soát
nhịp độ các chuyến bay, thì những đường bay có thể đăng ký những dịch vụ của
họ vào trong một thư mục UDDI. Những đại lý du lịchcó thể tìm kiếm trong thư
mục UDDI để thấy giao diện kiểm soát đường bay. Khigiao diện được tìm thấy,
hãng đại lý du lịch có thể truyền thông với dịch vụngay lập tức bởi vì nó sử dụng
một giao diện kiểm soát được định nghĩa đày đủ và rõ ràng.
75 trang |
Chia sẻ: tlsuongmuoi | Lượt xem: 2706 | Lượt tải: 2
Bạn đang xem trước 20 trang tài liệu Hệ thống e-Learning, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
L cũng dùng để định vị Web services.
- WSDL không còn là một chuẩn của W3C.
- WSDL đặc tả Web Services.
Câu hỏi: WSDL là chuẩn cho ngôn ngữ đặc tả Web Services?
Trả lời:
43
WSDL là một tài liệu được viết bằng XML. Tài liệu này dùng để đặc tả một
dịch vụ Web. Nó định rõ vị trí của dịch vụ và trình bày tất cả các phép toán (hay
phương thức) của dịch vụ đó.
Câu hỏi: Lịch sử phát triển của WSDL ở W3C?
Trả lời:
- WSDL 1.1 được ấn hành như một W3C Note bởi Ariba, IBM và Microsoft để
đặc tả dịch vụ cho W3C XML hoạt động trên giao thức XML vào 3/2001.
- Bản phác thảo đầu tiên của WSDL 1.2 được xuất bản bởi W3C vào 7/2002.
c) Dịch vụ khám phá - UDDI (Universal Description, Discovery, and
Integration):
Chuẩn UDDI, hay còn gọi là chuẩn dịch vụ Tích hợp, Khám phá và Mô tả Toàn
cầu, hoạt động như một dịch vụ đăng ký và định vị có khả năng xác nhận và phân
loại các ứng dụng dịch vụ Web, giúp người sử dụng dễ dàng tìm thấy chúng trên
mạng.
Hội đồng Điều hành Kinh doanh Đăng ký UDDI (Universal Descripsion,
Discovery and Intergaration), một tổ chức nhận được sự hậu thuẫn của cả
Microsoft, IBM, NTT Communications và SAP, hiện đã rầm rộ quảng bá cho
phiên bản của dịch vụ mới nhất UDDI ver 3.
Ở lõi của nó, UDDI gồm có hai phần. Thứ nhất, UDDI là một đặc tả kỹ thuật
để xây dựng một thư mục phân tán của những giao dịch và dịch vụ mạng. Dữ liệu
được đặt bên trong một định dạng XML đặc biệt. Đặc tả UDDI bao gồm chi tiết
API để tìm kiếm dữ liệu và xuất bản dữ liệu mới. Thứ hai, nơi đăng ký doanh
nghiệp UDDI là một sự thi hành thao tác hoàn toàn (của) thuyết minh UDDI.
Microsoft, Ariba và IBM đã công bố dự án Đăng ký Doanh nghiệp UDDI
(Universal Description, Discovery and Integration) vào tháng 9 /2002 và đã quảng
bá dự án này như "Những trang vàng" lần đầu tiên được đưa lên Internet.
Đến nay, đã có nhiều doanh nghiệp nổi tiếng nhất trên thế giới đã tham gia dự
án này, bao gồm: American Express, Compaq, SAP AG, Dell và Sun. Các hãng
này đều ký hợp đồng hỗ trợ phát triển UDDI. Số công ty tham gia UDDI hiện đã
lên đến 130, trong đó có cả HP và Intel.
Hệ thống UDDI cho phép các doanh nghiệp cung cấp thông tin về sản phẩm và
dịch vụ của mình trên mạng cho các đối tác và khách hàng trong nước. UDDI sẽ
phân thành ba nhóm thông tin như sau:
44
- Những trang trắng sẽ gồm tên doanh nghiệp, danh mục phân loại doanh
nghiệp và thông tin về các loại dịch vụ và hình thức hỗ trợ khách hàng...
- Những trang vàng cung cấp những quy định mới nhất của chính phủ về các
hoạt động của doanh nghiệp. Ngoài ra còn sắp xếp danh mục công ty theo
từng khu vực địa lý.
- Những trang xanh cung cấp các loại tài liệu tham khảo cần thiết liên quan đến
hoạt động kinh doanh của doanh nghiệp.
Ví dụ:
Để có thể hiểu một cách thông suốt về UDDI. Chúng ta hãy làm một FAQ sau:
Câu hỏi: UDDI là gì?
Trả lời:
- UDDI là một khung nền độc lập để đặc tả dịch vụ, khám phá giao dịch, và tích
hợp các dịch vụ giao dịch thông qua Internet.
- UDDI nghĩa là Universal Description, Discovery and Integration.
- UDDI là một thư mục chứa những thông tin về dịch vụ web.
- UDDI là một thư mục của giao diện dịch vụ web đặc tả bằng WSDL.
- UDDI truyền thông nhờ SOAP.
- UDDI được xây dựng trong nền tảng Microsoft .NET.
Câu hỏi: Nền tảng của UDDI là gì?
Trả lời:
- UDDI sử dụng World Wide Web Consortium (W3C) và Internet Engineering
Task Force (IETF) Internet chuẩn như là các giao thức XML, HTTP, và DNS.
- UDDI sử dụng WSDL đặc tả giao diện dịch vụ web.
Câu hỏi: Lợi ích của UDDI là gì?
Trả lời:
Bất kỳ một ngành kinh doanh hay một doanh nghiệp nào dù lớn hay nhỏ đều có
được lợi ích từ UDDI. Trước UDDI, đã không có chuẩn Internet cho các doanh
45
nghiệp mở rrộng khách hàng và đối tác của họ bằng nhứng thông tin về sản phẩm
và dịch vụ của mình. Và cũng không có cách nào để làm thế nào đó có thể tích
hợp vào mỗi hệ thống vào tiến trình khác nhau..
Vấn đề có thể giải quyết với đặc tả UDDI . Ví dụ như là : Làm cho có thể tìm
ngay ra doanh nghiệp từ hàng triệu người đang trực tuyến.
Câu hỏi: UDDI sử dụng như thế nào?
Trả lời:
Nếu nền công nghiệp cho ra một tiêu chuẩn UDDI để kiểm tra và kiểm soát
nhịp độ các chuyến bay, thì những đường bay có thể đăng ký những dịch vụ của
họ vào trong một thư mục UDDI. Những đại lý du lịch có thể tìm kiếm trong thư
mục UDDI để thấy giao diện kiểm soát đường bay. Khi giao diện được tìm thấy,
hãng đại lý du lịch có thể truyền thông với dịch vụ ngay lập tức bởi vì nó sử dụng
một giao diện kiểm soát được định nghĩa đày đủ và rõ ràng.
Câu hỏi: Ai hỗ trợ UDDI?
Trả lời:
Có thể một loạt như: Dell, Fujitsu, HP, Hitachi, IBM, Intel, Microsoft, Oracle,
SAP, và Sun,… Đã có hơn 220 công ty là thành viên của cộng đồng UDDI.
d) Dịch vụ truyền tải (Service Transport):
HTTP: Giao thức truyền tải siêu văn bản
World Wide Web đuợc xây dựng dựa vào nền của Internet và sử dụng giao
thức TCP/IP để truyền tải thông tin giữa các Web Client và Web server. HTTP là
giao thức client/server dùng cho World Wide Web. Nó cung cấp cách để Web
Browser truy xuất Web server và yêu cầu các văn bản hypermedia được tạo bởi
HTML (Ngôn ngữ đánh dấu siêu văn bản). Các văn bản HTML có thể chứa các
siêu kiên kết (hyperlink) đến các nơi khác nhau, có thể trong cùng một văn bản,
một văn bản khác cùng một Web site hay một văn bản trên một Web site khác.
Nói chung, HTTP có nhiệm vụ xử lý các liên kết nầy và cung cấp giao thức truyền
tin cho client/server.
Theo RFC 1945, ”HTTP là một giao thức cấp ứng dụng với sự nhanh nhạy cần
thiết để phân bố, cộng tác các hệ thống thông tin hypermedia. Nó là giao thức
hướng đối tượng tổng quát, không trạng thái, có thể dùng cho nhiều nhiệm vụ
chẳng hạn như đặt tên cho server và các hệ thống quản lý đối tượng phân tán,
thông qua việc mở rộng các phương thức theo yêu cầu (các lệnh)”.
46
Khi client đang chạy Web Browser gõ tên server (hay địa chỉ IP) vào trường
Address, browser sẽ định vị địa chỉ nầy trên mạng (mạng intranet nội bộ hay mạng
internet tùy thuộc vào sự kết nối) và sự kết nối sẽ được thực hiện đến Web server
đã chỉ định.
HTTP là giao thức lệnh và điều khiển xác lập việc truyền tin giữa client và
server và chuyển lệnh qua lại giữa hai hệ thống. HTML là ngôn ngữ định dạng văn
bản.
Quá trình kết nối bắt đầu khi bạn gõ địa chỉ của Web site trong Web Browser
của bạn (hay click chọn). Đầu tiên, địa chỉ IP của Web site nầy được dùng để tìm
ở server DNS (Domain Name System), tên và địa chỉ có liên quan đến Web site.
Địa chỉ tương ứng nầy được gửi về lại Web site của bạn và nó sẽ thực hiện kết nối
trực tiếp với Web server.
SMTP: Giao thức chuyển thư điện tử đơn giản
SMTP là một cơ chế trao đổi thư trên Internet. Nó có trách nhiệm chuyển thông
điệp từ một mail server (máy chủ chuyên lo về dịch vụ thư tín điện tử) nầy đến
mail server khác. Mail server chạy một giao thức kiểm soát thông điệp gọi là POP
(giao thức bưu điện) hay IMAP4 (giao thức truy cập thư Internet, phiên bản 4).
IMAP4 là một giao thức mới và linh động hơn thay thế cho POP. SMTP giống
như người mang thư có trách nhiệm chuyển thư trong khi POP và IMAP4 giống
như các bưu điện có trách nhiệm nhận, trữ và chuyển tiếp thư. SMTP dùng địa chỉ
thư Internet mà mọi người đều quen thuộc:
username@company.com
POP trữ các thư trong hộp thư của người sử dụng. Khi người sử dụng kết nối
vào mail server thì tên thư điện tử của họ được dùng để xác minh họ là ai và cho
phép họ truy cập vào hộp thư của họ. Những thông điệp sẽ được tải xuống máy
của họ. IMAP4 cải tiến mô hình nầy bằng cách cho phép người sử dụng giữ thư
điện tử trong những hộp thư riêng trên mail server thay vì các lá thư nầy tự động
được tải xuống máy của họ. Điều nầy có ích cho người sử dụng ở những nơi xa
xôi.
SMTP dùng một cơ chế yêu cầu và đáp ứng cơ bản để chuyển thư giữa các máy
OP hay IMAP4 trên Internet hay mạng nội bộ. Chỉ cần một lệnh rất đơn giản để
thực hiện trao đổi thư. Lệnh nầy được format ở dạng văn bản ASCII. Cấu trúc lệnh
đơn giản làm dễ dàng hơn khi xây dựng những mail server và các trạm cho khách
hàng.
47
Mạng mail server trên Internet thì khá phức tạp. Trong hầu hết các trường hợp,
một thông điệp được gởi từ người nầy sang người khác phải đi theo một con
đường thông qua một số SMTP server trước khi đến đích.
FTP: Giao thức truyền tập tin
FTP là một dịch vụ truyền tập tin trên hệ thống mạng Internet và trên các hệ
thống mạng TCP/IP. Về cơ bản, FTP là giao thức client/server (khách/chủ) trong
đó một hệ thống đang sử dụng trình FTP server chấp nhận các yêu cầu từ một hệ
thống đang chạy FTP client. Dịch vụ nầy cho phép các người dùng gửi đến máy
chủ các yêu cầu tải lên hoặc chép về các tập tin. FTP hoạt động giữa nhiều loại hệ
thống hỗn hợp và và cho phép người dùng từ hệ thống nầy tương tác với hệ thống
khác loại mà không cần quan tâm đến các hệ điều hành tại đó.
FTP khách hoạt động bằng giao diện tương tác text căn bản, qua bộ điều khiển
dòng lệnh. Các bước cơ bản mà một FTP client trải qua để tương tác với FTP
server được mô tả như sau:
1. Khởi động lệnh thiết lập giao diện FTP
2. Gõ ? để xem giúp đỡ
3. Sử dụng lệnh Open để chỉ định địa chỉ IP hay tên miền của FTP server
muốn truy cập
4. Đăng nhập mạng (log in) (tại các nơi công cộng, gõ anonymous cho tên
login của bạn)
5. Sử dụng lệnh dir hay ls để liệt kê danh sách tập tin trên FTP server
6. Sử dụng lệnh cd để chuyển đổi thư mục hiện hành
7. Sử dụng lệnh get để tải tập tin về (download) hay sử dụng lệnh put để đẩy
tập tin lên mạng (upload)
8. Gõ lệnh close để kết thúc phiên truyền hiện tại (và lại gõ lệnh open để truy
cập máy chủ khác)
9. Gõ lệnh quit để kết thúc chương trình
Trong hầu hết các trường hợp, các bước nầy đại diện cho tất cả những gì bạn sẽ
làm khi tương tác với một FTP server. Như đã đề cập, bạn có thể gõ dấu ? để xem
đầy đủ danh sách các lệnh, và tất nhiên có nhiều lệnh để bạn sử dụng. Nhiều trạm
FTP cho phép truy cập tập tin ở mức an toàn tối thiểu bởi vì chúng cung cấp các
tập tin nầy cho cả cộng đồng. Những nơi nầy được gọi là nơi anonymous FTP
(FTP nặc danh). Trong bước 4 đề cập trên đây, bạn chỉ đơn thuần gõ vào
anonymous để khai báo tên login, rồi gõ vào địa chỉ e-mail của bạn (hay một dữ
liệu thực nào đó) như là một mã của bạn.
FTP làm việc thông qua nhiều hệ thống tập tin khác nhau, như vậy các người
dùng phải lưu ý rằng các kiểu tập tin trên FTP server có thể không tương thích với
48
hệ thống của họ. Nói chung, tập tin văn bản có thể xem được bởi tất cả mọi loại hệ
thống, còn các loại tập tin phổ biến mới hơn như PDF (Portable Document
Format) của Adobe có ít khả năng nầy hơn. Một vấn đề khác: bạn gõ binary trước
khi lấy về các tập tin đồ họa hay tập tin thi hành được; gõ ascii trước khi lấy về
các tập tin văn bản.
Trên thực tế, FTP client điều quản phần lớn tiến trình đưa ra yêu cầu. Trước hết
nó thông dịch các câu lệnh của người dùng rồi mới gửi yêu cầu đó đến FTP server
đang sử dụng giao thức FTP.
Các câu lệnh và dữ liệu được gửi đi băng qua hai kết nối khác nhau. Khi bạn
khởi động FTP và nối vào một FTP server, một liên kết được mở ra cho máy chủ
đó để giữ nguyên tình trạng mở (giữ tính liên tục) cho đến khi bạn gõ lệnh close.
Khi bạn đưa ra yêu cầu truyền tập tin, dữ liệu của tập tin đó được truyền thông qua
một kết nối khác, và kết nối nầy sẽ kết thúc khi quá trình truyền tập tin hoàn thành.
Như vậy, một phiên truyền FTP điển hình có thể có vài liên kết được mở cùng một
lúc nếu có nhiều tập tin đang được truyền đi. Sử dụng phương pháp nầy để chia sẻ
điều khiển và dữ liệu có nghĩa là liên kết đó có thể được sử dụng trong khi dữ liệu
đã được truyền đi.
2. Tại sao Web Service là một lựa chọn tốt cho hệ thống e-Learning?
Xuất phát từ khái niệm của e-Learning, chúng ta có thể dễ dàng nhận ra một số
khó khăn khi xây dựng và triển khai một hệ thống e-Learning:
- Người sử dụng cuối rất đa dạng. Họ có thể sử dụng nhiều hệ điều hành khác
nhau, những ngôn ngữ lập trình khác nhau.
- Hệ thống e-Learning cần được truy cập trên một phương tiện truyền thông
chung, phổ biến càng rộng càng tốt, và như vậy hệ thống cũng cần được đăng
ký.
3. Làm thế nào để xây dựng hệ thống e-Learning như 1 Web
Service?
Xin lấy hệ thống LearningServe để minh hoạ, đây là hệ thống đào tạo trực
tuyến được xây dựng trên nền công nghệ Web service của tác giả Westerkampeter
tại trường đại học Munster, cộng hòa Liên bang Đức [3].
49
Kiến trúc dịch vụ Web cho e-Learning:
Hình 27. Kiến trúc tầng cao của LearnServe
Trong hình vẽ trên, LearnServe chia ra làm 2 phần: một phần mềm client và
dịch vụ Web cung cấp với một vài suppliers. The LearnServe client là một điểm
truy cập cho người dùng mà có thể sử dụng dịch vụ học tập này. Những dịch vụ đó
thi hành trên các server phân tán và bao gồm tác giả, nội dụng, bài tập, kiểm tra,
và các dịch vụ khám phá cũng như các dịch vụ truyền thông chẳng hạn như email
và các bảng thông tin. Các dịch vụ bài tập được cung cấp bởi hệ thống XLX, hệ
thống này đã được nâng cấp để có thể cung cấp các tính năng như một dịch vụ
Web và do đó có thể sẵn sàng được sử dụng bởi các hệ thống bên ngoài. Tất nhiên
là việc sử dụng các dịch vụ đào tạo là không hạn chế đối với các khách hàng bởi vì
việc cung cấp toàn bộ các tính năng của hệ thống như là các dịch vụ Web cho
phép tích hợp trực tiếp các tính năng của hệ thống đào tạo trực tuyến và một ứng
dụng thương mại (chẳng hạn như hệ thống CRM hay hệ thống ERP) để tương tác
với các ứng dụng, các tiến trình và các thông tin. Các dịch vụ Web cũng có thể
được sử dụng trên các thiết bị di động nếu khách hàng có các thiết bị đó.
50
Những hạn chế của hệ thống phân tán (không tập trung):
Xây dựng một hệ thống không tập trung (non-centralized) bằng cách liên kết
nhiều dịch vụ Web để có thể đạt được các chức năng như một hệ thống đào tạo
trực tuyến làm nảy sinh các vấn đề trong việc quản lý nội dung cho các học viên
và việc tìm kiếm các dịch vụ cần thiết đáp ứng yêu cầu vào thời điểm yêu cầu đó
được đưa ra. Hệ thống đào tạo trực tuyến LearnServe sử dụng các sổ đăng ký
UDDI để tìm kiếm các dịch vụ Web như là một hoạt động thường nhật trong lĩnh
vực dịch vụ Web. Tuy nhiên, UDDI không phù hợp với các dịch vụ nội dung bởi
vì sự lưu trữ các metadata về các nội dung không được hỗ trợ thích đáng. Trong
một tổ chức, các đối tương kiến thức có thể được đưa vào một hệ thống quản lý
đào tạo riêng biệt. Thay vào đó, nội dung cần được lưu trữ trên các server phân tán
và sẽ đựoc truy vấn đến khi có yêu cầu. Việc này làm xuất hiện các vấn đề về trình
diễn dữ liệu bởi vì đặc trưng của các dịch vụ Web là hướng dữ liệu (data-oriented),
nhưng việc biểu diễn là rất quan trọng để có thể hiểu rõ các nội dung sẽ được học.
Để giảm nhẹ các vấn đề về tương thích trong việc tích hợp nội dung, hệ thống
LearnServe sử dụng các tiêu chuẩn mới nhất để có thể tái sử dụng, khai phá và
trao đổi nội dung trong nội bộ hệ thống cũng như với các hệ thống đào tạo trực
tuyến khác.
Quá trình khai phá được hỗ trợ bởi kho chứa các đối tượng xuất bản của
LearnServe và khả năng tìm kiếm và đáp ứng môi trương làm việc của UDDI
được sử dụng cho các dịch vụ Web thương mại trong bối cảnh đào tạo. Nó cũng có
thể được phân biệt bởi nó chứa các dữ liệu tập trung về các đối tượng kiến thức,
nghĩa là tất cả các metadata, trong khi trên thực tế, các nội dung có thể được phân
bố một cách tùy ý. Để sử dụng nội dung, các platform tầng thấp triệu gọi các đối
tượng kiến thức cần thiết, các đối tượng kiến thức này sẽ được trình diễn bởi các
dịch vụ Web và chuyển giao tới người học. Dịch vụ trình diễn làm tăng lượng
thông tin về nội dung như đã được mô tả trong chuẩn WSRP (Web Services for
Remote Portlets Specification) và do đó làm tăng khả năng đáp ứng trong việc
trình diễn nội dung tùy theo yêu cầu của người học.
Từ đó, chúng ta có thể khắc phục một số vấn đề phát sinh khi triển khai một
platform cho dịch vụ, gồm có:
1. Lưu trữ các nội dung đào tạo trong mô hình phân tán.
2. Trao đổi dữ liệu một cách linh hoạt khi cần thiết hay khi phù hợp.
Ví dụ như, điều này có thể dựa trên các hồ sơ cá nhân của người học và các đặc
tả về khóa học mà một tác giả nào đó đã đưa lên kho chứa của LearnServe.
51
V. Xây dng mt h thng đào to trc tuyn b4ng công ngh
Web service da trên plat form J2EE
Hiện nay, cả 2 platform J2EE và .Net đều hỗ trợ triển khai Web service. Một
trong những ưu điểm của việc sử dụng J2EE để phát triển hệ thống đào tạo trực
tuyến là chúng ta có một sự lựa chọn phong phú các nhà cung cấp với các phần
mềm đã được xây dựng sẵn (pre-built), với rất nhiều các dữ án mã nguồn mở.
J2EE là một chuẩn công nghiệp. Nguyên nhân quan trọng nhất để lựa chọn J2EE
là do tất các hệ thống khác đều dựa trên JAVA. Chúng ta sẽ không cần phải thay
đổi bất kỳ một phần nhỏ kiến trúc nào khi triển khai Web service trên platform
J2EE và các thành phần của J2EE cũng có thể phân tách một cách dễ dàng thành
các dịch vụ Web. Ta sẽ tận dụng được rất nhiều ưu điểm khi triển khai Web
services trên nền J2EE như tính khả chuyển, tính vô hướng, tính tin cậy. Sau đây
chúng ta sẽ tìm hiểu về platform J2EE và cách xây dựng các dịch vụ Web trên
platform này.
A. Gi>i thiu v$ J2EE
1. Giới thiệu chung
J2EE là Java 2 Platform Enterprise Edition, đây là một phân tán tính toán
framework của Sun Microsystems.J2EE là một platform để phát triển những ứng
dụng phân tán bao gồm những thành phần sau:
J2EE Platform - một platform chuẩn để chứa các ứng dụng J2EE.
Reference Implemetation - một ứng dụng server hỗ trợ chuẩn mới nhất
của J2EE, ngoại trừ những ưu điểm của nó là những đặc tính mới trong
phiên bản chuẩn của J2EE, đây chưa phải là 1 sản phẩm hoàn chỉnh.
Compatibility Test Suite - một công cụ để kiểm tra xem một ứng dụng
server có tương thích với chuẩn J2EE hay không. Thiếu cái này thì mỗi
nhà cung cấp có thể hiểu và từ đó phát triển chuẩn J2EE theo những
hướng khác nhau mà như thế thì làm giảm đi thế mạnh của J2EE platform
là “write once, run anywhere”.
Application Programming Model (APM) Blueprint – một mô hình ứng
dụng tham khảo, được cung cấp để minh hoạ cách phát triển ứng dụng
dùng J2EE.
2. Phát triển chương trình dùng J2EE
J2EE Framework cho phép phát triển những ứng dụng phân tán bằng cách cung
cấp 1 tập các dịch vụ cơ bản như quản lý giao dịch, kiểm tra bảo mật, quản lý
52
trạng thái, quản lý tài nguyên. Các ứng dụng server đều cung cấp những dịch vụ
cơ bản này của J2EE Framework.
3. J2EE API
Những công nghệ được sự dùng trong J2EE bao gồm:
Java 2 Standard Edition (J2SE) - trước kia còn gọi là JDK.
Java Database Connectivity (JDBC) - Một API chuẩn dùng để kết nối
Java Platform với cơ sở dữ liệu.
RMI-JRMP – Remote Method Invocation (RMI),một chuẩn dùng để gọi
hàm từ xa dựa trên Java Remote Message Protocol (JRMP).
Java Interface Definition Language (Java IDL) - một dịch vụ kết hợp
Common Object Request Broker Architecture (COBRA) vào trong Java
Platform để cung cấp tính interoperability thông qua chuẩn IDL.
Remote Method Invocation–Internet Inter-ORB Protocol (RMI-IIOP) -
một giao thức cho phép lập trình viên RMI kết hợp những lợi ích của
RMI API và giao thức CORBA/IIOP để giao tiếp với CORBA-compliant
client được phát triển bởi bất cứ ngôn ngữ nào tuân theo CORBA.
Enterprise JavaBean (EJB) - một kiến trúc thành phần để phát triển và
triển khai các ứng dụng kiểu thành phần dựa trên phân tán.
Servlet – tương tác với Web client thông qua cơ chế request – response.
Cơ chế này dựa trên giao thức HTTP.
Java Server Page (JSP) – Dùng để xây dựng những ứng dụng có chứa nội
dung web động như là HTML, DHTML, XML.
Java Message Service (JMS) - một API để giao tiếp với Message Oriented
Middleware (MOM) cho phép truyền nhận message theo cơ chế point-to-
point và publish/subcribre.
Java Naming and Directory Interface (JNDI) - một interface duy nhất
dùng để truy cập những kiểu dịch vụ khác nhau về naming và directory.
Java Transaction API (JTA) - một tập API cho phép quản lý transaction.
Ứng dụng có thể sự dụng JTA để start, commit, abord transaction.
JavaMail - một API cung cấp 1 framework platform-independent và
protocol-independent (không phụ thuộc giao thức về platform) để xây
dựng ứng dụng về mail và messaging.
JavaBean Activation Framework (JAF) - tập các API được sử dụng bởi
các package khác như là JavaMail…Bạn có thể dùng JAF để xác định
kiểu dữ liệu, đóng gói truy cập đến dữ liệu đó, mở rộng những tác vụ dựa
trên dữ liệu đó và khởi tạo một bean tương ứng để thực hiện những tác vụ
đó. Ví dụ JavaMail dùng JAF để xác định object nào sẽ được khởi tạo dựa
trên kiểu MIME của object.
4. Các thành phần của J2EE.
53
J2EE được xây dụng trên một mô hình container component (trình chứa-thành
phần).Bốn container component cốt lõi cung cấp môi trường cho các component
khác của J2EE thông qua các API. Những component cốt lõi này liên quan đến
bốn kiểu trình chứa được hỗ trợ trong J2EE bao gồm, Application Client, Applet,
Web và EJB:
Java Application – component này là 1 chương trình standalone chạy bên
trong Application Client container. Application Client container cung cấp
những API hỗ trợ cho messaging, remote invocation, database
connectivity và lookup service. Application Client container đòi hỏi
những API sau: J2SE, JMS, JNDI, RIM-IIOP và JDBC.Container này
được cung cấp bởi nhà cung cấp application server.
Applet – Applet component là java applet chạy bên trong Applet
container, chính là web browser có hỗ trợ công nghệ Java. Applet phải hỗ
trợ J2SE API.
Servlet và JSP – đây là Web-based component chạy ở bên trong Web
container, được hỗ trợ bởi Web Server. Web container là một môi trường
run-time cho servlet và jsp. Web Container phải hỗ trợ những API sau:
J2SE, JMS, JNDI, JTA, JavaMail, JAF, RIM-IIOP và JDBC. Serlet và
JSP cung cấp một cơ chế cho việc chuẩn bị, xử lý, định dạng nội dung
động.
Enterprise JavaBean (EJB) – EJB component là business component –
thành phần nghiệp vụ chạy bên trong EJB container. EJB component là
phần nhân, cốt lõi của ứng dụng J2EE. EJB container cung cấp các dịch
vụ quản lý transaction, bảo mật, quản lý trạng thái, quay vòng tài nguyên
(resource pooling). EJB container phải hỗ trợ những API sau: J2SE, JMS,
JNDI, JTA, JavaMail, JAF, RIM-IIOP và JDBC.
5. Sử dụng EJB
EJB chứa những business logic của ứng dụng, cho nên có thể nói rằng EJB
chính là phần lõi của phần lớn các ứng dụng phân tán cho doanh nghiệp. Một
enterprise bean có những đặc điểm sau:
Chứa các business logic để thao tác với dữ liệu.
Được tạo ra và được quản lý bởi một container.
Xử lý các truy cập của client .
Chứa metadata, như là thuộc tính của transaction và security, riêng biệt
với các bean.
54
Cung cấp dịch vụ quản lý transation, quản lý trạng thái, quay vòng tài
nguyên và bảo mật.
Nếu bạn thiết kế 1 ứng dụng không cần có hỗ trợ transaction hoặc bảo mật,
lúc đó nên trở lại câu hỏi có nên dùng đến EJB hay không.
Mỗi EJB bắt buộc phải có những interface và class sau:
Home Interface - home interface extend javax.ejb.EJBHome. Nó đóng vai
trò như một Factory pattern để khởi tạo các instance của EJB.
Remote Interface – remote interface extend javax.ejb.EJBObject. Remote
interface chứa các business method , được gọi từ client. Nó đóng vai trò
như 1 proxy của EJB.
Bean Class - chứa phần cài đặt của các method khai báo trong remote
interface. Bean class extend javax.ejb.SessionBean hoặc
javax.ejb.EntityBean hoặc javax.ejb.MessageDrivenBean.
5.1 Sử dụng Session và Entity Bean
Các ứng dụng cho enterprise cần những component linh động trong business
logic. Các component phải có khả đáp ứng stateless service, conversational state,
và hỗ trợ việc chia sẻ dữ liệu.EJB có 2 loại bean chính ứng với các nhu cầu khác
nhau của component trong ứng dụng: session và entity. Entity bean phục vụ cho
việc duy trì và chia sẻ dữ liệu. Như thế không có nghĩa là session bean không thể
duy trì đối tượng được, nhưng entity bean được thiết kế chuyện dụng cho mục
đích này. Session bean thì phục vụ cho các bussiness logic và workflow liên quan
đến ứng dụng J2EE, tương ứng với nhu cầu về stateless service và conversational
state.
5.2 Stateless Bean và Stateful Bean
Có 2 loại session bean: stateless và stateful:
Stateless Beans.
Stateless bean không giữ tạm dịch là trạng thái giao dịch của client.
Tuy nhiên không có nghĩa là stateless bean không thể giữ được trạng
thái, nhưng trạng thái này không bảo đảm đủ để xác định client nào đã
gọi đến bean này. Điều này có nghĩa là bạn có thể dùng stateless bean
để thực hiện bất cứ hành động nào trong ứng dụng.
Stateful Beans.
Stateful bean có khả năng giữ conversational state (tạm dịch là trạng
thái giao tiếp) của client. Tất nhiên là có nhiều cách để giữ
consersational state trong ứng dụng, nhưng nếu state đó cần phải gắn
với business logic thì nó nên được lưu giữ trong stateful bean.Ví dụ
55
điển hình nhất của session stateful bean là component shopping cart
trong các ứng dụng mua hàng trực tuyến.
5.3 Sử dụng MessageDrivenBean
MessageDrivenBean là một điểm mới trong chuẩn EJB 2.0 (EJB 1.1 chỉ định
nghĩa 2 loại bean là session và entity). Mục đích của MesssageDrivenBean là phục
vụ cho nhu cầu về các dịch vụ không đồng bộ của các component. Bởi vì session
và entity bean chỉ phục vụ các dịch vụ loại synchronous. Do đó cách sử dụng
MessageDrivenBean có phần giống với session stateless bean, chỉ khác ở cách gọi
bean, với MDB thì client phải gửi message đến MDB đó để thực hiện các hàm
trong MDB.
5.4 Sử dụng Container-Managed Persistence
Có 2 cách để 1 entity bean persist object: container-managed persistence
(CMP) và bean-managed persistence (BMP). Trong CMP, container điều khiển
việc cài đặt cần thiết cho các tác vụ chèn, đọc, ghi, cập nhật object trong một data
source. Còn trong BMP, thì lập trình viên phải tự cài đặt các code cho các tác vụ
trên. CMP lý tưởng cho việc phát triển ứng dụng vì nó không đòi hỏi lập trình viên
phải thay đổi code mỗi khi data model thay đổi. Tuy nhiên để có được tính linh
hoạt, CMP không cho phép sinh ra những câu lệnh SQL hiệu quả.
Hiện nay các công cụ phục vụ việc ánh xạ object với cơ sở dữ liệu vẫn còn đang
trong quá trình phát triển và chưa đủ chín muồi. Trong khi chờ đợi CMP phát triển
hoàn thiện thì BMP cộng với pattern DAO có lẽ là 1 giải pháp khá tốt.
5.5 Sử dụng Data Access Object
Khi bạn quyết định dùng BMP, có nghĩa là bạn sẽ phải tự coding các câu lệnh
SQL trong entity bean của bạn. Để giảm sự nối kết của entity bean với các câu
lệnh SQL cần thiết cho các việc đọc, ghi, xoá , cập nhật object, bạn có thể tạo ra
một DAO pattern đóng gói các câu lệnh SQL đó. Bằng cách này bạn đã làm giảm
sự phụ thuộc của bạn vào code và sư thay đổi của data model. Nói cách khác nếu
có sự thay đổi thì BMP entity bean của bạn vẫn có thể giữ nguyên và bạn chỉ phải
sửa lại phần DAO mà thôi.
DAO chứa code phục vụ việc đọc , ghi, cập nhật xoá object trên 1 data source.
Nó cho phép 1 entity bean có thể định nghĩa như 1 BMP, nhưng sau này khi các
công cụ hỗ trợ cho CMP trở nên hoàn thiện hơn thi entity bean này có thể chuyển
sang thành CMP, và DAO sẽ được thay thế bởi sự hỗ trợ CMP của container.
56
B. Áp d0ng J2EE trong cài đAt h thng E-learning
Java 2 Platform Entreprise Edition (J2EE) sử dụng mô hình phân tán nhiều tầng.
PlatformJ2EE bao gồm một Web Server và một EJB Server (Những Server đó còn
được gọi là trình chứa). Trong đó Web Server cung cấp môi trường run-time qua
các thành phần mà cung cấp ngữ cảnh đặt tên và quản lí vòng đời. Một vài Web
Server cũng cung cấp thêm các dịch vụ như quản lí bảo mật và quản lí tương tranh.
Một Web Server có thể làm việc với EJB server để cung cấp các dịch vụ đó. Một
Web Server không cần thiết phải trên cùng một máy với EJB server.
Ngày nay, platform J2EE và .Net hỗ trợ việc cài đặt của Web Services. Một
điểm mạnh của việc sử dụng J2EE là một cơ sở cho việc cài đặt hệ thống E-
Learning là chúng ta có rất nhiều nhà cung cấp và rất nhiều mã nguồn mở. J2EE
là một chuẩn công nghiệp. Lí do quan trọng nhất mà chúng ta chọn J2EE đó là tất
cả đều dựa trên cơ sở JAVA. Không cần thiết bất cứ một sự thay đổi nào về kiến
trúc hệ thống khi chúng ta cài đặt Web Services trên kiến trúc J2EE và các thành
phần J2EE đã tồn tại có thể dễ dàng được thể hiện như là Web Services. Có rất
nhiều thuận lợi của J2EE đã được hỗ trợ cho Web Services như là tính khả chuyển,
tính mở rộng, tính an toàn.
57
Hình 28. Mô hình cài đặt trên Platform J2EE
Một ứng dụng J2EE được thiết kế tốt sẽ đạt được những mục tiêu sau đây:
Tính mạnh mẽ:
Phần mềm doanh nghiệp là rất quan trọng đối với một tổ chức.Người
dùng của những phần mềm này luôn hy vọng rằng phần mềm sẽ đáng tin
cậy và không có lỗi.Vì vậy chúng ta phải hiểu và tận dụng được những
tính năng của J2EE để có thể giúp chúng ta xây dựng những giải pháp
mang tính mạnh mẽ và phải đảm bảo chắc chắn rằng chúng ta viết code
có chất lượng tốt.
58
Có hiệu năng cao và khả năng dễ dàng mở rộng.
Các ứng dụng doanh nghiệp phải thỏa mãn những hy vọng về hiệu năng
của người dùng của chúng.Đồng thời chúng phải thể hiện khả năng dễ
dàng mở rộng-đây một yếu tố cần thiết cho một ứng dụng để nó có thể hỗ
trợ khi tải tăng lên trên một hệ thông phần cứng cho trước.Khả năng mở
rộng là một yếu tố hết sức quan trọng cho các ứng dụng Internet,khi mà
thật khó để dự đoán số người dùng.Hiểu được kiến trúc của J2EE sẽ rất
thích hợp để thỏai mãn những yêu cầu trên.
Tận dụng được những điểm mạnh của nguyên tắc thiết kế hướng đối
tượng
Nguyên tắc thiết kế hướng đối tượng đưa ra rất nhiều thuận lợi cho các hệ
thống phức tạp.Một ứng dụng được thiết kế tốt theo mô hình hướng đối
tượng được đẩy mạnh bằng việc sử dụng design pattern.
Tránh được những sự phức tạp không cần thiết .
Dễ dàng trong bảo trì và mở rộng.
Phân phối sản thẩm đúng thời hạn.
Dễ dàng trong kiểm thử.
Dế dàng sử dụng lại các thành phần.
J2EE cung cấp những sự hỗ trợ nổi bật cho việc cài đặt kiến trúc phân tán.Các
thành phần của một ứng dụng J2EE phân tán có thể được chia ra và chạy trên
nhiều JVM trên một máy đơn duy nhất hay trên nhiều máy chủ vật lý.Ứng dụng
J2EE phân tán dựa chủ yếu trên việc sử dụng EJB với giao tiếp remote,điều này
cho phép các server ứng dụng có thể che dấu đi rất nhiều sự phức tạp của việc
truy nhập và việc quản lí của các thành phần phân tán.
Kiến trúc phân tán có thể đưa ra rất nhiều những ưu điểm như sau:
Khả năng hỗ trợ nhiều Client và ở nhiều loại khác nhau mà yêu cầu chia
sẻ “tầng giữa” của các business object.Sự xem xét này không áp dụng cho
các ứng dụng Web,khi web container đã cung cấp một tầng giữa.
Khả năng triển khai bất cứ một thành phần ứng dụng nào trên bất kì
server vật lí nào.Trong một vài ứng dụng thì điều này rất quan trọng cho
việc cân bằng lưu lượng.
59
Tuy nhiên kiến trúc phân tán cũng làm xuất hiện rất nhiều vấn đề:
Vấn đề về hiệu năng.
Việc đánh thức từ xa là chậm hơn rất nhiều so với việc đánh thức cụ bộ.
Sự phức tạp.
Các ứng dụng phân tán rất khó để cài đặt ,gỡ rối,triển khai và bảo dưỡng.
Các ràng buộc trong việc thực hiện thiết kế hướng đối tượng.
Đặc tả của J2EE 1.2 đã đưa ra nhiều sự lựa chọn đơn giản.EJBs có giao tiếp
remote và có thể sử dụng chỉ trong các ứng dụng phân tán. Remote Method
Invocation (RMI) là sự lựa chọn duy nhất cho việc hỗ trợ remote client.
Từ đó,hai sư phát triển-một trong J2EE và một bên ngoài J2EE đã có sự kết
hợp sâu sắc cho thiết kết J2EE.
Đặc tả EJB 2.0 cho phép EJB có giao tiếp cục bộ thay vì giao tiếp remote.EJB
có thể được đánh thức qua giao tiếp cục bộ của nó bởi các thành phần trong một
ứng dụng J2EE tích hợp chạy trên cùng JVM.
Sự kết hợp của Simple Object Acess Protocol dựa trên XML đã được chấp
nhận dụng rộng rãi như là một chuẩn flatform –agnostic cho RMI và hỗ trợ rộng
khắp cho Web Services.
Giao tiếp cục bộ EJB 2.0 được giới thiệu rộng khắp để giải quyết bài toán về
hiệu năng của Entity Bean 1.1.
Một trong những quyết định quan trọng nhất trong thiết kế một ứng dụng J2EE
đó là có hay không sử dụng EJB.EJB vẫn được coi như là lõi của kiến trúc
J2EE.Đây là một quan niệm sai lầm,EJB chỉ đơn thuần là một trong số các lựa
chọn được J2EE đưa ra.Nó được ý định là phù hợp để giải quyết các vấn đề,nhưng
trong một vài ứng dụng thì EJB đem lại rất ít ý nghĩa.
Khi các yêu cầu có ý tưởng là một kiến trúc phân tán và RMI/IIOP là giao thức
từ xa ban đầu thì EJB cho chúng ta một sự cài đặt chuẩn.Chúng ta có thể lập trình
đối tượng nghiệp vụ của chúng ta là các EJB với các giao tiếp từ xa và có thể sử
dụng trình chứa EJB để quản lí các vòng đời của chúng và dùng để đón nhận các
đánh thức từ xa.
Nếu các yêu cầu không dẫn đến ý tưởng là kiến trúc phân tán thì hay nếu
RMI/IIOP không là giao thức từ xa tự nhiên thì quyết định có hay không sử dụng
EJB sẽ trở nên khó khăn hơn.
60
EJB là công nghệ phức tạp nhất trong J2EE và từ thông dụng nhất trong
J2EE.Điều này có thể dẫn đến các lập trình viên sử dụng EJB sai mục đích.
EJB là một công nghệ high –end.Nó có thể giải quyết một số vấn đề nhất định
rất tôt,nhưng không nên sử dụng nó nếu không có lí do cần thiết và đúng đắn.
Những vấn đề liên quan khi sử dụng EJB.
Một trong những mục tiêu trong đặc tả EJB 2.0 đó là làm đơn giản code của
các ứng dụng. Đặc tả EJB 2.0 khẳng định rằng :”Kiến trúc EJB sẽ làm cho việc
viết code các ứng dụng sẽ dễ dàng hơn.Các nhà phát triển ứng dụng sẽ không phải
hiểu chi tiết về các quản lí giao dịch mức thấp,các chi tiết về tính Multi-
thread ,chia sẻ kết nối,và các API mức thấp”.
Về mặt lí thuyết bằng việc chuyển toàn bộ cho các vấn đề mức thấp cho trình
chứa EJB thì các người phát triển tự do để đầu nỗ lực của họ cho các business
logic.
Tuy nhiên công nghệ EJB cũng làm nảy sinh các vấn đề sau:
Sử dụng EJB làm cho các ứng dụng trở nên khó khăn hơn trong quá trình
kiểm tra.
Sử dụng EJB cũng khiến cho các ứng dụng khó khăn trong quá trình triển
khai.
Sử dụng EJB với giao tiếp từ xa có thể làm cản trở việc thiết kế theo mô
hình hướng đối tượng.
Sử dụng EJB có thể khiến những thứ đơn giản trở nên phức tạp.
Làm giảm sự lựa chọn của các server ứng dụng.
Một số điểm mạnh khi dùng EJB.
Cho phép truy nhập từ xa tới các thành phần ứng dụng.
Cho phép các thành phần ứng dụng có thể được trải ra trên nhiều server
vật lý khác nhau.
Hỗ trợ phong phú các loại Client COBRA hay JAVA.
Cài đặt các message consumers khi một mô hình không đồng bồ là hợp lí.
Truy nhập dữ liệu.
Việc lựa chọn công nghệ truy nhập dữ liệu là một trong những vấn đề cần xem
xét chính khi quyết định có hay không sử dụng EJB khi mà một trong những sự
lựa chọn (entity beans) là sự lựa chọn duy nhất khi dùng EJB.Chiến lược truy nhập
61
dữ liệu thường xuyên quyết định hiệu năng của toàn hệ thống doanh nghiệp và
khiến nó trở thành bài toán thiết kế chủ yếu.
Chú ý rằng trình chứa (container) hỗ trợ cho việc chia sẻ kết nối tài nguyên là
có ý nghĩa trong trình chứa Web chứ không chỉ đơn thuần cho server EJB.
Rất nhiều người phát triển J2EE không linh hoạt khi xem xét vấn đề truy nhập
dữ liệu.Những trong khi đó thì:
- Sự di chuyển giữa các Database là luôn luôn cần thiết.
- Ánh xạ Object/Relation (O/R) luôn là những giải pháp tốt nhất khi làm việc
với cơ sở dữ liệu quan hệ.
- Ánh xạ O/R là một giải pháp hoàn hảo trong vài trường hợp (đặc biệt là khi
dữ liệu có thể được che dấu ở lớp ánh xạ) tuy nhiên trong một vài trường hợp
thì chúng sẽ làm suy giảm đáng kể hiệu năng của hệ thống.Ở khía cạnh tích
cực,giải pháp ánh xạ O/R ,nếu chúng là một sự thích hợp tốt trong vài ứng
dụng cụ thể thì chúng có thể giúp cho người phát triển thỏai mái trong việc
viết các code truy nhập cơ sở dữ liệu,năng cao hiệu quả công việc.
Người ta thường cho rằng entity bean là cách duy nhất để đạt được sự phân
tách rõ ràng giữa truy nhập dữ liệu và logic nghiệp vụ ,đây là một ý kiến sai
lầm.Truy nhập dữ liệu không khác với bất cứ một phần nào khác của hệ thống nơi
mà người ra mong muốn giữ lại một lựa chọn khác cho quá trình cài đặt.Chúng ta
có thể phân tách các chi tiết về việc truy nhập dữ liệu ra khỏi phần còn lại của ứng
dụng một cách đơn giản bằng các nguyên tắc thiết kế hướng đối tượng của lập
trình đối với các giao tiếp hơn là các lớp.Hướng tiếp cận này là linh hoạt hơn sử
dụng entity bean khi mà chúng ta đã chỉ được chuyển cho một giao tiếp JAVA.
Entity bean.
Entity bean là một cách thực hiện tốt cho việc tách biệt các code truy nhập dữ
liệu.Nhưng thật không may,Entity Bean là một cách rất “tốn kém” để đạt được
điều này,đặc biệt về thời gian chạy.Entity Bean không chói buộc chúng ta với một
kiểu cơ sở dữ liệu cụ thể nào tuy nhiên nó lại trói buộc chúng ta với trình chứa
EJB và một công nghệ ánh xạ O/R cụ thể.
Vẫn tồn tại những sự nghi ngờ khi xem xét cơ sở lí thuyết và giá trị thực tế của
Entity Bean.Trói buộc truy nhập dữ liệu với trình chứa EJB làm giới hạn sự linh
hoạt của cấu trúc và làm cho các ứng dụng khó kiểm tra.
62
Cho dù với những sự cải tiến của EJB 2.0 thì Entity Bean khiến nó trở nên khó
sử dụng khi giải quyết một số vấn đề thông thường (Entity là một chuẩn ánh xạ
O/R).Chúng thường dẫn tới sự sử dụng không hiệu quả của các ứng dụng cơ sở dữ
liệu quan hệ ,và điều này làm suy giảm hiệu năng của hệ thống.
Java Data Object (JDO)
JDO là một đặc tả gần đây được phát triển bởi Java Community Process mà
miêu tả một kĩ thuật cho việc đảm bảo sự duy trì của các đối tượng Java đối với
bất cứ một dạng lưu trữ nào.JDO thường xuyên được sử dụng như là một ánh xạ
O/R những nó không bị trói buộc vào RDBMS.JDO có thể được trở thành chuẩn
API cho việc truy nhập Java đới ODBMS.JDO đưa ra mô hình “nhẹ nhàng” hơn
so với EJB. Hầu hết các đối tượng Java có thể tồn tại bao lâu cung được miễn là
trạng thái của nó được giữ trong các thể hiện của dữ liệu.Không giống với Entity
Bean,các đối tượng được duy trì khi sử dụng JDO không cần thiết phải cài đặt bất
cứ một giao tiếp đặc biệt nào .JDO cũng định nghĩa một ngôn ngữ truy vấn để
chạy các câu lệnh truy vấn trên các đối tượng tồn tại.
JDO hiện tại chưa trở thành một phần của kiến trúc J2EE,tuy nhiên nó sẽ sớm
trở thành một API cần thiết như JDBC và JNDI.
JDO cung cấp hầu hết các ưu điểm của Entitty Bean trong khi đó lại loại bỏ các
hầu hết các yếu điểm của chúng.Nó tích hợp tốt với quản lí giao dịch máy chủ
J2EE,nhưng không bị trói buộc với EJB hay thậm trí là J2EE.
63
Kiến trúc hệ thống
Hình 29. Sơ đồ kiến trúc
64
Dispatcher Request Interpreter
Protocol Interfaces
IMS-LD
Interpreter
Interface
OpenACS
Interface
JAXM
Interface
J2EE Application Server
...
Common Interface
Services
XML
Services
Config.
XML
Interface
Config.
Tracker
Logger
Common
Repository
Interaction
Object
Hình 30. Kiến trúc truyền thông của hệ thống
Hình 31. Bussines Logic của Platform E-learning
65
Hình 32. Sơ đồ kết nối JDBC
VI. Cài đAt mt h thng đào to trc tuyn trên platform J2EE
1. Giới thiệu về gói phần mềm
Đây là một phần mềm mã nguồn mở được cung cấp miễn phí tại địa chỉ web
nhóm chúng em đã download về và tìm cách cài đặt dựa
trên hướng dẫn cài đặt của gói phần mềm. Phần mềm đưa ra những yêu cầu khá
cao về cấu hình hệ thống có thể cài đặt nó, vì thế nếu không có sự giúp đỡ về cơ
sở vật chất của công ty CMC, nơi một số thành viên của nhóm đang làm việc, thì
chúng em sẽ rất khó khăn trong việc tìm kiếm platform cài đặt nó. Vì vậy. chúng
em xin gửi lời cảm ơn tới các đồng nghiệp ở công ty CMC đã tạo điều kiện để
chúng em có thể hoàn thành phần cài đặt khá phức tạp này.
2. Cài đặt phần mềm
a) Yêu cầu hệ thống
JavaTM 2 SDK, Standard Edition, Version 1.4.2
512MB RAM
60GB Drive.
66
b) Cấu hình trình duyệt máy khách và firewall
Mọi người dùng của LMS phải có một Java 1.4 enabled –browser.Để làm điều
đó bạn thực hiện như sau:
Mở Control Panel, mở Java Plugin,sau đó trong Dialog này chuyển đến Tab
Advanced và chọn version 1.4 của plugin(Nếu nó tồn tại) nếu không thì chuyển
đến Tab Update và thực hiện quá trình Update.
c) Cài đặt Server
a-LMS là một Free Learning Mangement System tương thích với chuẩn
SCORM 1.2 .Database a-LMS theo dõi sinh viên, người quản lí, quản trị, các khoá
học…Phiên bản này của a-LMS sử dụng Hypersonic Database, đây là một engine
cơ sở dữ liệu quan hệ open-source.Tuy nhiên, tất cả các truy nhập database là
thông qua JDBC để mà bất cứ JDBC (JDBC-ODBC cầu nối) tương thích database
sẽ có thể được thay thế.
a-LMS được viết bằng JAVA và yêu cầu môi trường JAVA trên máy chủ và
trình duyệt Java-enabled.
a-LMS là một ứng dụng Web mà sử dụng Tomcat,một servlet engine open-
source và web server từ Apche Group.
a-LMS sẽ chạy trêm bất cứ platform nào ,tuy nhiên nó đã được kiểm tra là chạy
tốt trong các hệ điều hành sau:
Windows 2000 Professional [Version 5.00.2195 SP4].
WindowsXP Professional [Version 5.1].
WindowsXP Home Edition.
Đây là phần mềm được phát triển bởi Rubecula Software, LLC (Rubecula)
dưới hợp đồng của Telecommunications Research Associates (TRA)
Bản release này của LMS gồm 6 phần:
File Readme.html.
ReleaseNotes.txt
database.zip
licenses.zip
licenses.zip
Flimsy.war
67
Bạn cần những phần mềm sau đây để có thể cài đặt:
Java(TM) 2 SDK, Standard Edition, Version 1.4.2
HSQLDB (version: 1.7.2.4);
Tomcat (version: 4.1.30).
Sau đó bạn thực hiện các bước cài đặt sau:
1. Tạo một thư mục gọi là LMS.
2. Unpack Tomcat file và extract nó vào trong một thư mục (Ví dụ: c:\jakarta-
tomcat-4.1.30).
3. Thêm vào các biến môi trường sau:
JAVA_HOME: Có giá trị là đường dẫn đến thư mục Java SDK (ví
dụ c:\jsdk1.4.2_03).
CATALINA_HOME: Tên của thư mục dùng để cài Tomcat (Ví
dụ: c:\jakarta-tomcat-4.1.30).
CATALINA_OPTS: Dùng để thiết lập thư mục và file của a-LMS
logs properties.
DB_HOME: Tên của thư mục chứa cài đặt HSQLDB.
4. Copy Flimsy.war vào trong thư mục %CATALINA_HOME%\webapps.
5. Vào command prompt window, cd tới %CATALINA_HOME%\bin.Gõ startup.
6. Vào trang
7. Trở lại của sổ cmd và gõ: shutdown.
8. Tạo Context trong Tomcat.
1. Đăng nhập vào trang quản trị Tomcat: sau đó
Click Tomcat Administration.
68
Hình 33. Trình chủ Tomcat
69
Hình 34. Đăng nhập Web Server
2. Click để expand Tomcat Server (đỉnh của danh sách bên trái), sau đó
Service (Tomcat-Standalone), rồi Host (localhost).
70
Hình 35. Tomcat Web Server
1. Chọn Create New Context trong select box "Host Actions".
2. Set “Path”: cho tên của context.Ví dụ nếu bạn muốn một file
Index.htm có thể nhận được bằng URL
thì bạn set Path nhận giá
trị /Courses.
3. Set "Document Base:" chỉ vào thư mục file hệ thống tương ứng.
4. Chọn nút “Save”.
5. Chọn nút "Commit Changes".
9. Trong thư mục %CATALINA_HOME%\webapps\Flimsy\WEB-INF bạn sẽ tìm
thấy một file XML tên là : web.xml .Trong file này bạn tìm tham số:
CourseContentContextPath, sau đó hãy nhập vào Path của context mà bạn định
nghĩa trong bước trước đó. Sau đó tìm tham số CourseContentDocumentBase và
thay thế giá trị đã tồn tại với giá trị Document Base của context mà bạn định nghĩa
ở bước trước.Khi đó nó sẽ có dạng như sau:
<! -- Parameters for interacting with webapp context for course content
data. -->
71
CourseContentContextPath</param-
name>
/Courses
CourseContentDocumentBase</param-
name>
C:\lms\courses
10. Trong %CATALINA_HOME%\webapps\Flimsy\WEB-INF\config bạn sẽ tìm
thấy một file tên là: log4j.properties.Trong File này bạn hãy tìm tham số:
log4j.appender.consoleLogFile.File và thay thế nó bởi thư mục mà bạn muốn.Làm
tương tự với log4j.appender.modelLogFile.File và
log4j.appender.configLogFile.File.
Save file rồi sau đó copy nó vào thư mục thu mục và bạn đã xác định trong
CATALINA_OPTS ở trên.
11. Unpack hsqldb_1_7_2_4.zip vào thư mục \LMS Trong System Variable ,hãy
thiết lập biến DB_HOME có giá trị tương ứng.Ví dụ DB_HOME=c:\LMS\hsqldb
12. Đặt sáu thành phần của Release này vào trong thư mục LMS
13. Khởi động HSQLDB Server bằng cách : \LMS\bin\startDb.bat
14. Khởi động HSQLDB Manager bằng cách sau:
cd %DB_HOME%
java -cp lib\hsqldb.jar org.hsqldb.util.DatabaseManager.
Khi chương trình khởi động:
1. Trong “Type” chọn kiểu kết nối "HSQL Database Engine
Server".
2. Trong URL nhập vào: "jdbc:hsqldb:hsql://localhost:9001/lmsdb"
3. Giữ nguyên các tham số khác.
4. Click OK.
72
Hình 36. Màn hình đăng nhập CSDL
15. Chuyển vào thư mục Flimsy và chạy bin\createSQLScript.bat. Chương trình
này sẽ tạo ra file model.sql trong thư mục Flimsy :
1. Nếu là chương trình cài đặt mới, chạy file model.sql trong
DatabaseManager.
2. Nếu mà bạn đang cài một version mới của phần mềm mà không
có sự thay đổi vào về mô hình, sau đó xóa hết tất cả các câu lệnh
trong file model.sql.
16. Nếu là lần cài đặt đầu tiên thì bạn cần tạo một nhóm group và
administrator.Để làm việc đó bạn :
Unzip the release file database.zip để extract file
PopulateTables.sql.
Chạy PopulateTables.sql trong DatabaseManager.
17. Tạo một thư mục rỗng Courses
trong %CATALINA_HOME%\webapps\Flimsy
73
18. Nếu bạn có ý định in “diplomas” cho các sinh viên thì bạn phải thay đổi các
tham số trong web.xml.
CompanyName: Tên của công ty.
GrantorName: Tên của Grantor của Dilomas.
GrantorTitle: Tựa đề của Grantor của Dilomas.
CompanyLogo: File hình ảnh được dùng làm logo của công ty.
GrantorSignature :File ảnh chứa chữ kí của Grantor.
19. Bạn quay lại command window và khởi động lại nó.
20. Mở File %CATALINA_HOME%\webapps\Flimsy\files\Flimsy.html.
Bạn nên sử dụng đường dẫn sau để bắt đầu với LMS
Quá trình cài đặt hoàn tất.!
a-LMS được chạy như là một ứng dụng web thông qua trình duyệt.Mặc dù a-
LMS tự nó sẽ chạy dưới Netscape,bạn sẽ không thể đưa nội dung TRA trừ khi bạn
sử dụng Internet Exxplorer như là trình duyệt của bạn.Khi bạn làm theo link ở trên
thì bạn sẽ nhìn thấy mà hình Login.Hãy nhập vào fistname và lastname và
password của bạn.Bạn sẽ được chuyển đến màn hình mà nội dung của nó sẽ khác
nhau tuỳ theo vai trò của bạn.Một đăng nhập mặc định được nhập vào trong quá
trình cài đặt khi bạn chạy file PopulatyeTables.sql .Nó sẽ chèn vào người dùng
gốc với một đăng nhập là root và password là r00t. Bạn nên thay đổi password với
lệnh Edit Users.
Với vai trò là một người quản trị,bạn có thể thêm các khoá học.Các dữ liệu cho
một khoá học có thể tòn tại trên server hoặc trên một file zip trên hệ thống máy
client. Trong trường hợp đó,bạn click vào Add course, còn trong trương hợp thứ
2 ,click Upload course . Ở đó phải tồn tại trước các thông tin của bạn để có thể
tương ứng với một course mới.Nếu là upload thì đầu tiên phải upload file zip sau
đó kết hợp nó với curriculum tương ứng.Nếu tham thiết với dữ liệu đã tồn tại trên
server, thì hãy nhập vào tên đường dẫn của file cần tìm và tên của curriculum.
Nếu bạn đăng là sinh viên đăng kí và bạn muốn đăng kí cho một khoá học,
click Register for Course sau đó làm theo hướng dẫn.
Để tham gia vào một đơn vị khoá học, click vào View registered courses. Bạn
sẽ thấy một danh sách khoá học mà bạn đã đăng kí.Click vào View Units bên
cạnh khoá học mà bạn muốn tham gia.Và bạn sẽ được giới thiệu một danh sách
các Unit .Click vào nút Launch bên cạnh Unit mà bạn muốn .
74
Khởi động và Tắt LMS.
Khởi động và tắt LMS liên quan đến khởi động và tắt Tomcat cũng như
HSQLDB .Ở đó có những file batch trong %CATALINA_HOME%\bin và
\LMS\bin.Ngoài ra, còn có một file trong \LMS\bin\lms.rc mà chứa các cấu hình
cần thiết để dừng HSQLDB.
Để khởi động phần mềm LMS bạn thực hiện theo các bươc sau:
1. Chuyển vào thư mục \LMS\bin và nhập vào startDb.
2. Chuyển vào thư mục %CATALINA_HOME%\bin và nhập vào câu
lệnh startup.
Để dừng phần mềm LMS bạn thực hiện các bước sau:
1. Chuyển vào thư mục \LMS\bin và nhập vào câu lênh: startDb.
2. Chuyển vào thư mục %CATALINA_HOME%\bin và nhập vào câu
lệnh: shutdown.
Thành phần \LMS\bin\lms/rc đã được cấu hình để dừng một database có tên là
lmsdb, chạy trên localhost tại cổng 9001, với một administrator hệ thống với
username là “sa” và password là “”.
Hình 37. Giao diện của a-LMS
75
Đỗ Công Thành
Bùi Quang Trung
Đào Quang Tuấn
Phùng Tiến Lân
Tài liệu tham khảo
[1]. Xiaofei Liu, “An implementable architecture of an e-learning system”,
Distributed and Collaborative Virtual Environments Research Lab
School of Information Technology and Engineering, University of Ottawa,
Ottawa, Ontario, Canada.
[2]. “E-learning Application Infrastructure”, White paper of Sun
Microsystems.
[3]. “E-learning Interoperability Standards”, White paper of Sun
Microsystems.
[4]. Peter Westerkamp, “E-Learning as a Web Service”, University of M¨unster
Institut f¨ur Wirtschaftsinformatik Leonardo-Campus 3 D-48149 M¨unster,
Germany pewe@wi.uni-muenster.de
[5]. Ethan Cerami, “Web Services Essential, Distributed Applications with XML-
RPC, SOAP, UDDI & WSDL”, O’reilly Publishing First Edition February
2002.
[6]. Copyright Bộ GDĐT, Việt Nam.
[7]. , Copyright FPT Corp.
[8].
[9]. Tien. N. D, Đồ án tốt nghiệp đại học, khoa CNTT, ĐHBKHN, 2002.
Các file đính kèm theo tài liệu này:
- Hệ thống e-Learning.pdf