Bài giảng Mạng máy tính - Chương 7: Tầng vận chuyển (Computer Network) - Ngô Bá Hùng

pdf 30 trang ngocly 150
Bạn đang xem 20 trang mẫu của tài liệu "Bài giảng Mạng máy tính - Chương 7: Tầng vận chuyển (Computer Network) - Ngô Bá Hùng", để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên

Tài liệu đính kèm:

  • pdfbai_giang_mang_may_tinh_chuong_7_tang_van_chuyen_computer_ne.pdf

Nội dung text: Bài giảng Mạng máy tính - Chương 7: Tầng vận chuyển (Computer Network) - Ngô Bá Hùng

  1. TẦNG VẬN CHUYỂN (Computer Network) Trình bày: Ngô Bá Hùng Khoa CNTT&TT Đại Học Cần Thơ
  2. Mục đích  Chương này nhằm giới thiệu với người đọc những nội dung sau: • Vai trò của tầng vận chuyển và các chức năng mà tầng vận chuyển cung cấp cho tầng ứng dụng • Ý nghĩa và cơ chế thiết lập nối kết và giải phóng nối kết cho các nối kết điểm – điểm • Chi tiết về hay giao thức TCP và UDP thuộc tầng vận chuyển Đại Học Cần Thơ - Khoa CNTT
  3. Yêu cầu  Sau khi học xong chương này, người học phải có được những khả năng sau: • Biện luận được sự cần thiết của tầng vận chuyển trong một liên mạng • Giải thích được cơ chế thiết lập và xóa nối kết các cuộc giao tiếp điểm-điểm của tầng vận chuyển • Trình bày được nguyên tắc hoạt động của hai giao thức TCP và UDP của mạng Internet Đại Học Cần Thơ - Khoa CNTT
  4. Nhiệm vụ của tầng vận chuyển  Tầng mạng đảm bảo truyền tải kiểu Host -to- Host  Tầng vận chuyển đảm bảo truyền tải kiểu End point –to- End point  End point là các chương trình ứng dụng  Cấp dịch vụ vận chuyển gói tin hiệu quả, tin cậy và tiết kiệm chi phi cho người dùng Đại Học Cần Thơ - Khoa CNTT
  5. Vị trí của tầng vận chuyển Đại Học Cần Thơ - Khoa CNTT
  6. Dịch vụ cung cấp bởi tầng vận chuyển  Hai kiểu dịch vụ • Có nối kết : • Thiết lập nối kết, • Truyền dữ liệu • Hủy nối kết • Không nối kết  Các hàm dịch vụ cơ sở để triệu gọi các dịch vụ vận chuyển và các hàm này là đơn giản, duy nhất và độc lập với các hàm cơ sở ở tầng mạng Đại Học Cần Thơ - Khoa CNTT
  7. Các hàm dịch vụ cơ sở - Có nối kết Hàm Gói tin gởi đi Ý nghĩa LISTEN Không có Nghẽn cho đến khi tiến trình nào đó nối kết tới Yêu cầu kết nối CONNECT Chủ động yêu cầu thiết lập nối kết đến tiến trình khác (Connection Request) SEND Dữ liệu (Data) Gởi thông tin đi RECEIVE Không có Nghẽn cho đến khi một gói tin đến và nhận nó Yêu cầu hủy kết nối DISCONNECT Muốn hủy kết nối với bên đối tác (Disconnection Request) Đại Học Cần Thơ - Khoa CNTT
  8. Các hàm dịch vụ cơ sở - Không nối kết Hàm Gói tin gởi đi Ý nghĩa SEND Dữ liệu (Data) Gởi thông tin đi RECEIVE Không có Nghẽn cho đến khi một gói tin đến và nhận nó Đại Học Cần Thơ - Khoa CNTT
  9. Các yếu tố cấu thành giao thức vận chuyển  Điều khiển lỗi, đánh số thứ tự gói tin và điều khiển luồng dữ liệu.  Môi trường giao tiếp qua một tập các mạng trung gian  Những vấn đề cần quan tâm: • Định địa chỉ các tiến trình trên các host • Xử lý những trường hợp mất gói tin, gói tin đi chậm dẫn đến mãn kỳ và gởi thêm một gói tin bị trùng lắp, • Đồng bộ hóa hai tiến trình đang trao đổi dữ liệu khi mà chúng đang ở rất xa nhau Đại Học Cần Thơ - Khoa CNTT
  10. Định địa chỉ  Địa chỉ tiến trình là TSAP (Transport Service Access Point). • Mạng Internet là dùng số hiệu cổng (port), • Mạng ATM là AAL- SAP.  Tầng mạng được gọi là NSAP Đại Học Cần Thơ - Khoa CNTT
  11. Thiết lập nối kết Three-way hand-shake Bản CR bị trùng lắp Hoạt động bình thường. Đại Học Cần Thơ - Khoa CNTT
  12. Thiết lập nối kết Cả CR và ACK đều bị trùng lắp Đại Học Cần Thơ - Khoa CNTT
  13. Giải phóng nối kết  Hai kiểu giải phóng nối kết: • Kiểu dị bộ hoạt động như sau: khi một bên cắt nối kết, kết nối sẽ bị hủy bỏ (giống như trong hệ thống điện thoại). • Kiểu đồng bộ làm việc theo phương thức ngược lại: khi cả hai đồng ý hủy bỏ nối kết, nối kết mới thực sự được hủy Đại Học Cần Thơ - Khoa CNTT
  14. Giải phóng nối kết dị bộ Đại Học Cần Thơ - Khoa CNTT
  15. Giải phóng nối kết đồng bộ  Một nút phải tiếp tục nhận dữ liệu sau khi đã gởi đi yêu cầu giải phóng nối kết (DISCONNECT REQUEST – CR), cho đến khi nhận được chấp thuận hủy bỏ nối kết của bên đối tác đó  Sử dụng phương pháp hủy nối kết ba chiều cùng với bộ định thời Đại Học Cần Thơ - Khoa CNTT
  16. Giải phóng nối kết đồng bộ Bình thường Khung ACK cuối cùng bị mất Đại Học Cần Thơ - Khoa CNTT
  17. Giải phóng nối kết đồng bộ Trả lời bị mất Trả lời mất và các gói tin DR theo sau cũng bị mất Đại Học Cần Thơ - Khoa CNTT
  18. Điều khiển thông lượng  Sử dụng giao thức cửa sổ trượt với kích thước cửa sổ của bên gởi và bên nhận là khác nhau  Cần phải có sơ đồ cung cấp buffer động: • Trước tiên, bên gởi phải gởi đến bên nhận một yêu cầu dành riêng số lượng buffer để chứa các gói bên gởi gởi đến. • Bên nhận cũng phải trả lời cho bên gởi số lượng buffer tối đa mà nó có thể cung cấp. • Mỗi khi báo nhận ACK cho một gói tin có số thứ tự SEQ_NUM, bên nhận cũng phải gởi kèm theo thông báo cho bên gởi biết là lượng buffer còn lại là bao nhiêu để bên gởi không làm ngập bên nhận Đại Học Cần Thơ - Khoa CNTT
  19. Điều khiển thông lượng Đại Học Cần Thơ - Khoa CNTT
  20. Điều khiển thông lượng Đại Học Cần Thơ - Khoa CNTT
  21. Tầng vận chuyển trong mạng Internet  Nhiệm vụ • Đảm bảo việc phân phối thông điệp qua mạng. • Phân phối các thông điệp theo thứ tự mà chúng được gởi. • Không làm trùng lắp thông điệp. • Hỗ trợ những thông điệp có kích thước lớn. • Hỗ trợ cơ chế đồng bộ hóa. • Hỗ trợ việc liên lạc của nhiều tiến trình trên mỗi host  Hỗ trợ hai phương thức hoạt động • Không nối kết (UDP) • Có nối kết (TCP) Đại Học Cần Thơ - Khoa CNTT
  22. Giao thức UDP (User Datagram Protocol)  UDP là dịch vụ truyền dữ liệu dạng không nối kết.  Không có thiết lập nối kết giữa hai bên truyền nhận,  Gói tin UDP (segment) có thể xuất hiện tại nút đích bất kỳ lúc nào.  Các segment UDP tự thân chứa mọi thông tin cần thiết để có thể tự đi đến đích. Đại Học Cần Thơ - Khoa CNTT
  23. Giao thức UDP (User Datagram Protocol) 0 16 31  Checksum:Là phần kiểm SrcPort DstPort tra lỗi tổng hợp trên Length Checksum phần header, phần dữ Data liệu và cả phần header ảo.  Phần header ảo chứa 3 trường trong IP header: địa chỉ IP nguồn, địa chỉ IP đích, và trường chiều dài của UDP. Đại Học Cần Thơ - Khoa CNTT
  24. Giao thức UDP (User Datagram Protocol)  Phương pháp kiểm tra lỗi • u_short • cksum(u_short *buf, int count) • { • register u_long sum = 0; • while (count ) • { • sum += *buf++; • if (sum & 0xFFFF0000) • { • /* bit carry xuất hiện, vì thế gấp và cộng dồn nó lại */ • sum &= 0xFFFF; • sum++; • } • } • return ~(sum & 0xFFFF); • } Đại Học Cần Thơ - Khoa CNTT
  25. Giao thức TCP (Transmission Control Protocol)  TCP là giao thức cung cấp dịch vụ vận chuyển tin cậy, hướng nối kết theo kiểu truyền thông tin bằng cách phân luồng các bytes.  TCP là giao thức truyền song công, hỗ trợ cơ chế đa hợp  TCP là giao thức hướng bytes Đại Học Cần Thơ - Khoa CNTT
  26. Giao thức TCP (Transmission Control Protocol) Đại Học Cần Thơ - Khoa CNTT
  27. Giao thức TCP (Transmission Control Protocol) Bắt tay trong TCP Hủy bắt tay trong TCP Đại Học Cần Thơ - Khoa CNTT
  28. Điều khiển thông lượng trong TCP  Là giao thức truyền hướng bytes  Mỗi lần truyền đi một Segment Đại Học Cần Thơ - Khoa CNTT
  29. Điều khiển thông lượng trong TCP  Sử dụng giao thức cửa sổ trượt Đại Học Cần Thơ - Khoa CNTT
  30. Giao thức TCP (Transmission Control Protocol) Flags = [ SYN, FIN, RESET, PUSH, URG, ACK] Đại Học Cần Thơ - Khoa CNTT