Bài giảng Mạng máy tính - Chương 5: Giao thức TCP/UDP - Nguyễn Hữu Thanh

Phát hiện tắc nghẽn Vấn đề: Làm sao để phát hiện tắc nghẽn? Khi xảy ra mất gói  hàng đợi tại các nút trung gian bị tràn  tắc nghẽn xảy ra TCP chuyển sang trạng thái phát hiện tắc nghẽn khi mất gói xảy ra: Không nhận được ACK (timeout) Nhận được 3 ACK trùng yêu cầu phát lại Phát hiện tắc nghẽn (tiếp )  Khi timeout (không nhận được ACK) TCP đặt ngưỡng ssthresh xuống còn một nửa giá trị hiện tại của cwnd TCP đặt cwnd về 1 MSS TCP chuyển về trạng thái slow start  Nếu nhận được 3 ACK trùng TCP đặt ngưỡng ssthresh xuống còn một nửa giá trị hiện tại của cwnd TCP đặt cwnd bằng ½ giá trị hiện tại TCP chuyển về trạng thái tránh tắc nghẽn

pdf33 trang | Chia sẻ: hachi492 | Lượt xem: 421 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Bài giảng Mạng máy tính - Chương 5: Giao thức TCP/UDP - Nguyễn Hữu Thanh, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
1PGS. TS. Nguyễn Hữu Thanh Bộ môn Kỹ thuật thông tin Viện Điện tử - Viễn thông ĐHBK Hà Nội Email: thanhnh@mail.hut.edu.vn Chương 5. Giao thức TCP/UDP Nội dung Giới thiệu chung UDP TCP Chức năng TCP Điều khiển luồng và chống tắc nghẽn trong TCP 23 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Đặt vấn đề  Ứng dụng trên mạng:  Đa dạng  Yêu cầu khác nhau về mặt chất lượng: ◊ Ứng dụng thời gian thực: trễ nhỏ ◊ Ứng dụng truyền số liệu (truyền file, web, email .v.v.): độ tin cậy cao, xác suất mất gói hoặc lôi gói phải ~ 0%  Nhiều ứng dụng tại 1 máy trạm cùng chia sẻ đường truy nhập Internet  Mạng Internet:  Chức năng chính: định tuyến (routing) và chuyển tiếp (forwarding)  Truyền tin không tin cậy ◊ Không có cơ chế đảm bảo thứ tự gói ◊ Không có cơ chế đảm bảo gói sẽ được truyền đến nơi nhận  Vấn đề: làm thế nào để truyền nhiều ứng dụng với các yêu cầu khác nhau trên giao thức IP không tin cậy, độc lập với ứng dụng? 4 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Đặt vấn đề (tiếp)  Cần các chức năng bổ sung giữa “Application” và “Internetwork” Network Access Internetwork Host-to-Host Application Mô hình Internet Điều khiển truy nhập kênh, biến đổi dòng bit theo kênh vật lý Định tuyến và chuyển tiếp, truyền tin không tin cậy IEEE 802.x IP, ICMP, routing protocols Ứng dụng truyền thông: truyền file, ứng dụng thời gian thực, web, email, VoIP .v.v. http, SIP, H.323, RTP, FTP, SMTP, POP, SNMP .v.v. ??? 35 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Chức năng của lớp Host-to-Host Lớp host-to-host thực hiện các chức năng bổ sung giữa “application” và “internetwork” Ghép nhiều luồng dữ liệu trên một thiết bị đầu cuối để truyền trên mạng IP Tăng độ tin cậy của luồng thông tin 6 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Chức năng của lớp Host-to-Host (tiếp ) Network Access Internetwork Host-to-Host Application Máy trạm Network Access Internetwork Host-to-Host Application Máy trạmRouter Network Access Internetwork Thông tin giữa 2 lớp cùng cấp 47 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Chức năng của lớp Host-to-Host (tiếp )  Tại sao các chức năng của host-to-host lại được thực hiện ở thiết bị đầu cuối? Router chỉ thực hiện các chức năng định tuyến và chuyển tiếp Router không cần lưu giữ trạng thái của một luồng dữ liệu (flow state) nâng cao hiệu năng của router các chức năng khác được đưa ra “rìa” của mạng 8 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế ghép kênh  Chức năng ghép kênh:  Chia nhỏ dữ liệu của người sử dụng thành các segment lớp host-to-host  Ghép nhiều luồng dữ liệu lớp ứng dụng vào để truyền trên mạng IP FTP HTTP Chat FTP HTTP Chat Application Host2Host Internetwork Network Access TCP/UDPmultiplexing demultiplexing application-layer protocols 59 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế ghép kênh (tiếp) Phương pháp ghép kênh: Mỗi ứng dụng (hay tiến trình) có một địa chỉ cổng (port number) khác nhau Địa chỉ cổng: 16 bit Các ứng dụng trao đổi dữ liệu qua “socket”. Mỗi socket được phân biệt qua 2 tham số: ◊Địa chỉ port ◊Địa chỉ IP 10 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế ghép kênh (tiếp)  Một số cổng điển hình:  0 – 1023: cổng mặc định định nghĩa bởi IANA ◊ FTP: 20, TCP ◊ SSH: 22, TCP/UDP ◊ Telnet: 23, TCP ◊ SMTP: 25, TCP ◊ DNS: 53, TCP/UDP ◊ HTTP: 80, TCP/UDP  Từ 1024: do người sử dụng tự định nghĩa  Socket được quản lý bởi hệ điều hành  Có thể tạo, trao đổi dữ liệu qua socket thông qua các API của HĐH socket 1 socket 2 socket 3 App1 App2 App3 Application Host-to-host 611 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế tăng độ tin cậy Độ tin cậy: Kiểm tra và chống lỗi: thêm các mã kiểm tra lỗi phần dữ liệu (CRC .v.v.) ◊ARQ (auto-repeat request) ◊FEC (forwarding error correction) Chống tắc nghẽn Câu hỏi: Sự khác nhau giữa ARQ và FEC? Trong giao thức IP có kiểm tra và chống lỗi không? Ở đâu? 12 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế tăng độ tin cậy (tiếp)  ARQ:  Trao đổi dữ liệu thông qua cơ chế: gửi – phúc đáp  Phân loại: ◊ Stop-and-Wait ◊ Go-Back-N ◊ Selective Repeat  Chức năng: ◊ Phát hiện lỗi gói ◊ Phát hiện mất gói ◊ Sắp xếp thứ tự gói ◊ Điều khiển luồng: điều chỉnh kích thước cửa số trượt  Câu hỏi:  Phân biệt các cơ chế Stop-and-Wait, Go-Back-N, Selective Repeat?  Tham khảo tài liệu môn “Cơ sở mạng thông tin” 713 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế tăng độ tin cậy (tiếp)  ARQ - Stop and Wait: RTT tp ts p1 ACK1 p0 ACK0 p1 lỗi NACK1 p1 ACK1 p1 p1 ACK1 mất gói t tim eo ut a) Không lỗi b) Lỗi gói c) Mất gói 14 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế tăng độ tin cậy (tiếp)  ARQ - Go-Back-N:  “Cumulative feedback” p1 p2 p3 ACK4 p4 p5 p6 a) Không lỗi p1 p2 p3 ACK2 p2 p3 p4 lỗigói b) Lỗi gói p1 p2 p3 ACK2 p2 p3 p4 mất gói c) Mất gói W=3 – kích thước cửa sổ 815 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế tăng độ tin cậy (tiếp)  ARQ - Selective Repeat p1 p2 p3 ACK4 p4 p5 p6 a) Không lỗi p1 p2 p3 NACK2 p2 p4 p5 lỗigói b) Lỗi gói NACK4 p1 p2 p3 ACK1 ACK3p4 p2 p5 mất gói c) Mất gói 16 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế tăng độ tin cậy (tiếp)  Điều khiển luồng trong ARQ: Để thay đổi tốc độ truyền: ◊ Thay đổi kích thước cửa sổ trượt W ◊ Thay đổi thời gian ACK để điều chỉnh RTT  Nhận xét: ARQ không thích hợp cho các dịch vụ thời gian thực: ◊ RTT lớn ◊ Băng thông của luồng dữ liệu bị giới hạn bởi W  ARQ được áp dụng trong TCP 917 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế tăng độ tin cậy (tiếp) Câu hỏi: Tính hiệu suất kênh truyền trong “Stop- and-Wait”, “Go-Back-N” và “Selective Repeat” khi: ◊Kênh truyền lý tưởng ◊Kênh chịu xác suất mất gói là Pe  Tham khảo bài giảng môn “Cơ sở mạng thông tin” 18 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế tăng độ tin cậy (tiếp) FEC: Bên phát không phát lại gói Bên thu có chức năng: ◊Kiểm tra lỗi ◊Nếu phát hiện gói lỗi: – Bên thu sửa lỗi (xác định vị trí bit lỗi) – Nếu lỗi không sửa được: hủy gói Nhận xét: ◊FEC thích hợp cho các dịch vụ thời gian thực 10 19 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Giao thức UDP  UDP – User Datagram Protocol  RFC 768  Gói tin UDP – UDP datagram  Đặc điểm:  Sử dụng cơ chế không liên kết (connectionless): không cần thiết lập một phiên truyền giữa nguồn – đích  UDP là giao thức không tin cậy ◊ Không có phúc đáp (ACK) ◊ Không cơ chế tự động phát lại ◊ Kiểm tra lỗi (checksum): chỉ kiểm tra phần đầu khung (header), không có kiểm tra lỗi phần dữ liệu ◊ Không có cơ chế phát hiện gói mất, gói đến không đúng thứ tự ◊ Không có cơ chế điều khiển luồng  UDP có thể gửi dữ liệu nhanh và nhiều nhất có thể  Chức năng cơ bản của UDP là gì? 20 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Giao thức UDP (tiếp)  Chức năng chính của UDP: Ghép/tách kênh App App A1 A2 App App B1 B2 UDP OS IP UDP Port 11 21 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Giao thức UDP (tiếp)  Cấu trúc gói UDP SRC port DST port checksum length DATA Chỉ bảo vệ phần header Kích thước phần data theo byte  UDP được dùng cho ứng dụng gì?  Các ứng dụng không cần độ tin cậy cao  Các phiên truyền ngắn, thiết lập kết nối hướng liên kết theo kiểu TCP đem lại hiệu suất thấp  Các ứng dụng thời gian thực 22 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Giao thức TCP  TCP – Transmission Control Protocol  RFC 793, 1122, 1323, 2018, 2581  Đặc điểm:  Hướng liên kết (connection-oriented) ◊ Thiết lập kết nối: “3-way handshake” – thiết lập kết nối 3 bước ◊ Huỷ bỏ kết nối: “2-way handshake” – huỷ bỏ kết nối 2 bước  Client – server: client thiết lập kết nối  TCP là giao thức truyền tin cậy: ◊ Cơ chế phúc đáp (ACK) khi nhận được dữ liệu ◊ Mã chống lỗi để bảo vệ dữ liệu ◊ Số thự tự (sequence number) để phát hiện gói mất và gói không đúng thứ tự ◊ Cơ chế timeout (sau một thời gian bên phát không nhật được ACK) để gửi lại dữ liệu ◊ Cơ chế sắp xếp lại thứ tự gói ở đầu thu ◊ Cơ chế điều khiển luồng sử dụng cửa sổ trượt ◊ Cơ chế chống tắc nghẽn để chia sẻ băng thông giữa nhiều nguồn dữ liệu 12 23 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Hướng liên kết  Không liên kết ở lớp Internetwork, hướng liên kết trên lớp Host-to-Host A B R1 R2 R3 R4 24 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Hướng liên kết (tiếp)  Thiết lập kết nối: 3-way handshake  Bước 1: A gửi SYN cho B ◊ chỉ ra giá trị khởi tạo seq # của A ◊ không có dữ liệu  Bước 2: B nhận SYN, trả lời bằng SYN/ACK ◊ B khởi tạo vùng đệm ◊ chỉ ra giá trị khởi tạo seq. # của B  Bước 3: A nhận SYN/ACK, trả lời ACK, có thể kèm theo dữ liệu  Ghi chú: phiên truyền TCP là phiên song công (số liệu truyền theo 2 hướng) Client A (chủ động) Server B (thụ động) Syn Syn + Ack Ack 13 25 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Hướng liên kết (tiếp)  Huỷ bỏ kết nối: 2-way handshake  Bước 1: Gửi FIN cho B  Bước 2: B nhận được FIN, trả lời ACK, đồng thời đóng liên kết và gửi FIN.  Bước 3: A nhận FIN, trả lời ACK, vào trạng thái “chờ”.  Bước 4: B nhận ACK. đóng liên kết.  Ghi chú: cả client hoặc server đều có thể yêu cầu huỷ bỏ kết nối Client A Server B Fin (Data +) Ack Fin Ack 26 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn TCP data segment  Dữ liệu lớp ứng dụng được đóng gói vào các “TCP segment”  MSS (Maximum Segment Size): chiều dài tối đa cho phép của 1 TCP segment Byte 0 Byte 1 Byte 2 Byte 3 Byte 0 Byte 1 Byte 2 Byte 3 Gửi Nhận Byte 80 TCP segment TCP segment Byte 80 14 27 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Bản tin TCP Src port Dst port Sequence Number ACK Sequence Number HLEN 4 RSVD 6 U RG A CK PS H RS T S YN FI N Flags Receive Window Size Checksum Urg Pointer (TCP Options) 0 15 31 TCP Data 28 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Ý nghĩa các trường Source/Destination Port: địa chỉ cổng Checksum: mã chống lỗi – cho cả TCP header và phần dữ liệu Receive Window Size (RWND): kích thước cửa sổ trượt bên nhận  chỉ ra lượng dữ liệu tối đa bên thu có thể tiếp nhận  điều khiển luồng 15 29 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Sequence Number  Sequence Number: số thứ tự TCP segment Gửi Nhận TCP Data TCP Data TCP HDR TCP HDR ISN (initial sequence number) Sequence number = số thứ tự byte đầu STT ACK = byte tiếp theo bên thu đợi nhận 30 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Sequence Number (tiếp) Sequence number: Số thứ tự byte đầu tiên của 1 segment  sequence number của TCP segment Được tính bằng byte 16 31 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Initial Sequence Number  ISN – giá trị thứ tự khởi tạo Được thiết lập trong giai đoạn bắt tay 3 bước để khởi tạo kết nối Client A Server B Syn +ISNA Syn + Ack +ISNB Ack 32 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cửa sổ trượt trong TCP Vấn đề: Một kết nối TCP có thể gửi bao nhiêu gói dữ liệu liên tiếp qua mạng? Khi lỗi xảy ra, TCP truyền lại gói thế nào? Sử dụng cơ chế “selective repeat” hay “Go-Back-N”? Làm cách nào để TCP không làm tràn bộ đệm bên thu? 17 33 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cửa sổ trượt trong TCP (tiếp)  Kích thước cửa sổ phải điều chỉnh cho phù hợp với bộ đệm của bên thu  Kích thước cửa sổ tối đa bên thu cho phép sẽ được gửi cho bên phát RWND trong trường Receive Window Size (thông thường từ 4kB – 8kB)  Cơ chế truyền lại trong TCP: Go-Back-N Dữ liệu đã gửi và chưa nhận được ACK Kích thước cửa sổ Dữ liệu được phép gửi Dữ liệu chưa được phép gửi Dữ liệu đã gửi và nhận được ACK Dữ liệu 34 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cửa sổ trượt trong TCP (tiếp)  Lựa chọn kích thước cửa sổ: RTT > Window Size: hiệu suất kênh truyền thấp RTT= Window Size: hiệu suất kênh  100% Phát (A) Thu (B) ACK Window Size Round-trip time (RTT) ACK Window Size??? ACK Window Size Round-trip time (1) RTT > Window size (2) RTT = Window size 18 35 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế truyền lại  TCP sử dụng đồng hồ timeout để truyền lại  Sau khoảng thời gian RTO>RTT, nếu không nhận được gói  truyền lại  RTO là giá trị thay đổi, thích ứng với trạng thái kênh. Nguyên nhân:  Tắc nghẽn, đường đi thay đổi  RTT thay đổi  RTO cũng thay đổi theo  Câu hỏi:  Giá trị RTO được tính thế nào?  Nếu RTO quá lớn/quá bé thì sao? Phát (A) Thu (B) ACK Round-trip time (RTT) ACK Retransmission TimeOut (RTO) Estimated RTT Data1 Data2 Guard Band 36 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế truyền lại (tiếp)  Ước lượng giá trị RTO:  Vấn đề: ◊ Nếu giá trị RTO quá lớn: trễ truyền lại lớn ◊ Nếu giá trị RTO quá nhỏ: phát trùng gói không cần thiết  Thuật toán ước lượng RTO – sử dụng phương pháp “trung bình cửa sổ trượt theo trọng số mũ” (Exponential Weighted Moving Average - EWMA) ◊ Gọi: –  – trọng số thuật toán EWMA (0 ≤  ≤ 1, thông thường  =0,125) – k – số bước lặp – EstimatedRTT: giá trị RTT ước lượng theo EWMA – SampleRTT: giá trị RTT đo được tại bước k ◊ Thuật toán: 1. EstimatedRTTk=  EstimatedRTTk-1 + (1 - ) SampleRTT 2. RTO = 2 * EstimatedRTT 19 37 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế truyền lại (tiếp) RTT: gaia.cs.umass.edu to fantasia.eurecom.fr 100 150 200 250 300 350 1 8 15 22 29 36 43 50 57 64 71 78 85 92 99 106 time (seconnds) RT T (m ill ise co nd s) SampleRTT Estimated RTT 38 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế truyền lại (tiếp)  Trong thuật toán trên  Giả thiết: Phương sai của giá trị RTT là hằng số  Trong thực tế: ◊ Chiều dài hàng đợi của router tăng dần khi tải tăng ◊ Phương sai của RTT tăng nhanh khi tải tăng ◊ Phân bố xác suất của RTT không xác định  Yêu cầu:  Ước lượng RTT chính xác để tránh ước lượng sai RTO Tải tới hàng đợi router Tr ế tru ng bì nh Phương sai tăng nhanh khi tải tăng RTT X ác su ất kỳ vọng Phương sai 20 39 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế truyền lại (tiếp)  Thuật toán ước lượng RTO mới: Cho phép đánh giá cả phương sai của RTT 1. EstimatedRTTk =  EstimatedRTTk-1 + (1 - ) SampleRTT 2. Differencek = (1 - )*Differencek-1 +  *|SampleRTT - EstimatedRTTk| 3. RTO =  * EstimatedRTTk +  *Differencek   0,125;   1;   4;   0,25 40 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Cơ chế truyền lại (tiếp)  Thuật toán Karn:  Vấn đề: Khi truyền lại thì RTT được ước lượng thế nào cho chính xác?  Giải pháp: ◊ Không cập nhật giá trị EstimatedRTT ◊ RTOk=2 * RTOk-1 Truyền lại RTT sai Host A Host B Truyền lại RTT sai Host A Host B 21 41 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Tắc nghẽn trong Internet  Tắc nghẽn trong mạng thường xuyên xảy ra và không thể tránh được  Tắc nghẽn xảy ra ở nhiều cấp độ khác nhau (mức gói, mức luồng .v.v.)  Bên phát TCP phải có khả năng phát hiện tắc nghẽn và giảm tắc nghẽn (giảm kích thước cửa sổ trượt)  Router cũng có thể giảm tốc độ luồng TCP bằng cách tăng trễ hàng đợi (khi tải tăng) 42 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Tắc nghẽn trong Internet (tiếp)  Tắc nghẽn xảy ra khi tải tới nút mạng tăng ( 100%) A1(t) A2(t) D(t) X(t) Cu m ul at iv e by te s t Atotal(t) H1 H2 R1 H3 A1(t) 10Mb/s D(t) 1.5Mb/s A2(t) 100Mb/s A1(t) A2(t) X(t) D(t) 22 43 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Tắc nghẽn trong Internet (tiếp)  Các cấp độ của tắc nghẽn Mức người sử dụng: quá nhiều người truy nhập trong giờ cao điểm Mức luồng: các luồng dữ liệu chiếm trọn dung lượng kênh đầu ra Mức gói: 2 gói xung đột tại router 7:00 8:00 9:00 1s 2s 3s 100µs 200µs 300µs 44 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Tắc nghẽn trong Internet (tiếp)  Tắc nghẽn và trễ: RTT bao gồm: ◊ Trễ lan truyền (propagation delay) ◊ Trễ hàng đợi (queue delay) Thông thường trễ hàng đợi đóng vai trò quyết định đến RTT Trễ hàng đợi phụ thuộc vào chiều dài hàng đợi  tải tăng thì trễ tăng. Khi tắc nghẽn xảy ra  trễ hàng đợi lớn  RTT là đại lượng được sử dụng để ước lượng tắc nghẽn trong mạng (TD: ping) 23 45 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Tránh tắc nghẽn trong Internet  TD: 2 luồng dữ liệu đến router R1 ? A1(t) A2(t) Chính sách Yêu cầu các luồng giảm tốc độ Chuyển thời gian phục vụ một luồng tới thời điểm muộn hơn Đệm một luồng trong bộ đệm cho đến khi luồng kia được phục vụ xong Từ chối một luồng 46 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Tránh tắc nghẽn trong Internet (tiếp)  Nhận xét: tắc nghẽn không thể tránh khỏi Cơ chế hợp kênh thống kê trong chuyển mạch gói cho phép sử dụng kênh truyền hiệu quả  bộ đệm thường xuyên bị đầy Nếu bộ đệm rỗng  trễ nhỏ, mạng không bị tắc nghẽn. Nhưng: hiệu suất sử dụng kênh thấp Nếu bộ đệm luôn đầy  trễ lớn, tắc nghẽn. Nhưng: hiệu suất sử dụng kênh cao  Tắc nghẽn thế nào là vừa phải? 24 47 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Tải, trễ và hiệu năng  Quan hệ giữa tải và trễ:  Tải: L (bit/s)  Trễ: D (s)  Gọi P là một tham số đơn giản để đánh giá hiệu năng mạng, với:  P=L/D  P càng lớn càng tốt Tr ễ tr un g bì nh Tải Hiệu năng Tải“Tải tối ưu” 48 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Chống tắc nghẽn trong TCP  Yêu cầu: TCP phải ước lượng chính xác băng thông còn thừa Thay đổi tốc độ phát theo tình trạng kênh: ◊ Tăng tốc độ phát khi còn băng thông ◊ Khi tắc nghẽn xảy ra  giảm tốc độ phát t Băng thông Băng thông còn thừa C 25 49 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Chống tắc nghẽn trong TCP (tiếp)  Bên phát TCP thay đổi tốc độ bằng việc thay đổi kích thước cửa sổ  “cwnd” hoạt động theo cơ chế: Tăng kích thước cửa sổ theo cấp số cộng Giảm kích thước cửa sổ theo cấp số nhân Window=min{ReceiveWindow, CongestionWindow} RWND bên thu CWND bên phát 50 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Chống tắc nghẽn trong TCP (tiếp)  Các trạng thái của 1 luồng TCP: “slow start”: ◊ Khi mới khởi tạo luồng ◊ Kích thước cwnd tăng theo hàm mũ cho đến mức ngưỡng ssthresh Tránh tắc nghẽn: ◊ Từ mức ssthresh, kích thước cửa sổ tăng thêm một MSS (maximum segment size) sau mỗi chu kỳ RTT kích thước cửa sổ tăng tuyến tính đến khi phát hiện tắc nghẽn Phát hiện tắc nghẽn: ◊ Tắc nghẽn xảy ra khi gói tin bị mất  TCP giảm kích thước cửa sổ xuông một nửa. 26 51 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn “Slow Start”  Mục đích: cho phép phiên TCP tăng tốc độ nhanh chóng sau khi thiết lập kết nối  Nguyên tắc:  cwnd = 1 (MSS)  Tăng cwnd 1 đơn vị mỗi khi nhận được ACK  kích thước cwnd tăng theo cấp số nhân D A D D A A D D A A D A Src Dest D A 4 81 2 52 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Tránh tắc nghẽn  Tránh tắc nghẽn – congestion avoidance  Nguyên tắc:  Sau khi kích thước cwnd đạt đến giá trị ssthresh, kết nối TCP chuyển sang chế độ tránh tắc nghẽn  cwnd tăng một đơn vị (01 MSS) sau một RTT không có gói lỗi  cwnd tăng tuyến tính D A D D A A D D A AD A Src Dest 1 2 3 4 27 53 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Phát hiện tắc nghẽn Vấn đề: Làm sao để phát hiện tắc nghẽn? Khi xảy ra mất gói  hàng đợi tại các nút trung gian bị tràn  tắc nghẽn xảy ra TCP chuyển sang trạng thái phát hiện tắc nghẽn khi mất gói xảy ra: Không nhận được ACK (timeout) Nhận được 3 ACK trùng yêu cầu phát lại 54 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Phát hiện tắc nghẽn (tiếp)  Khi timeout (không nhận được ACK) TCP đặt ngưỡng ssthresh xuống còn một nửa giá trị hiện tại của cwnd TCP đặt cwnd về 1 MSS TCP chuyển về trạng thái slow start  Nếu nhận được 3 ACK trùng TCP đặt ngưỡng ssthresh xuống còn một nửa giá trị hiện tại của cwnd TCP đặt cwnd bằng ½ giá trị hiện tại TCP chuyển về trạng thái tránh tắc nghẽn 28 55 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Phát hiện tắc nghẽn (tiếp)  Nhận xét: cửa sổ cwnd có dạng răng cưa 2 4 6 8 10 12 14 16 18 20 22 Timeout 3 ACKs SS SS AI AI AI Threshold=16 Threshold=10 Threshold=6 Threshold is set to half of cwnd (20) And slow start starts Threshold is set to half of cwnd (12) And additive increase starts cwnd Time 56 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Thông lượng của phiên TCP Trong một chu kỳ RTT: số byte phiên TCP gửi là cwnd Gọi R – thông lượng phiên TCP R=cwnd/RTT Câu hỏi: Dạng lưu lượng một phiên TCP có tuân theo dạng răng cưa không? 29 57 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Thông lượng của phiên TCP (tiếp) 58 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Thông lượng của phiên TCP (tiếp)  Nhận xét: Dạng lưu lượng TCP không nhất thiết có dạng răng cưa. Như trong hình trước, lưu lượng là hằng số.  Nguyên nhân: Nếu độ lớn của bộ đệm tại router đủ lớn: ◊ Số gói đến router tăng  kích thước bộ đệm tăng  RTT tăng tỷ lệ với cwnd lưu lượng TCP là hằng số  Có 2 cách tránh tắc nghẽn: 1. Đệm gói đến để tăng RTT 2. Huỷ gói để giảm kích thước cửa sổ cwnd 30 59 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Tính công bằng của TCP Mục tiêu: Nếu có n luồng TCP chia sẻ kênh truyền có dung lượng C  mỗi luồng được chia sẻ băng thông C/n TCP 1 R TCP 2 C 60 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Tính công bằng của TCP (tiếp)  TCP cho phép chia sẻ băng thông công bằng  Xét 2 luồng TCP chia sẻ băng thông C. C C Điểm chia sẻ công bằng Thông lượng luồng 1 Th ôn g lư ợ ng lu ồn g 2 congestion avoidance: additive increase loss: decrease window by factor of 2 congestion avoidance: additive increase loss: decrease window by factor of 2 31 61 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Tính công bằng của TCP (tiếp) TCP công bằng đến đâu? Các ứng dụng có thể mở song song nhiều luồng TCP ◊Web browser ◊Flashget TD: ◊một liên kết dung lượng C phục vụ 10 luồng TCP  mỗi luồng nhận băng thông trung bình là C/10 ◊ứng dụng mới mở thêm 10 luồng TCP  ứng dụng đó nhận được băng thông C/2 62 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Đồng bộ giữa nhiều luồng TCP  Vấn đề:  Khi truyền nhiều luồng TCP với cùng thời gian bắt đầu và RTT A B C D RTT Luồng A N RTT 32 63 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Đồng bộ giữa nhiều luồng TCP (tiếp) Băng thông tổng cộng f(RTT) trung bình 64 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Đồng bộ giữa nhiều luồng TCP (tiếp)  Nếu thay đổi thời gian bắt đầu giữa các luồng (không đồng bộ)  băng thông tổng hợp ít dao động hơn Nguồn A N RTT 33 65 CHƯƠNG 5 – UDP/TCP PGS. TS. Nguyễn Hữu Thanh Giới thiệu UDP TCP Chông tắc nghẽn Đồng bộ giữa nhiều luồng TCP (tiếp) Băng thông tổng hợp Trung bình N RTT Tài liệu tham khảo  Internetworking with TCP/IP, Vol 1, Douglas Comer, Prentice Hall Computer  Karn, Phil; Craig Partridge, "Improving Round- Trip Time Estimates in Reliable Transport Protocols“, ACM SIGCOMM '87. pp. 2–7  Computer Networks, Nick McKeown, Stanford University  Networking: a top-down approach featuring the Internet, James F. Kurose, Keith W. Ross, Addison Wesley, 4thed, 2006  Một số tài liệu và bài giảng khác trên Internet

Các file đính kèm theo tài liệu này:

  • pdfbai_giang_mang_may_tinh_chuong_5_giao_thuc_tcpudp_nguyen_huu.pdf