Giáo trình Lập trình truyền thông - Ngô Bá Hùng
Tóm tắt Giáo trình Lập trình truyền thông - Ngô Bá Hùng: ...Integer number = "+i ); System.out.println("Long number = "+l ); System.out.println("Float number = "+f ); } } Biên dịch và thực thi chương trình được kết quả sau: 1.4. Ngoại lệ (EXCEPTION) Trong chương trình, có một số các "thao tác không chắc chắn", ví dụ như các thao tác vào/ra...hai ống dẫn: một ống dẫn để truyền các yêu cầu (request), một ống dẫn để truyền các trả lời (reply). Hình 3.2 – Dùng ống dẫn trong chương trình Client -Server Có hai loại ống dẫn: • Ống dẫn bình thương ( Normal Pipe): Giới hạn trong phạm vi không gian địa chỉ của một quá trình mà thôi. Nó ..., ta có thể đặt thông tin trên DatagramPacket này bằng các phương thức sau: • public synchronized() void setAddress(IntermetAddress dis) : Đặt địa chỉ máy nhận. • public synchronized() void setPort(int port) : Đặt cổng quá trình nhận • public synchronized() void setData(byte buffer[]) : Đặ...
Interfacename object = null; try { object = (InterfaceName)Naming.lookup(remoteObjectURL); object.remoteMethodOne(); ... } catch (Exception e) { Biên Soạn: Ngô Bá Hùng - Nguyễn Công Huy 88 Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ - Giáo Trình Lập Trình Truyền Thông System.out.println(" Error: ”+ e); } } } o Tạo client có tên là HelloClient, tìm đối tượng HelloObject trên rmiregistry chẳng hạn tại địa chỉ 172.18.211.160. Gọi phương thức sayHello() và in kết quả trả về ra màn hình. import java.rmi.Naming; import java.rmi.RemoteException; public class HelloClient { public static void main(String args[]) { String helloURL = "rmi://172.18.211.160/HelloObject"; HelloItf object = null; try { object = (HelloItf)Naming.lookup( helloURL); String message = object.sayHello(); System.out.println(message); } catch (Exception e) { System.out.println("Client Error :" + e); } } } Lưu chương trình vào tập tin HelloClient.java Bước 05: Dịch các tập tin nguồn theo dạng RMI để tạo ra các lớp tương ứng và stub cho client, skeleton cho server: o Cú pháp tổng quát: javac InterfaceName.java RemoteClass.java Server.java Client.java ( Tạo ra các lớp InterfaceName.class RemoteClass.class Server.class Client.class) rmic RemoteClass ( Tạo ra các lớp cho Skeleton và Stub: RemoteClass_Skel.class RemoteClass_Stub.class) o Biên dịch các lớp trong Hello: javac Hello.java HelloItf.java HelloServer.java HelloClient.java rmic Hello.class Biên Soạn: Ngô Bá Hùng - Nguyễn Công Huy 89 Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ - Giáo Trình Lập Trình Truyền Thông Bước 06: Khởi động dịch vụ rmiregistry o Cú pháp tổng quát: start rmiregistry [port] Cổng mặc định là 1099. o Khới động dịch vụ rmiregistry trên cổng mặc định như sau: Khi đó rmiregistry server sẽ chạy trên một cửa sổ mới, giữ nguyên cửa sổ này, không đóng nó lại. Biên Soạn: Ngô Bá Hùng - Nguyễn Công Huy 90 Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ - Giáo Trình Lập Trình Truyền Thông Bước 07: Thực hiện chương trình Server o Cú pháp tổng quát: java -Djava.security.policy =UrlOfPolicyFile ServerName Trong đó UrlOfPolicyFile là địa chỉ theo dạng URL của tập tin mô tả chính sách về bảo mật mã nguồn của Server (policy file). Nó qui định "ai" (chương trình, máy tính, quá trình trên) sẽ có quyền download các tập tin của nó trong đó có stub. Để đơn giản trong phần này ta cho phép tất cả mọi người đều có quyền download các tập tin của Server. Khi triển khai các ứng dụng thật sự ta phải có các chính sách bảo mật nghiêm ngặt hơn (Tham khảo tài liệu về Security của Java). File policy có dạng như sau: grant { // Allow everything for now permission java.security.AllPermission; }; Lưu nội dung trên vào tập tin có tên policy.java o Thực thi HelloServer với địa tập tin plolicy nằm ở thư mục D:\progs\policy.java Bước 08: Thực thi chương trình Client: Biên Soạn: Ngô Bá Hùng - Nguyễn Công Huy 91 Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ - Giáo Trình Lập Trình Truyền Thông o Cú pháp tổng quát java ClientName o Thực thi HelloClient với địa chỉ của rmiregistry đưa vào trong tham số Để thực thi được chương trình HelloClient cần có hai class nằm cùng thư mục với nó là HelloItf.class và Hello_Stub.class. 1.4. Bài tập áp dụng • Mục đích: Xây dựng ứng dụng phân tán theo cơ chế RMI. • Yêu cầu Sinh viên thực hiện các bài tập sau: o Bài 1 : Xây dựng một ứng dụng phục vụ việc bán vé máy bay cho các đại lý phân tán ở các tỉnh thành khác nhau. Ứng dụng này có các lớp sau: Lớp chuyến bay: Đại diện cho một chuyến bay Có các thuộc tính: Số hiệu chuyến bay, Ngày giờ bay, Nơi đi, Nơi đến, Thời gian bay, Tổng số ghế, Số lượng ghế đã bán, Số lượng ghế còn trống. Các phương thức trên một chuyến bay: phương thức xem thông tin về chuyến bay, phương thức mua vé, phương thức trả vé. Để phục vụ cho nhiều đại lý các phương thức trên thuộc loại đuợc gọi từ xa. Lớp Server, tạo ra nhiều chuyến bay và duy trì nó để cho phép các đại lý thực hiện các giao dịch trên chuyến bay cụ thể. Client là chương trình cho phép mỗi đại lý được quyền xem thông tin về chuyến bay, mua vé, trả vé theo yêu cầu. Mục lục Biên Soạn: Ngô Bá Hùng - Nguyễn Công Huy 92 Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ - Giáo Trình Lập Trình Truyền Thông CHƯƠNG 1..........................................................................................................................1 Tổng quan về lập trình truyền thông....................................................................................1 1.1. Cơ chế giao tiếp liên quá trình là gì ?.....................................................................2 1.2. Phân loại cơ chế giao tiếp liên quá trình ................................................................2 1.3. Mô hình tham khảo OSI .........................................................................................3 1.4. Mạng TCP/IP..........................................................................................................6 1.5. Dịch vụ mạng .........................................................................................................7 1.6. Mô hình Client – Server .........................................................................................7 1.6.1. Giới thiệu.........................................................................................................7 1.6.2. Ví dụ về dịch vụ Web......................................................................................8 1.6.3. Các chế độ giao tiếp ........................................................................................9 1.6.3.1. Chế độ nghẽn :..........................................................................................9 1.6.3.2. Chế độ không nghẽn:................................................................................9 1.7. Các kiểu kiến trúc chương trình .............................................................................9 1.7.1. Kiến trúc đơn tầng (Single-tier Architecture) ...............................................10 1.7.2. Kiến trúc hai tầng (Two - Tier Architecture) ................................................10 1.7.2.1. Loại Fat Client........................................................................................11 1.7.2.2. Loại Fat Server .......................................................................................12 1.7.3. Kiến trúc đa tầng (N-Tier Architecture)........................................................12 1.8. Bài tập...................................................................................................................13 1.8.1. Bài tập bắt buộc.............................................................................................13 1.8.2. Bài tập gợi ý ..................................................................................................13 Tìm đọc và viết một báo cáo không quá 10 trang về giao thức POP3...............................13 CHƯƠNG 2........................................................................................................................14 Sơ lược về ngôn ngữ Java ..................................................................................................14 1.1. Giới thiệu về ngôn ngữ Java.................................................................................15 1.1.1. Lịch sử phát triển...........................................................................................15 1.1.2. Khả năng của ngôn ngữ Java.........................................................................15 1.1.2. Những đặc điểm của ngôn ngữ Java .............................................................15 1.1.3. Máy ảo Java (JMV - Java Virtual Machine) .................................................15 1.1.4. Hai kiểu ứng dụng dưới ngôn ngữ java.........................................................16 1.1.5. Bộ phát triển ứng dụng Java (JDK- Java Development Kit) ........................16 1.1.6. Kiểu dữ liệu cơ bản dưới Java.......................................................................16 1.1.7. Các phép toán cơ bản ....................................................................................17 Biên Soạn: Ngô Bá Hùng - Nguyễn Công Huy 93 Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ - Giáo Trình Lập Trình Truyền Thông 1.1.8. Qui cách đặt tên trong Java ...........................................................................17 1.2. Chương trình ứng dụng kiểu Application ............................................................18 1.2.1. Chương trình HelloWorld .............................................................................19 1.2.3. Biên soạn chương trình bằng phần mềm Notepad của Ms Windows ...........19 1.2.4. Cài đặt bộ phát triển ứng dụng JDK..............................................................20 1.2.5. Biên dịch và thực thi chương trình................................................................20 1.2.6. Một số ví dụ...................................................................................................21 1.2.6.1. Hiển thị thông tin ra màn hành...............................................................21 1.2.6.2. Đọc ký tự từ bàn phím............................................................................21 1.3. Các cấu trúc điều khiển trong Java.......................................................................23 1.3.1. Lệnh if – else .................................................................................................23 1.3.2. Phép toán ? ....................................................................................................24 1.3.3. Lệnh switch ...................................................................................................25 1.3.4. Lệnh while.....................................................................................................26 1.3.5. Lệnh do - while..............................................................................................27 1.3.6. Lệnh for .........................................................................................................27 1.3.7. Lệnh break.....................................................................................................28 1.3.8. Lệnh continue ................................................................................................29 1.3.9. Một số vấn đề khác........................................................................................30 1.3.9.1. Đọc đối số của chương trình ..................................................................30 1.3.9.2. Đổi chuỗi thành số..................................................................................31 1.4. Ngoại lệ (EXCEPTION) ......................................................................................31 1.5. Một số vấn đề liên quan đến lớp trong Java.........................................................33 1.5.1. Định nghĩa lớp mới........................................................................................33 1.5.2. Phạm vi nhìn thấy của một lớp......................................................................34 1.5.3. Tính thừa kế...................................................................................................35 1.6. Vào / Ra với Stream ............................................................................................36 1.6.1. Lớp java.io.InputStream................................................................................37 1.6.2. Lớp java.io.OutputStream .............................................................................39 1.6.3. Nhập chuỗi từ một InputStream ....................................................................40 1.6.4. Xuất chuỗi ra một OutputStream ..................................................................41 1.7. Luồng (Thread).....................................................................................................42 1.7.1. Các mức cài đặt luồng ...................................................................................43 1.7.1.1. Tiếp cận luồng ở mức người dùng: ........................................................44 Biên Soạn: Ngô Bá Hùng - Nguyễn Công Huy 94 Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ - Giáo Trình Lập Trình Truyền Thông 1.7.1.2. Tiếp cận luồng ở mức hạt nhân hệ điều hành.........................................44 1.7.2. Luồng trong java ...........................................................................................44 1.7.2.1 Độ ưu tiên của luồng ...............................................................................47 1.7.3. Đồng bộ hóa giữa các luồng..........................................................................49 1.8. Bài tập áp dụng.....................................................................................................49 Chủ đề 1: Cơ bản về Java ........................................................................................49 Chủ đề 2: Thiết kế lớp trong Java ...........................................................................49 Chủ đề 3: Thread .....................................................................................................50 CHƯƠNG 3........................................................................................................................51 Ống dẫn (Pipe) ...................................................................................................................51 1.1. Giới thiệu về ống dẫn ...........................................................................................52 1.2. Ống dẫn trong Java...............................................................................................52 1.2.1. Giới thiệu.......................................................................................................52 1.2.2. Các cách tạo ống dẫn.....................................................................................53 1.3. Dịch vụ phản hồi thông tin (Echo Service) ..........................................................53 1.4. Giả lập dịch vụ phản hồi thông tin bằng Pipe ......................................................54 1.4.1. Lớp PipedEchoServer....................................................................................54 1.4.2. Lớp PipedEchoClient ....................................................................................55 1.4.3. Lớp PipedEcho ..............................................................................................55 1.4.5. Biên dịch và thực thi chương trình................................................................56 CHƯƠNG 4........................................................................................................................57 Socket .................................................................................................................................57 1.1. Giới thiệu về socket..............................................................................................58 1.1.1. Giới thiệu.......................................................................................................58 1.1.2. Số hiệu cổng (Port Number) của socket........................................................58 1.1.3. Các chế độ giao tiếp ......................................................................................60 1.2. Xây dựng ứng dụng Client-Server với Socket .....................................................61 1.2.1. Mô hình Client-Server sử dụng Socket ở chế độ có nối kết (TCP) ..............61 1.2.2. Mô hình Client-Server sử dụng Socket ở chế độ không nối kết (UDP)........63 1.3. Socket dưới ngôn ngữ Java ..................................................................................64 1.3.1. Xây dựng chương trình Client ở chế độ có nối kết .......................................65 1.3.1.1. Lớp java.net.Socket ................................................................................65 1.3.1.2. Chương trình TCPEchoClient ................................................................66 1.3.2. Xây dựng chương trình Server ở chế độ có nối kết ......................................67 Biên Soạn: Ngô Bá Hùng - Nguyễn Công Huy 95 Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ - Giáo Trình Lập Trình Truyền Thông 1.3.2.1. Lớp java.net.ServerSocket .....................................................................67 1.3.2.2. Xây dựng chương trình Server phục vụ tuần tự .....................................67 1.3.2.3. Chương trình STCPEchoServer .............................................................68 1.3.2.4. Server phục vụ song song.......................................................................69 1.3.2.5. Chương trình PTCPEchoServer .............................................................70 1.3.3. Xây dựng chương trình Client - Server ở chế độ không nối kết ...................71 1.3.3.1. Lớp DatagramPacket ..............................................................................72 1.3.3.2. Lớp DatagramSocket..............................................................................73 1.3.3.3. Chương trình UDPEchoServer...............................................................74 1.3.3.4. Chương trình UDPEchoClient ...............................................................75 1.4. Bài tập áp dụng.....................................................................................................77 CHƯƠNG 5........................................................................................................................79 RPC và RMI.......................................................................................................................79 1.1. Lời gọi thủ tục xa (RPC- Remote Procedure Call) ..............................................80 1.1.1. Giới thiệu.......................................................................................................80 1.1.2. Kiến trúc của chương trình Client-Server cài đặt theo cơ chế lời gọi thủ tục xa 80 Hình 5.1 Kiến trúc chương trình kiểu RPC........................................................................80 1.2. Kích hoạt phương thức xa (RMI- Remote Method Invocation ) .........................81 1.2.1. Giới thiệu.......................................................................................................81 1.2.2. Kiến trúc của chương trình Client-Server theo cơ chế RMI .........................82 1.2.3. Các cơ chế liên quan trong một ứng dụng đối tượng phân tán .....................83 1.2.4. Cơ chế vận hành của của một ứng dụng Client-Server theo kiểu RMI ........84 1.2.5. Các lớp hỗ trợ chương trình theo kiểu Client-Server trong Java ..................85 1.3. Xây dựng một ứng dụng phân tán với RMI .........................................................85 1.3.1. Thiết kế và cài đặt các thành phần của ứng dụng..........................................85 1.3.2. Biên dịch các tập tin nguồn và tạo Stubs và Skeleton...................................85 1.3.3. Tạo các lớp có thể truy xuất từ mạng............................................................86 1.3.4. Thực thi ứng dụng .........................................................................................86 1.3.4. Ví dụ minh họa ..............................................................................................86 1.4. Bài tập áp dụng.....................................................................................................92 Mục lục...............................................................................................................................92 Biên Soạn: Ngô Bá Hùng - Nguyễn Công Huy 96
File đính kèm:
- giao_trinh_lap_trinh_truyen_thong_ngo_ba_hung.pdf