Sử dụng IP cho mạng di động thế hệ mới

Từ những thời gian đầu vào những năm 70 và 80 của Internet và cho đến ngày nay, Internet đã tạo lập cho mình một vị trí thống trị trong truyền thông toàn cầu cho phép tạo ra một số lượng rất đa dạng các ứng dụng máy tính. Các ứng dụng Internet hiển nhiên là hết sức cần thiết xét từ góc độ Internet, nhưng tất cả các dự báo đều cho thấy các ứng dụng này cũng trở nên cần thiết với hầu hết các mạng vô tuyến trong tương lai. Ngành công nghiệp này cũng đã nhận thức được rất rõ các hạn chế của giao thức IPv4, các nhà cung cấp mạng di động thế hệ sau cũng như các nhà cung cấp thiết bị cho biết họ cần số lượng địa chỉ IP cho hàng triệu thiết bị. Một trong những tiêu chí chính của các nhà khai thác mạng di động tương lai là khả năng luôn luôn kết nối với mạng của người sử dụng. Điều này đòi hỏi một số lượng lớn địa chỉ IP. IPv6 cung cấp thêm nhiều khả năng trong đó đáng chú ý nhất là sự mở rộng về không gian địa chỉ, IPv6 có không gian địa chỉ là 128 bit trong khi IPv4 chỉ sử dụng 32 bit. Việc tổ hợp IPv6 và các hệ thống di động (như GSM/GPRS và UMTS) sẽ giảm thiểu được các vấn đề hiện tại về sự thiếu hụt của cả hai bên IP và mạng di động: thiếu địa chỉ IP, chất lượng dịch vụ và bảo mật trong IP và sự thiếu hụt phổ tần trong mạng di động. Bằng cách tổ hợp hai công nghệ này, có thể đảm bảo cung cấp lợi ích tốt nhất cho người sử dụng di động đầu cuối. Trong luận văn này trình bày các vấn đề cần thiết khi đưa IPv6 vào mạng di động tương lai. Chương 1 trình bày tổng quan về mạng 3G, chương 2 giới thiệu về mobile IP, chương 3 trình bày về IPv6 và chương 4 đưa ra các giải pháp thực hiện IPv6 trên nền IPv4.

pdf113 trang | Chia sẻ: banmai | Lượt xem: 1784 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Sử dụng IP cho mạng di động thế hệ mới, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
sequence number tuy nhiên node đích phải kiểm tra trường nay để bật dịch vụ anti-replay. Để cung cấp dịch vụ xác thực nguồn traffic thì thông tin về nguồn và đích thực phải được che đi. Do đó, dịch vụ này yêu cầu ESP header được sử dụng trong tunnel mode. Hình 3.21 sẽ mô tả định dạng của ESP header. Giá trị next header của header trước nếu bằng 50 nghĩa là header tiếp theo được xử lý chính là ESP header. Trường payload data chứa dữ liệu đã được Hình 3.20. Thứ tự của các header khi áp AH vào tunnel mode. 76 mã hoá được mô tả bởi trường next header. Giải thuật mã hoá được sử dụng xác định kích thước và vị trí của cấu trúc dữ liệu trong trường payload data. thì thứ tự của các header trong IPv6 packet sẽ như sau: Hình 3.21. Định dạng của ESP header Hình 3.23. Thứ tự của các header trong IPv6 khi hoạt động ở transport mode. 77 Và ở tunnel mode sẽ có thứ tự như sau: Hình 3.24. Thứ tự của các header trong IPv6 khi hoạt động ở tunnel mode. 78 CHƯƠNG 4. GIẢI PHÁP THỰC HIỆN IPv6 TRÊN NỀN IPv4 4.1. Các vấn đề chung. IPv6 là một giao thức Internet mới được thiết kế nhằm đáp ứng các yêu cầu về phát triển các dịch vụ mới và mở rộng không gian địa chỉ trên mạng Internet, đồng thời khắc phục những hạn chế khác của IPv4 hiện nay không hỗ trợ tính “mở” của giao thức, dịch vụ QoS, các chức năng bảo mật… Tuy nhiên hai giao thức IPv4 và IPv6 không thật sự tương thích với nhau. Mặt khác, hệ thống IPv4 đã phát triển mạnh mẽ và hiện nay đã hình thành một mạng Internet toàn cầu có quy mô hết sức rộng lớn cả về kiến trúc mạng và dịch vụ trên mạng. Do vậy trong một tương lai gần không thể chuyển đổi mạng toàn bộ hệ thống mạng IPv4 hiện nay sang hệ thống mạng IPv6. Để triển khai mạng IPv6 hiệu quả và thiết thực, các nhà thiết kế IPv6 đã đưa ra các giải pháp sau: - Xây dựng các cơ chế chuyển đổi cho phép kết nối các host/router IPv6 trên nền cơ sở hạ tầng của mạng IPv4 hiện nay. - Song song là triển khai kết nối các mạng IPv6 lại với nhau hình thành một mạng IPv6 toàn cầu (kết nối vào mạng thử nghiệm 6Bone). Thách thức mà IPv6 phải đối mặt là khả năng chuyển đổi “trọn vẹn” các gói tin IPv6 từ định dạng theo giao thức IPv6 sang IPv4 để từ đó có thể vận chuyển trên nền hạ tầng là mạng IPv4, vì hầu hết các thiết bị kết nối mạng Internet hiện nay đều được thiết kế cho IPv4. Để thực hiện yêu cầu này, quá trình triển khai IPv6 phải đảm bảo tính linh động một cách tối đa, nhưng điều này mâu thuẫn với quy mô rộng lớn của mạng Internet. Do vậy, đây cũng thể coi là một điểm chính trong quá 79 trình thiết kế IPv6, đảm bảo sự thành công của mạng IPv6. Không đảm bảo được yêu cầu trên sẽ không có sự thành công của mạng IP6. Ví dụ : trước đây đã có một vài giao thức được thiết kế để thử thay thế TCP/IPv6, như XTP nhưng đã không thể thành công là do không có khả năng chạy song song (dual stack), hay không có tính tương thích lẫn nhau giữa các họ giao thức cũ và mới. IPv6 cũng vậy, nếu với các đặc tính ưu việt của nó so với IPv4 cũng chưa đủ để thuyết phục người dùng bỏ mạng IPv4 hiện nay để xây dựng mạng IPv6, do vậy cần phải đảm bảo tính tương thích trên cơ sở các chức năng của IPv4 trong quá trình chuyển đổi sang IPv6. Để triển khai mạng IPv6 có các phương thức diễn ra đồng thời là xây dựng mạng IPv6 trên nền hạ tầng là mạng IPv4 hiện nay, sau đó thay thế dần mạng IPv4 hiện nay. Mục đích của các cơ chế chuyển đổi là đảm bảo một số chức năng chính như sau: - Đảm bảo thực hiện các đặc tính ưu việt của mạng IPv6 so với mạng IPv4. - Tận dụng hạ tầng sẵn có của mạng Ipv4 trong giai đoạn chuyển tiếp sang một mạng thuần IPv6. - Tăng cường khả năng nâng cấp và triển khai. Việc chuyển đổi đối với các host/router không bị phụ thuộc vào nhau. - Tối thiểu hoá sự phụ thuộc trong các quá trình nâng cấp. Một trong những điều kiện bắt buộc để nâng cấp host tới IPv6 là hệ thống DNS server hỗ trợ IPv6. Các điều kiện đối với các router như hỗ trợ các giao thức định tuyến BGP4+, hỗ trợ IPv6 … chưa phải là bắt buộc. - Gán và cấp phát các loại địa chỉ thuận tiện. Khi các hệ thống IPv4 được cài đặt được gán các địa chỉ IPv4, mặt khác địa chỉ IPv4 là một tập con của địa chỉ IPv6, do vậy có thể tiếp tục sử dụng với các địa chỉ IPv4 sẵn có. 80 Chỉ gán các địa chỉ IPv6 thật sự cần thiết cho các kết nối tới 6Bone và tuân theo các kế hoạch phân bổ địa chỉ của tổ chức đó. - Giá thành khởi điểm thấp. Vì không cần chuẩn bị cần thiết để nâng cấp các hệ thống từ IPv4 sang IPv6 khi triển khai một hệ thống IPv6 mới. Cơ chế này được thực hiện hoàn toàn trên nền IPv4 đã có. Cơ chế chuyển đổi của IPv6 là có thể kết hợp các trạm IPv6 cùng làm việc với các trạm IPv4 ở bất kỳ nơi nào trên Internet cho đến khi địa chỉ IPv4 không còn tồn tại, và cho phép các trạm IPv6 và IPv4 trong một không gian giới hạn để cùng làm việc sau đó. Các cơ chế này bảo đảm khoản đầu tư to lớn của người dùng trong việc xây dựng hệ thống mạng IPv4 đồng thời triển khai được mạng IPv6. Hiện nay số lượng các mạng IPv4 là rất lớn, hầu hết các dịch vụ và các giao dịch trên mạng đều dựa trên hạ tầng mạng IPv4. Do vậy xuất hiện nhiều cơ chế chuyển đổi cho phép kết nối các host IPv6 qua mạng IPv4. Việc xây dựng lại các giao thức của tầng Internet trong mô hình TCP/IP đã dẫn đến nhiều thay đổi. Trong đó vấn đề thay đổi lớn nhất của IPv6 với IPv4 là việc thay đổi cấu trúc địa chỉ. Sự thay đổi này ảnh hưởng đến các vấn đề sau: - Ảnh hưởng tới hoạt động của các giao thức ở tầng trên (tầng giao vận và tầng ứng dụng). - Ảnh hưởng tới các phương thức định tuyến. Mặt khác, một yêu cầu quan trọng trong việc triển khai IPv6 là phải thực hiện được mục tiêu ban đầu đề ra khi thiết kế giao thức IPv6 đó là: IPv6 phải làm việc được trong môi trường sử dụng giao thức IPv4. Sẽ có hiện tượng chỉ có những host dùng duy nhất IPv6 và đồng thời cũng tồn tại những host chỉ duy nhất có IPv4. Đồng thời những host “thuần” IPv6 đó phải giao tiếp được 81 với những host IPv4 trong khi đó vẫn đảm bảo địa chỉ IPv4 là có tính thống nhất toàn cầu. Do vậy, để đảm bảo thực hiện các sự tương thích giữa IPv4 và IPv6, các nhà thiết kế IPv6 đã xây dựng một số cơ chế chuyển đổi khác nhau. Các cơ chế chuyển đổi này có những đặc điểm chung như sau: - Đảm bảo các host/router cài đặt IPv6 có thể làm việc được với nhau trên nền IPv4. - Hỗ trợ các khả năng triển khai các host và router hoạt động trên nền IPv6 với mục tiêu thay thế dần các host đang hoạt động IPv4. - Có một phương thức chuyển đổi dễ dàng, thực hiện được ở các cấp độ khác nhau từ phía người dùng cuối tới người quản trị hệ thống, các nhà quản lý mạng và cung cấp dịch vụ. Các cơ chế này là một tập các giao thức thực hiện đối với các host và các router, kèm theo là các phương thức như gán địa chỉ và triển khai, thiết kế để làm quá trình chuyển đổi sang IPv6 làm việc với ít rủi ro nhất có thể được. Hiện nay các nhà thiết kế IPv6 đã đưa ra 3 cơ chế chuyển đổi chính cho phép kết nối IPv6 trên nền IPv4 như sau: - Dual IPv6 layer: Cơ chế này đảm bảo một host/router được cài đặt cả 2 stack IPv4 và IPv6 ở tầng Internet Layer trong kiến trúc TCP/IPv6 của nó. - IPv6 tunnel qua IPv4: Cơ chế này thực hiện đóng gói một tin IPv6 theo chuẩn giao thức IPv4 để có thể mang gói tin đó trên nền kiến trúc IPv4. Có 2 loại tunneling là cài đặt sẵn (configured) và tự động (automatic). - 6to4: Cơ chế này hoạt động dựa trên các host IPv4 đã sẵn có các địa chỉ IPv4 từ đó xây dựng một địa chỉ IPv6 có cấu trúc đặc biệt, các host sử dụng cơ chế này không cần phải thông qua một ISP có hỗ trợ IPv6. 4.2. Cơ chế Dual-Layer. 4.2.1. Mô tả. 82 Dual IP layer: cơ chế này đảm bảo mỗi host/router được cài đặt cả hai giao thức IPv4 và IPv6. Với cơ chế “đôi” này, hoạt động của các host/router hoàn toàn tương thích với IPv4 và IPv6. Theo cơ chế này, IPv6 sẽ cùng tồn tại với IPv4 và nó sẽ dùng cơ sở hạ tầng của IPv4. Sự lựa chọn để sử dụng stack (lựa chọn giao thức nào trong tầng Internet) sẽ dựa vào thông tin được cung cấp bởi dịch vụ named qua DNS server. Hình 4.1 minh họa cơ chế này. Đây là cơ chế được coi là “thẳng hướng” nhất để đảm bảo một nodes IPv6 hoàn toàn tương thích với những nodes IPv4 khác. Những node vừa hỗ trợ IPv6 vừa hỗ trợ IPv4 như vậy, gọi là IPv4/IPv6. Những node này có khả năng vừa nhận vừa gửi cả những gói tin IPv4 và IPv6. Chúng có thể làm việc trực tiếp IPv4 sử dụng giao thức IPv4 đồng thời vừa có thể trực tiếp làm việc với với các host “thuần” IPv6 qua giao thức IPv6. Hạn chế của mô hình Dual-Stack là phải gán thêm một địa chỉ IPv4 đối với mỗi node IPv6 mới. Đối với mỗi host sử dụng kỹ thuật dual IP layer, có kết hợp với cơ chế chuyển đổi IPv6-over-IPv4 tunneling (cơ chế này sẽ trình bày dưới đây). Đối với những node này, có thể sử dụng kết hợp với các cơ chế tunneling tự động hoặc tunneling cài sẵn, hoặc cả hai kỹ thuật tunneling này. Do đó có thể có 3 cơ chế chuyển đổi đối với mỗi node IPv4/IPv6 là: • Node IPv4/IPv6 không kết hợp sử dụng kỹ thuật tunneling. • Node IPv4/IPv6 sử dụng kết hợp tunneling cài sẵn. Hình 4.1. Cơ chế dual IP layer. 83 • Node IPv4/IPv6 sử dụng kết hợp cả tunneling cài sẵn và tunneling tự động. Để triển khai trong mạng LAN, người ta thường vận dụng mô hình Dual- Stack “hạn chế”. Mô hình Dual-Stack “hạn chế” được mô tả như sau: Một site khi thiết kế theo mô hình Dual-Stack chỉ có những node làm “server” là các node “Dual-Stack”. Những node đóng vai trò Client chỉ là những node “thuần” IPv6. Node server đóng vai trò là điểm cung cấp các dịch vụ như DNS, Web, file sharing…Với phương thức này, chỉ có 1 địa chỉ IPv4 được gán cho server; giảm thiểu các địa chỉ IPv4 gán cho các node trong site. Đối với một host/router khi hỗ trợ cả dual-Stack IP song song cần phải điều khiển hai bộ địa chỉ khác nhau. Nhưng các giao thức Automatic Neighbour Discovery của IPv4 làm cho Stack này là trong suốt đối với nhà quản lý. Việc nâng cấp router để hỗ trợ IPv6 phức tạp hơn. Các router phải được trang bị mã để forward các gói IPv6, trang bị các giao thức định tuyến IPv6 và giao thức quản lý IPv6. Cơ chế Dual-Stack dựa vào dịch vụ name service. Các máy chủ Dual- Stack sẽ có các bản ghi địa chỉ khai báo trong DNS server, do vậy DNS server này phải hỗ trợ IPv6. Một bản ghi A tương đương một địa chỉ IPv4 và một bản ghi AAA tương đương địa chỉ IPv6. Một giao diện (lập trình) GHN hiện tại, cho phép các ứng dụng nhận được địa chỉ IPv4 tương ứng với một domainame, sẽ được thay thế bởi một giao diện mới HNA. GHN được gọi với chỉ một lệnh là tên của đích. HNA được gọi với hai lệnh là địa chỉ đích và quan hệ địa chỉ, hoặc là AF- INET cho địa chỉ IPv4, hoặc là AF-INT6 cho địa chỉ IPv6. 84 Nếu AF-INET thì thủ tục sẽ chuyển một địa chỉ của bản ghi A có trong đích của DNS. Nếu AF-INT6 thì thủ tục trước hết sẽ query DNS cho bản ghi AAA. Nếu query được thì thủ tục lại quay lại từ đầu. Nếu không tìm thấy thủ tục sẽ query DNS một lần nữa, lần này là hỏi cho địa chỉ đích IPv4. Nó sẽ dùng CIA này như một địa chỉ IPv6 được map bởi IPv4. Các máy chủ Dual-Stack sẽ sử dụng các giao thức lookup ngược mới. Chúng sẽ nhặt ra các địa chỉ tốt nhất ngoài danh sách được trả về và sử dụng các địa chỉ này trong yêu cầu kết nối TCP hoặc coi như là các địa chỉ đích cho các datagram UDP. Các giao thức vận chuyển Dual-Stack sẽ quyết định hoặc là sử dụng IPv6 nếu như các địa chỉ IPv6 và chuyển đổi vào DNS. Sự chuyển tiếp (IPv4 sang IPv6) sẽ xảy ra một cách ngạc nhiên, ngày càng nhiều connecsion sử dụng IPv6. Sẽ không có bất kỳ một ngày nào mà việc thay thế này trở nên rõ nét tuy nhiên cuối cùng việc thay thế này sẽ bao phủ toàn bộ. Các thủ tục DNS là trong suốt đối với nội dung của bản ghi. Chỉ những server và giao diện nào mà cần cung cấp hoặc truy nhập tới địa chỉ IPv6 mới phải được nâng cấp. Việc trang bị cho cac server này sẽ là một phần của việc trang bị IPv6 cho các tổ chức mạng này. Nhưng chúng ta phải đảm bảo rằng các version mới phải hoạt động được, để có thể kết nối được IPv6. Các ứng dụng được nâng cấp sẽ tìm các địa chỉ trong DNS sẽ cố gắng để thiết lập kết nối TCP tới các địa chỉ này. Các kết nối này sẽ bắt đầu được cung cấp cấu trúc overlay trên internet và được xây dựng trên các đường ngầm kết nối giữa các ốc đảo. 4.2.2. Phương pháp thực hiện. Qua phần phân tích trên ta thấy các thông số chính để thực hiên cơ chế Dual - stack được mô tả trong bảng 4.1. 85 Bảng 4.1. Các tham số của cơ chế Dual-Stack Thông số Giá trị Phạm vi áp dụng Site Địa chỉ IPv4 cần gán Một địa chỉ đối với 1 host, nhiều địa chỉ đối với router Địa chỉ IPv4 yêu cầu Một địa chỉ IPv6 đối với 1 host, nhiều địa chỉ đối với router Yêu cầu đối với host Cài đặt cả IPv4/IPv6 Yêu cầu đối với router Cài đặt cả IPv4/IPv6, các giao thức định tuyến phải hỗ trợ IPv6 4.2.3. Yêu cầu về gán địa chỉ : Vì các host này sử dụng cả 2 giao thức ở tầng IP là IPv4 và IPv6, do vậy cần gán cả 2 loại địa chỉ IPv4 và IPv6 ở mỗi host này. Không nhất thiết phải có sự quan hệ giữa hai địa chỉ này. Do vậy, những host IPv4 /IPv6 có thể gán những địa chỉ IPv4 và IPv6 không có quan hệ với nhau. Đối với những nodes có cơ chế chuyển đổi này kết hợp với kỹ thuật tunneling tự động cần phải gán một địa chỉ IPv6 được tạo bởi địa chỉ IPv4 gán đối với host đó. (Địa chỉ IPv6 này gọi là IPv4 – compatible IPv6). Cấu trúc của địa chỉ này như sau : Hình 4.2. Cấu trúc địa chỉ IPv4-compatible IPv6. 86 Đối với những nodes IPv4 /IPv6, có thể có được địa chỉ IPv4 theo bất kỳ một giao thức cấu hình địa chỉ IPv4 nào hợp lệ. Ví dụ sử dụng qua các giao thức cấp địa chỉ động như DHCP, BOOTP, RARP; hoặc gán trực tiếp các địa chỉ IPv4 tĩnh. Đối với địa chỉ loopback: Theo cấu hình địa chỉ IPv4, địa chỉ loopblack có dạng 127.0.0.1; địa chỉ này chuyển sang dạng địa chỉ IPv6 tương thích với IPv4 sẽ có dạng :: 127.0.0.1; đây được coi là dạng địa chỉ IPv6 tương thích với IPv6. Những packet có địa chỉ loopblack sẽ tồn tại trong node đó mà không chuyển ra mạng. 4.2.4. Khai báo DNS : Trong một hệ thống có cài đặt các node hỗ trợ cơ chế dual – stack thì điều kiện tối thiểu cần thiết là dịch vụ DNS của hệ thống đó phải hỗ trợ IPv6 (Hiện nay đã có một số phần mềm như BIND 8.2 hỗ trợ IPv6 ). Đối với các nodes IPv4 /IPv6 cần phải khai báo cả 2 loại bản ghi trong DNS server. Hay nói cách khác là cần phải cấu hình DNS đối với cả 2 loại địa chỉ mà host đó được gán. Đối với mỗi địa chỉ IPv6, cấu trúc bản ghi DNS có dạng AAAA (Đặc tả về cấu trúc các loại bản ghi hỗ trợ IPv6 đối với dịch vụ DNS được mô tả trong RFC 1886). Đối với mỗi địa chỉ IPv4, cấu trúc bản ghi DNS có dạng A. Khi dùng địa chỉ IPv4 – compatible IPv6 được gán với các host IPv4/IPv6 ( những host này sử dụng kỹ thuật automatic tunneling ), cả 2 loại bản ghi A và AAAA phải được cấu hình trong DNS. Bản ghi AAAA phải khai báo dạng đầy đủ địa chỉ IPv4 –compatible IPv6, trong khi đó bản ghi A sẽ sử dụng 32 bits thấp trong địa chỉ này. Khi thực hiện lookup đối với các host IPv6 /IPv4 có thể tìm thấy 2 loại bản ghi A và AAAA. Mỗi bản ghi này có thể trỏ đến mỗi địa chỉ IPv4 hoặc 87 IPv6. Trong trường hợp kết quả tìm thấy là một bản ghi AAAA trỏ đến một địa chỉ IPv4 –compatible IPv6, và một bản ghi A trỏ đến địa chỉ IPv4 tương ứng thì kết quả trả về có thể có các giá trị sau: • Trả lại duy nhất địa chỉ IPv6 • Trả lại duy nhất địa chỉ IPv4 • Trả lại cả 2 địa chỉ IPv4 và IPv6 Lựa chọn loại địa chỉ nào được trả về phụ thuộc vào tuỳ từng trường hợp;trong trường hợp cả 2 loại địa chỉ được trả về thì trật tự sắp xếp các loại địa chỉ liên quan đến luồng IP đối với host đó. Nếu một địa chỉ IPv6 được trả về, node đó giao tiếp với node đích trong đó các gói tinh được đóng gói theo chuẩn IPv6. Nếu địa chỉ IPv4 được trả về thì node đó giao tiếp với một host IPv4. 4.3. Cơ chế Tunneling 4.3.1. Đặc điểm chung. Cơ sở hạ tâng mạng Internet hoạt động trên nền IPv4 hoạt động khá ổn định và có quy mô rộng lớn. Tận dụng khả năng này, các nhà thiết kế IPv6 đã đưa ra giải pháp là thực hiện cơ chế tunneling (đường hầm) trên nền IPv4. Có 2 loại tunneling là Automatic Tunneling và Configured Tunneling. Trước khi trình bày về đặc điểm của các cơ chế tunneling, sau đây sẽ mô tả một số khái niệm liên quan đến quá trình tunneling. • IPv4 –only node: là một host hay router hoạt động trên nền IPv4, những host hoặc router này không hiểu IPv6, các host này chiếm phần lớn các thiết bị trên mạng Internet hiện nay, gọi là các node thuần IPv4. • IPv6/IPv4 node: là các node có khả năng thực hiện trên nền IPv4 hoặc IPv6 và gọi đó là các node đôi. 88 • IPv6 –only node: là các node chỉ có khả năng hoạt động trên nền IPv6, không có khả năng thực hiện trên nền IPv4 và gọi đó là các node thuần IPv6. • IPv6 node: node thuần IPv6 và node đôi IPv6/IPv4. • IPv4 node: node thuần IPv4 và node đôi IPv6/IPv4 • IPv4- compatible IPv6 address: là một địa chỉ IPv6, được gán cho các node đôi IPv6/IPv4 và gọi địa chỉ IPv6 loại này là địa chỉ IPv6 tương thích IPv4. Địa chỉ loại này được sử dụng trong cơ chế tunnel IPv6 trên nền IPv4. • IPv6-only address: là những địa chỉ IPv6 còn lại. • IPv6-over-IPv4 tunnelling: kỹ thuật này thực hiện việc đóng gói các datagram theo cấu trúc IPv6 vào phần dữ liệu của datagram IPv4 để có thể mang các gói tin IPv6 qua mạng IPv4, gọi cơ chế này là tunnel IPv6 trên nền IPv4. • Automatic Tunneling: theo phương thức này, địa chỉ cuối cùng có tunnel là địa chỉ IPv6 tương thích với địa chỉ IPv4. • Configured Tunneling: theo phương thức này, địa chỉ cuối cùng có tunnel được xác định nhờ thông tin cấu hình tại node đóng gói. Hình 4.3 minh hoạ cơ chế Tunneling. Cơ chế Tunneling được mô tả như sau: các node IPv6/IPv4 sẽ thực hiện đóng gói các datagram IPv6 vào thành phần dữ liệu trong datagram IPv4 (phần tải trọng của gói tin IPv4 Hình 4.3. Cơ chế tunneling. 89 truyền trên mạng là gói tin IPv6) và do đó, gói tin này sẽ có thể truyền trên nền IPv4. Các kết nối có thể áp dụng cơ chế tunneling là: • Router-to-router: các router IPv6/IPv4 kết nối với nhau bởi cơ sở hạ tầng IPv4, do đó có thể thực hiện chuyển các datagram IPv6 qua cơ chế tunnel. Trong trường hợp này, cơ chế tunnel trải rộng từ điểm bắt đầu tới điểm kết thúc của một gói tin IPv6. • Host-to-router: một host đôi IPv6/IPv4 có thể thực hiện tunnel IPv6 trên nền IPv4 để chuyển các gói tin tới các router trung gian cũng được cấu hình là các node đôi IPv6/IPv4. Trong trường hợp này, cơ chế tunnel trải rộng trong phạm vi từ host tới router đó. • Host-to-host: hai host đôi IPv6/IPv4 có thể truyền các datagram theo định dạng IPv6 trên nền IPv4. Trong trường hợp này, cơ chế tunnel trải rộng từ điểm đầu đến điểm cuối. Kỹ thuật tunnel được phân loại dựa trên nguyên tắc sử dụng phương thức nào để quyết định địa chỉ của node cuối cùng được cấu hình tunnel. Trong hai phương thức tunnel là Router-to-router và Host-to-router gói tin IPv6 được tunnel đến địa chỉ cuối cùng là tại router. Do đó, điểm cuối cùng của quá trình tunnel này là các router trung gian, tại các router này phải có nhiệm vụ “mở gói tin” được tunnel và chuyển nó tới đích cuối cùng. Địa chỉ trong gói tin IPv6 được tunnel, không hỗ trợ địa chỉ IPv4 của điểm cuối cùng tunnel, thay vào đó, địa chỉ điểm cuối cùng tunnel phải được quyết định từ các thông tin cấu hình trên node thực hiện đóng gói. Theo cơ chế xác định địa chỉ cuối như vậy, ta gọi là “Configured Tunneling”, có nghĩa là địa chỉ điểm cuối của quá trình tunnel đã được khai báo trước. 90 Theo hai phương thức host-to-host và host-to-router, gói tin IPv6 được tunnel trên tất cả hành trình của chúng, cho tới khi đến được đích. Theo cơ chế này, node cuối cùng được xác định tunnel là địa chỉ đích của gói tin IPv6. Vì vậy, điểm cuối cùng của tunnel có thể được quyết định từ địa chỉ đích của gói tin IPv6. Nếu địa chỉ này là một địa chỉ tương đương với địa chỉ IPv4 thì theo cấu trúc của địa chỉ này 32 bit thấp sẽ được lấy làm địa chỉ của node đích và được sử dụng làm địa chỉ đích của node cuối cùng được tunnel. Kỹ thuật này tránh được việc phải khai báo trước địa chỉ đích của node cuối cùng tunnel, gọi là “automatic tunneling”. Cả hai kỹ thuật automatic tunneling và configured tunneling có khác nhau cơ bản nhất là việc quyết định địa chỉ cuối của quá trình tunnel, còn lại về cơ bản hoạt động của hai cơ chế này giống nhau. Cụ thể như sau: • Điểm khởi tạo tunnel (điểm đóng gói tin) tạo một header IPv4 đóng gói và truyền gói tin đã được đóng gói. • Node kết thúc của quá trình tunnel (điểm mở gói tin) nhận được gói tin đóng gói, xoá bỏ phần header IPv4, sửa đổi một số trường của header IPv6 và xử lý phần dữ liệu này như một gói tin IPv6. • Node đóng gói cần duy trì các thông tin về trạng thái của mỗi quá trình tunnel, ví dụ các tham số MTU để xử lý các gói tin IPv6 bắt đầu thực hiện tunnel. Vì số lượng các tiến trình tunnel có thể tăng lên một số lượng khá lớn, trong khi đó các thông tin này thường lặp lại và do đó có thể sử dụng kỹ thuật cache và được loại bỏ khi cần thiết. 91 4.3.2. Cơ chế đóng gói thực hiện tunneling. Hình 4.4 minh hoạ cơ chế đóng gói thực hiện tunnel. Cấu trúc của phần header packet IPv4 khi thực hiện tunneling (đóng gói IPv6 packet trong một datagram IPv4) được trình bày ở bảng 4.2. Bảng 4.2. Cấu trúc của phần header IPv4 khi thực hiện tunneling. Tham số Giá trị (bit) Ý nghĩa Version 4 Giao thức sử dụng là IPv4 IP header length 5 Chiều dài tối đa của trường này là 32 bit. Đối với các gói tin IPv4 đóng gói không thiết lập giá trị cho phần option trong header. Type of service 0 Total Length 60 bytes Xác định độ lớn gồm chiều dài phần header IPv6 + chiều dài của IPv6 + chiều dài IPv4 header. Identification Giá trị được xác định thống nhất cho bất kỳ gói tin IPv4 được truyền bởi hệ thống. Flags DF hoặc MF Hình 4.4. Cơ chế đóng gói thực hiện tunnel. 92 Time to live Protocol 41 Gán tương ứng với loại payload trong gói tin IPv6 đóng gói Header Checksum Giá trị tổng các byte của phần header IPv4 để kiểm tra tính toàn vẹn dữ liệu khi nhận ở địa chỉ đích. Source Address IPv4 address Địa chỉ IPv4 của trạm nguồn Destination Address IPv4 address Địa chỉ IPv4 của trạm đích 4.3.3. Cơ chế mở gói khi thực hiện tunnel IPv6-over-IPv4. Khi một host hay một router nhận được một datagram IPv4 có kiểu giao thức là 41 nó sẽ bỏ phần header IPv4 trong gói tin và giữ lại phần data, đó chính là gói tin IPv6. Hình 4.5 minh họa cơ chế mở gói. Chú ý là khi thực hiện mở gói tin IPv6 (IPv6–in-IPv4), phần header của IPv6 không bị biến đổi. Nếu đó là gói tin đến đích cuối cùng, giá trị trong Hình 4.5. Cơ chế mở gói IPv4 khi thực hiện tunnel. 93 trường hop-limit sẽ bị giảm xuống một giá trị. Phần header IPv4 đóng gói bị loại bỏ. Các node thực hiện mở gói sẽ thực hiện việc tái hợp các datagram IPv4 trước khi nó thực hiện mở gói IPv6. Do vậy, tất cả các giá trị option IPv6 vẫn được giữ nguyên như trước khi đóng gói. Sau khi thực hiện việc mở gói, mọi quá trình xử lý giống với việc nhận một datagram IPv6 thông thường khác. Để đảm bảo tính tương thích giữa IPv6 và IPv4, cần phải có cơ chế chuyển đổi đối với những thay đổi của IPv6 so với IPv4 mà cụ thể là phần header của các datagram và phần thay đổi địa chỉ của IPv6. Các phương thức chuyển đổi địa chỉ đảm bảo thực hiện được các nhiệm vụ chính như sau: • Đảm bảo các host hoạt động trên nền IPv4 và IPv6 hoàn toàn làm việc được với nhau. • Hỗ trợ các khả năng triển khai các host và router hoạt động trên nền IPv6 với mục tiêu thay thế dần các host đang hoạt động IPv4. • Có một phương thức chuyển đổi dễ dàng, thực hiện được ở các cấp độ khác nhau từ phía người dùng cuối tới nhà quản trị hệ thống, các nhà quản lý mạng và cung cấp dịch vụ. • IPv6 tunnel qua IPv4: cơ chế này đóng gói một gói tin IPv6 vào trong phần header của IPv4 để có thể mang gói tin đó trên nền kiến trúc IPv4. Có hai loại tunnel: cấu hình sẵn và tự động. 4.3.4. Lựa chọn giá trị MTU và phân mảnh. Giá trị giới hạn kích thước gói tin trong tầng Datalink của giao thức TCP/IPv6 gọi là MTU (Maximum Transfer Unit). Đối với mỗi giao thức trên tầng Datalink khác nhau có một giá trị MTU khác nhau. Ví dụ giá trị MTU của Ethernet là 1518 octet. Do có nhiều phương thức khác nhau đối với các 94 luồng traffic trong mạng Internet nên sẽ xảy ra hiện tượng các giá trị MTU tại các điểm gateway nhỏ hơn giá trị MTU của các mạng trong. Do vậy sẽ xảy ra hiện tượng phân mảnh tại các điểm gateway. Sau đó sẽ xảy ra hiện tượng tái hợp ở các điểm đích. Hình 4.6 minh họa cơ chế này. Đối với giao thức IPv4 giá trị MTU chỉ là 576 bytes, giá trị này có thể nhỏ hơn giá trị của một gói tin IPv6. Như vậy ở các node entry-point khi thực hiện đóng gói các gói tin IPv6 sẽ phải kiểm tra gói tin IPv6 mà nó đóng gói có vượt qua giá trị MTU cho phép hay không. Nếu vượt quá thì phải thực hiện phân mảnh gói tin IPv6. Việc phân mảnh này dẫn đến các hiện tượng sau: • Ở phía nhận sẽ nhận được rất nhiều các mảnh nhỏ được tách ra từ gói lớn. Nó sẽ phải mất nhiều thời gian và bộ nhớ để tái hợp các gói tin phân mảnh trước khi mở gói. • Trong trường hợp một gói tin phân mảnh bị mất, các gói tin còn lại sẽ chiếm mất không gian bộ đệm cho đến khi vượt quá giá trị TTL mới bị huỷ. Toàn bộ IPv6 lúc này bị mất và phải truyền lại. Tóm lại, việc tách gói sẽ chỉ là có hại cho tunnel giữa các máy chủ. Như vậy việc thực hiện phân mảnh gói tin là không hiệu quả. Để xác định giá trị MTU hợp lý người ta đã xây dựng giao thức MTU Discovery Protocol. Có thể mô tả tóm tắt thuật toán chọn lựa giá trị MTU này như sau: Hình 4.6. Phân mảnh và tái hợp gói tin. 95 • Nếu gói tin IPv6 cần đóng gói có kích thước lớn hơn 576 bytes thì ở node entry-point trả về một thông báo ICMPtheo chuẩn IPv6 và node nguồn của gói tin IPv6 đó. Thông báo ICMP có nội dung cảnh báo là kích cỡ gói tin lớn hơn mức cho phép (packet too big). Giá trị MTU hợp lệ là 576 bytes và ở điểm entry tunnel sẽ huỷ gói tin yêu cầu tunneling. • Nếu gói tin IPv6 cần đóng gói có kích cỡ nhỏ hơn 576 bytes sẽ thực hiện đóng gói và giá trị của trường flag fragmention trong phần header IPv4 được thiết lập bằng không (không phân mảnh). Để giảm được việc phải phân nhỏ gói tới mức nhỏ nhất, router ở hai đầu tunnel thực hiện tìm kiếm giá trị MTU được coi là hợp lý nhất. Chúng sẽ bắt đầu từ MTU của tunnel tới MTU của giao diện cục bộ của chúng. Nếu như các message ICMP trở lại để chỉ rằng gói là quá lớn, chúng sẽ chuyển tới một MTU thấp hơn. Trong vài trường hợp chúng có thể gửi một message thử để khám phá khả năng tăng trong MTU. Khi MTU của tunnel vẫn còn lớn hơn kích thước gói nhỏ nhất mà IPv6 hỗ trợ (5760 octet) thì việc phân nhỏ gói IPv4 sẽ được tắt đi trong IPv4 header. Nếu như gói IPv6 lớn hơn MTU của tunnel có trong giao diện thì nó sẽ bị loại bỏ và message ICMP “IPv6 packet too big” sẽ được gửi lại cho khách hàng. Nhưng kích thước nhỏ nhất của gói IPv4 chỉ là 48 octet chứ không phải là 576. MTU của tunnel có thể ít khi nhỏ hơn 576 octet, điều mà buộc các router IPv6 sử dụng việc phân nhỏ gói IPv4. Nếu MTU của tunnel IPv4 nhỏ hơn 576 octet. Các gói IPv6 lớn hơn 576 octet sẽ bị loại bỏ và message “packet too big” sẽ được gửi trở lại cho người gửi IPv6. Gói này sẽ chỉ ra một MTU IPv6 cực đại của 576 octet. Nếu một gói IPv6 lớn hơn MTU của tunnel nhưng lại nhỏ hơn 576 thì việc phân nhỏ gói sẽ không thể được dùng. 96 Hình 4.7 minh họa giao thức MTU discovery được hỗ trợ trong IPv6. 4.3.5. Các giao thức tunnel và routing. Khi tunnel được cấu hình, chúng sẽ được đối xử như nhiều loại đường link khác trong toàn bộ cơ sở hạ tầng IPv6. Nếu như tunnel được sử dụng cho đường nối giữa các domain định tuyến tách biệt nhau, nó sẽ sử dụng cho việc trao đổi giữa các router, sử dụng IDRP. Nếu như tunnel bị đưa vào định tuyến, nó sẽ được xem xét như là một đường link serial thuần tuý bằng các giao thức routing như là RIP hoặc OSPF. Nhưng các tunnel đều không phải thuần là các link. Trong trường hợp của RIP, toàn bộ số liệu là số lượng host. Ngầm định giá của tunnel đặt là 1, như là một đường kết nối trực tiếp giữa 2 router mặc dù là các gói qua tunnel trong thực tế được chuyển tiếp qua vài lần bởi các lớp IPv4. Đó có thể là do kết quả của các lựa chọn khác, giống như các lựa chọn cho việc định tuyến thông qua một tunnel dài thay vì chuyển tiếp qua một số lượng nhỏ các kết nối IPv6 trực tiếp. 4.3.6. Thời gian sống trong tunnel. Do việc định tuyến IPv4 là động, thời gian sử dụng cho các gói trong tunnel là thay đổi. Các gói nên gửi qua tunnel với 1 TTL IPv4 vừa đủ để đảm bảo rằng chúng không bị timeout. Khi định tuyến các đặc tính hiện tái của cơ Hình 4.7. Giao thức MTU discovery. 97 chế chuyển tiếp đã được lược bớt trong điểm này. Do đó, TTL được lựa chọn trong kiểu hoạt động phụ thuộc, với giá trị ngầm định được đề xuất trong RFC 1700. Thực tế người ta thiết lập TTL này một cách động, giống như chương trình traceroute thực hiện. Việc giám sát TTL của tunnel có thể có ích nếu như người ta muốn khám phá nhanh chóng sự thay đổi trong việc định tuyến IPv4 và cập nhật metric của tunnel. 4.3.7. Điều khiển việc chia sẻ tunnel. Một điểm hạn chế của định tuyến theo lớp là làm hỗn độn việc điều khiển tài nguyên. Các gói được qua tunnel sẽ hoàn thành việc truyền tài nguyên với các gói thuần IPv4. Vấn đề có thể gây ra lỗi trong trường hợp các router IPv4 được sử dụng bởi vì tunnel sẽ chỉ nhận được một phần chia sẻ của tài nguyên của khách hàng đó, mặc dù nó thông tin có trong toàn bộ gói tin IPv6. Các giải pháp tương tự sẽ được sử dụng cho IPv6 tunnel, nó có một số lợi ích sau: - Người quản lý có thể điều khiển việc chia sẻ mạng mà được định vị trong IPv6. - Dải thông tunnel có thể được sử dụng để ấn định metric hiện thực tới tunnel. Cũng có một số bất lợi tiềm ẩn. Theo định nghĩa, việc ép buộc mã giới hạn tốc độ cho IPv6 tunnel nghĩa là các gói IPv6 sẽ không sử dụng chung được các tài nguyên đang không sử dụng đến như là các gói thuần IPv4. Cũng vì vậy nếu như dải thông tương ứng không được dành riêng có hiệu quả ở mức IPv4 thì chính sách ở mức IPv6 sẽ không được đảm bảo rằng các gói có mức ưu tiên cao nhất là không bị loại bỏ trong tunnel. 98 Đây là một điều khá rõ ràng. Người ta có thể tưởng tượng ra một giao thức điều khiển tunnel động giám sát dải thông có sẵn cho tunnel trong các luồng IPv6 thời gian thực. Nhưng đó cũng là một vấn đề nguy hiểm bởi vì có nhiều sự tương tác rất phức tạp giữa các phần điều khiển, tốc độ gửi của các gói trong tunnel và khả năng của tunnel. Việc thiết lập một dải thông được định nghĩa trước và buộc nó sử dụng tại mức IPv4 là khá dễ dàng và có thể vững chắc hơn. Việc triển khai nhanh các khả năng nguyên thuỷ của IPv6 có thể sẽ là tốt hơn bởi vì chúng sẽ thoát ra được khỏi tunnel. 4.3.8. TTL cho các tunnel tự động. Các tunnel đã từng nhận các gói tới và từ các host độc lập đã không được cấu hình một cách tường minh. Vì vậy, người ta phải chọn các thông số IPv4 như là TTL hoặc MTU. Trong trường hợp của TTL, các host sẽ dùng các giá trị được khuyến nghị 64 cho RFC1700. Trường hợp của MTU thì phức tạp hơn, thực tế có ba trường hợp: - Các host độc lập quản lý một tunnel đơn tới một router IPv6 gần nhất. - Các host qual điều khiển các tunnel tới các partnel độc lập của chúng. - Các router dual xuyên các gói tới các host độc lập mà thay mặt cho các host thuần IPv6. Các host độc lập chỉ điều khiển một tunnel. Chúng có thể có giao thức phát hiện MTU. Các host chạy dual cũng nên có khả năng chạy giao thức phát hiện MTU cho tất cả các tunnel hiện tại đang kích hoạt, mặc dù các máy chủ phổ thông không phải trả lời nhiều cho khách hàng tìm ra nó cũng khá khó khăn. Các router dual sẽ sớm đối mặt với rất nhiều các tunnel đang kích hoạt, phải có khả năng tính toán một cách hiệu quả thông số MTU cho mỗi router. Chúng sẽ luôn luôn có lợi khi sử dụng tối thiểu ngầm định của MTU là 576 byte và quản lý được việc phân mảnh IPv4 các router mà thực hiện việc 99 tunneling có thể nhận được các báo hiệu lỗi khác thường là ICMP. Để tránh các vấn đề này, chúng thường cố gắng chuyển các báo hiệu này trong IPv6 ICMP quay trở lại nguồn IPv6. Các message ICMP bao gồm byte thứ nhất của gói IPv4, 40 byte tiếp theo sẽ là header IPv6 nguyên thuỷ. Nếu chúng xuất hiện thì router sẽ sử dụng chúng sẽ hồi phục lại địa chỉ nguồn IPv6 nguyên thuỷ nhằm xây dựng một message báo lỗi ICMP IPv6. 4. 4. Cơ chế Configure tunneling. 4.4.1. Mô tả. Với phương thức tunnel này, địa chỉ mở gói được quyết định bởi các thông tin được cấu hình ở node đóng gói (entry-point encapsulations). Đối với mỗi tunnel dạng này, các node phải lưu địa chỉ của trạm cuối (trạm mở gói-end point). Khi các gói IPv6 được chuyển qua tunnel này, địa chỉ của các end point được cấu hình sao cho giống với địa chỉ đích trong phần header của gói tin IPv4 đóng gói. Các thông số yêu cầu đối với cơ chế Configure tunneling như sau: - Khả năng ứng dụng: site. - Yêu cầu giao thức IPv4: kết nối giữa các site sử dụng IPv4. - Địa chỉ IPv4: tối thiểu có một địa chỉ IPv4 trong một site. - Yêu cầu giao thức IPv6: không cần thiết. - Yêu cầu địa chỉ IPv6: không cần thiết. - Yêu cầu host: IPv6 stack hoặc IPv4/IPv6 stack. - Yêu cầu đối với router: IPv4/IPv6 router. 4.4.2. Phương pháp thực hiện. 100 Để quyết định đường đi của các tunneling, hay nói cách khác để có được các thông tin về node cuối cùng cần phải dựa vào bảng định tuyến vì hướng đi của các gói phải dựa vào địa chỉ đích của chúng sử dụng các kỹ thuật netmask. Default Configured tunneling: giống như ý nghĩa của giá trị Default router trong bảng định tuyến, đối với một tunnel khi thực hiện phương thức Configurđ tunneling nếu nó không tìm thấy địa chỉ đích trong bảng định tuyến, nó sẽ sử dụng một giá trị Default khai trên router đó làm địa chỉ đích trong gói tin đóng gói. 4.5. Cơ chế Automatic tunneling. 4.5.1. Mô tả. Với phương thức tunneling này, địa chỉ đích trong gói tin đóng gói IPv4 được xác định là địa chỉ đích của gói tin IPv6. Do vậy địa chỉ đích của gói tin IPv6 được đóng gói phải có dạng địa chỉ IPv4 tương thích với IPv6 (IPv4- compability IPv6). Đối với những gói tin IPv6 mà địa chỉ đích là dạng địa chỉ không có dạng IPv4-compability thì sẽ không thể thực hiện Automatic tunneling. Cơ chế Automatic tunneling thường được sử dụng khi cần thực hiện những kết nối với các host hoặc với các mạng IPv6 trong một thời gian ngắn, hoặc trong những tình huống ngẫu nhiên. Các thông số liên quan đến Automatic tunneling: - Khả năng ứng dụng: đối với các host. - Yêu cầu giao thức IPv4: yêu cầu có các kết nối IPv4 giữa các site. - Yêu cầu địa chỉ IPv4: tối thiểu có một địa chỉ IPv4. - Yêu cầu giao thức IPv6: không cần thiết. - Yêu cầu địa chỉ IPv6: địa chỉ dạng IPv4-compability 101 - Yêu cầu host: cài đặt Dual-Stack IPv4/IPv6 - Yêu cầu đối với router: không cần thiết 4.5.2. Phương pháp thực hiện. Đối với những node IPv4/IPv6 có một phương thức để quyết định liệu các gói tin IPv6 có được Automatic tunneling hay không đó là dựa vào các thông số trong bảng định tuyến tĩnh. Đối với các host có địa chỉ đích dạng ::0/96 sẽ được thực hiện tự động định tuyến (vì những host này thoả mãn điều kiện là có địa chỉ đích dạng IPv4-compability). 4.6. Cơ chế 6to4. 4.6.1. Yêu cầu. Hiện nay, để triển khai mạng IPv6 tổ chức IGTRANs (IPng Transition Working Group- một nhóm thuộc IETF) đã đưa ra một giải pháp thứ ba để triển khai mạng IPv6 trên nền IPv4 là cơ chế 6to4. Một trong những hạn chế lớn nhất của hai cơ chế trên (cơ chế Dual-Stack và cơ chế tunneling) là với mỗi khách hàng cuối (end-user site) để kết nối với mạng IPv6 (ví dụ 6Bone) đều cần phải lựa chọn một ISP có hỗ trợ dịch vụ IPv6 để giải quyết các vấn đề liên quan đến cấp phát địa chỉ và tunneling…Mặt khác phương thức này cũng hạn chế được những khó khăn của cơ chế tunneling như các hoạt động tạo, quản lý, duy trì các cấu hình tunneling của phương pháp tunneling. Yêu cầu của cơ chế 6to4: - Một host phải có địa chỉ IPv4. - Để đảm bảo hoạt động chính xác của 6to4 trong một topo mạng phức tạp, tất cả các host IPv6 phải đảm bảo thuật toán sau đây là có giá trị: đó là thuật toán liên quan đến lựa chọn địa chỉ khi thực hiện gửi gói tin IPv6. Vì một node có thể gán nhiều dạng địa chỉ IPv6 khác nhau. do đó, trong dịch vụ tên miền DNS có thể khai nhiều bản ghi tương ứng với các địa chỉ IPv6 102 khác nhau của host đó. Thuật toán lựa chọn địa chỉ đảm bảo trong một tập các địa chỉ IPv6 trả về khi host thực hiện query DNS server sẽ lựa chọn một địa chỉ có dạng tiền tố 2002::/16 trong tập các địa chỉ trả về để gửi gói tin IPv6 trong các kết nối của host đó. 4.6.2. Mô tả. Theo cấu trúc của dạng địa chỉ Global Unicast, phần định danh tiền tố TLA được gán bởi tổ chức IANA. Ví dụ tiền tố 3FFE::/16 được gán cho mạng thử nghiệm 6Bone, hay 2001::/16 được phân bổ theo cơ chế production. Hiện nay tổ chức này cũng gán một tiền tố đặc biệt là 2002::/16 để hỗ trợ cơ chế 6to4. Theo đó cấu trúc địa chỉ IPv6 của một node thực hiện 6to4 có dạng như sau: trong đó: - Phần TLA ID được gán giá trị 0002::/16 - Phần NLA gán 32 bit còn lại là địa chỉ IPv4 của node đó. Như vậy một node muốn thực hiện cơ chế 6to4 phải có một địa chỉ IPv4 thực (địa chỉ IPv4 này phải có giá trị trên mạng Internet, không phải là địa chỉ của mạng riêng). Cấu trúc dạng địa chỉ này đảm bảo hoàn toàn giống với các định dạng địa chỉ IPv6 Global Unicast thông thường khác. Gói tin IPv6 trong các site cấu hình 6to4 được đóng gói theo dạng IPv4 (giống cơ chế tunneling-6over4) khi các gói tin này cần chuyển ra mạng ngoài. Sau khi gói tin đóng gói dạng IPv4 sẽ được chuyển trong mạng IPv4 như hoạt động của mạng Internet hiện nay. 103 Phần header của gói tin IPv4 có địa chỉ đích và địa chỉ nguồn dạng IPv4. Các địa chỉ này có được là dựa vào cơ chế lựa chọn địa chỉ, sau đó thực hiện lấy 32 bit địa chỉ V4ADDR trong cấu trúc địa chỉ IPv6 có tiền tố 2002::/16. Cấu trúc của dạng gói tin IPv4 được mô tả trên hình 4.8. Trường hợp triển khai đơn giản nhất của cơ chế 6to4 là sử dụng cơ chế này để kết nối các site IPv6 với nhau, các site này kết nối với nhau dựa trên mạng IPv4. Không yêu cầu các site này có các kết nối với cùng một ISP. Chỉ có một yêu cầu là các site được cài đặt IPv6 hỗ trợ cơ chế 6to4 để thiết lập giá trị Protocol=41 trong các gói IPv4. Để cơ chế này hoạt động, mỗi site còn cần phải gán một địa chỉ IPv6 theo cấu trúc địa chỉ đã mô tả ở trên. Đồng thời tạo một bản ghi DNS tương ứng với địa chỉ này. Ví dụ: Một site A có địa chỉ IPv4 là 203.162.0.10 sẽ tạo một bản ghi trên DNS với tiền tố IPv6 có dạng: {FP=001, TLA=0x0002, NLA=CBA2:000A}/48. Một site B có địa chỉ IPv4 là 9.254.253.252 sẽ tạo một bản ghi trên DNS với tiền tố IPv6 có dạng: {FP=001, TLA=0x0002, NLA=09FE:FDFC}/48. Hình 4.8. Cấu trúc gói tin IPv4 đóng gói theo cơ chế 6to4. 104 Khi một host IPv6 trên site B cần kết nối với một host IPv6 trên site A, các bước thực hiện như sau: - Nó thực hiện query tới DNS server để tìm địa chỉ IPv6 của host trên site A. Giả sử địa chỉ mạng trả về là {FP=001, TLA=0x0002, NLA=CBA2:000A}/48. Địa chỉ một host trong site A có dạng tiền tố như trên và một giá trị SLA và Interface ID có dạng bất kỳ. - Gói tin IPv6 được hình thành và được truyền thông thường bên trong hai site này (từ các host IPv6 đến các router 6to4 được truyền các gói tin thuần IPv6 – không có bất kỳ cơ chế chuyển đổi nào xảy ra ở trong nội bộ một site- các router 6to4 được coi là các router “cận biên”). - Khi các router này nhận thấy địa chỉ đích có phần tiền tố 2002::/16 nó sẽ thực hiện cơ chế gửi như sau: Đóng gói gói tin IPv6 theo dạng IPv4 với cấu trúc gói tin IPv4, trong đó địa chỉ đích của gói tin IPv4 này được lấy từ 32 bit của trường V4ADDR trong địa chỉ đích IPv6 của gói tin IPv4. Sau đó chuyển gói tin như giao thức IPv4 thông thường qua các giao thức định tuyến của IPv4. Đối với các router bên site A, sau khi nhận các gói tin IPv4 sẽ thực hiện cơ chế mở gói như sau: Thực hiện kiểm tra giá trị của trường Protocol trong phần header của gói Hình 4.9. Cơ chế đóng mở gói. 105 tin có bằng 41 hay không? Nếu giá trị này bằng 41 sẽ thực hiện bỏ phần header của gói tin IPv4 và lấy phần data của gói tin IPv4 này là một gói tin IPv6. Sau đó chuyển trong local site bằng các giao thức IPv6. Hình 4.9 mô tả hoạt động của quá trình này. 4.7. Phương thức lựa chọn các cơ chế. Đối với những node IPv4/IPv6 phải có phương thức lựa chọn khi nào gửi gói tin IPv4, khi nào gửi gói tin IPv6 và khi nào thực hiện automatic hoặc configured tunneling sử dụng kết hợp với nhau. Các trường hợp có thể xảy ra như sau: - Gửi gói tin IPv4 tới tất cả các địa chỉ đích IPv4. - Gửi gói tin IPv6 tới tất cả các địa chỉ đích IPv6 trên cùng một link. - Sử dụng automatic tunneling: Gửi các gói tin IPv4 đóng gói IPv6 có địa chỉ đích là dạng địa chỉ IPv4-compatible. - Gửi các gói tin IPv6 ra mạng ngoài mà router trong mạng đó có hỗ trợ IPv6. - Gửi các gói tin IPv6 ra mạng ngoài sử dụng default tunneling khi không có router hỗ trợ IPv6. Các thuật toán tương ứng với các trường hợp này như sau: 4.7.1. Nếu địa chỉ của node cuối là một địa chỉ IPv4. Nếu địa chỉ đích được locate trên một attached link thì sẽ gửi gói tin IPv4 tới node cuối. Nếu địa chỉ đích của node cuối không locate trên link với node nguồn thì hoặc: - Nếu có một router IPv4 trên link, node nguồn sẽ gửi gói tin dạng IPv4, địa chỉ đích là một dạng địa chỉ IPv4. 106 - Nếu không, địa chỉ đích sẽ là “unreachable” vì nó không nằm trên link host nguồn và cũng không nằm link với router. 4.7.2. Nếu địa chỉ của node cuối là một dạng địa chỉ IPv4-compatible IPv6. Có các tình huống xảy ra như sau: Nếu địa chỉ đích được locate trên một attached link, khi đó host nguồn sẽ gửi gói tin dạng IPv6 (không đóng gói). Địa chỉ đích của gói tin IPv6 là địa chỉ Global Unicast của trạm đích. Nếu trạm đích không locate trên link (phải thông qua router), có các tình huống sau xảy ra: - Nếu đó là một router IPv4 thì một gói tin IPv6 được đóng gói dạng IPv4 để tunnel qua router. Địa chỉ đích IPv6 là địa chỉ IPv6 của node cuối. Đối với gói tin IPv4 địa chỉ đích là 32 bit thấp của địa chỉ dạng IPv4- compatible IPv6. Địa chỉ datalink là địa chỉ datalink của router IPv4. - Nếu là một router IPv6 nằm trên đường link, thì gói tin được gửi từ trạm nguồn có dạng gói tin IPv6. Địa chỉ nguồn là một địa chỉ IPv6 của node nhận gói tin. Địa chỉ datalink là địa chỉ IPv6 của router. - Nếu không, không thể kết nối với trạm đích (unreachable). 4.7.3. Nếu node nhận là một node thuần IPv6 Có các tình huống xảy ra như sau: Nếu node nhận nằm trên link với node gửi, sẽ gửi gói tin dạng IPv6. Địa chỉ đích là địa chỉ IPv6 của node cuối. Địa chỉ datalink là địa chỉ của node cuối. Nếu node cuối không nằm trên link, có các tình huống sau: - Nếu có một router IPv6, thì gói tin gửi được định dạng IPv6. Địa chỉ đích IPv6 là địa chỉ của node cuối. Địa chỉ datalink là địa chỉ IPv6 của router. 107 - Nếu địa chỉ đích có thể có được qua configured tunneling và có một router IPv4 để kết nối ra ngoài thì gói tin gửi sẽ được đóng gói theo IPv4. Địa chỉ đích IPv6 là địa chỉ của node cuối. Địa chỉ đích của gói tin IPv4 là địa chỉ IPv4 của node mở gói. Địa chỉ datalink là địa chỉ IPv4 của router IPv4. - Nếu không địa chỉ đích không thể kết nối tới (unreachable). Bảng 4.3. Tóm tắt phương thức lựa chọn cơ chế chuyển đổi. Dạng địa chỉ của node đích Node đích trên link? Router IPv4 trên link Router IPv6 trên link Định dạng gói tin để gửi Dạng địa chỉ đích IPv6 Dạng địa chỉ đích IPv4 Dạng địa chỉ đích datalink IPv4 Yes N/A N/A IPv4 N/A E4 EL IPv4 No Yes N/A IPv4 N/A E4 RL IPv4 No No N/A UNRCH N/A N/A N/A IPv4- compatible Yes N/A N/A IPv6 E6 N/A EL IPv4- compatible No Yes N/A IPv6/4 E6 E4 RL IPv4- compatible No No Yes IPv6 E6 N/A RL IPv4- compatible No No No UNRCH N/A N/A N/A IPv6-only Yes N/A N/A IPv6 E6 N/A Electron IPv6 -only No N/A Yes IPv6 E6 N/A RL 108 IPv6 -only No Yes No IPv6/4 E6 T4 RL IPv6 -only No No No UNRCH N/A N/A N/A Chú thích: N/A: không có trong thực tế. E6: Địa chỉ IPv6 của node cuối. E4: Địa chỉ IPv4 của node cuối. EL: Địa chỉ datalink của node cuối. T4: Địa chỉ IPv4 của điểm mở gói trong tunnel. R6: Địa chỉ IPv6 của router. R4: Địa chỉ IPv4 của router. RL: Dạng địa chỉ datalink của router. IPv4: Định dạng gói tin IPv4. IPv6: Định dạng gói tin IPv6. IPv6/IPv4: Gói tin IPv6 được đóng gói dưới dạng IPv4. UNRCH: Gói tin không được gửi (Destination is unreachable) 4.8. IPv6 và 3G. Hình 4.10 mô tả IPv6 được ứng dụng trong UMTS như thế nào. Mức truyền tải và mức người sử dụng hoàn toàn độc lập, mạng UTRAN và mạng lõi cũng là hai mạng độc lập, vì vậy việc sử dụng IPv6 có nghĩa bao gồm người sử dụng IPv6, mạng UTRAN IPv6 và mạng lõi IPv6. Các gói IP đến/đi từ thiết bị đầu cuối xuyên qua mạng UMTS, chúng không được định hướng trực tiếp tại mức IP. 109 Hình 4.11 mô tả cấu hình mạng WCDMA2000 liên kết với mạng IPv6 qua PDSN hỗ trợ IPv6. Kết nối PPP giữa MS và PDSN sẽ vận chuyển gói tin IPv6. Mạng truy nhập vô tuyến (RAN), bao gồm giao diện R-P, sẽ độc lập với phiên bản các gói IP được truyền tải trong các phiên PPP. HiÖn t¹i, mobile IP (MIP) lµ gi¶i ph¸p ®−îc chÊp nhËn cho IP di ®éng. HiÖn nay c¸c tiªu chuÈn 3GPP hç trî MIPv4 b»ng c¸ch gép chøc n¨ng FA trong GGSN. Do trong IPv6 kh«ng cã FA, nªn MIPv6 kh«ng cã thªm yªu cÇu g× ®èi víi kiÕn tróc m¹ng 3GPP. GTP (GPRS Tunneling Protocol) ®−îc sö dông trong m¹ng 3GPP cho phÐp di ®éng trong cïng mét miÒn vµ gi÷a c¸c c«ng nghÖ truy cËp kh¸c nhau. Hình 4.10. IPv6 tại các hệ thống viễn thông di động toàn cầu. Hình 4.11. Các dịch vụ hỗ trợ IPv6 cho mạng WCDMA2000. 110 C¸c ®Çu cuèi 3G hi väng cã kh¶ n¨ng thùc hiÖn mét sè c¸c giao diÖn ®Ó sö dông víi c¸c m¹ng truy nhËp kh¸c nhau. VÝ dô, ngoµi kh¶ n¨ng hç trî c¸c giao diÖn di ®éng tæ ong, c¸c ®Çu cuèi cã thÓ hç trî c¸c c«ng nghÖ vo tuyÕn kh¸c nh− Bluetooth, Infra Red…Gi¶ thiÕt c¸c c«ng nghÖ truy nhËp nµy kÕt nèi víi c¸c router truy nhËp kh¸c nhau, khi ®ã mét ®Þa chØ IPv6 ®Çu cuèi cã thÓ thay ®«i khi di chuyÓn gi÷a c¸c m«i tr−êng nµy. Do ®ã ®Ó ®¶m b¶o tÝnh di ®éng liÒn m¹ch vµ duy tr× ®−îc c¸c kÕt nèi ®ang diÔn ra, cã thÓ sö dông MIPv6. MIPv6 còng cã thÓ ®−îc sö dông khi chuyÓn vïng gi÷a c¸c m¹ng 3GPP kh¸c nhau, do ®ã cho phÐp cã thÓ liªn l¹c tíi mét thiÕt bÞ theo tuyÕn tèi −u nhÊt. H×nh 4.12 m« t¶ viÖc kÕt hîp c¸c giao thøc qu¶n lý di ®éng kh¸c nhau cho c¸c hÖ thèng v« tuyÕn IPv6. H×nh 4.12. Qu¶n lý di ®éng trong c¸c hÖ thèng v« tuyÕn IPv6. 111 KẾT LUẬN VÀ KIẾN NGHỊ Tương lai của Internet di động đòi hỏi giao thức Internet lựa chọn phải cho phép khả năng mở rộng cao và hiệu suất quản lý cao. IPv6 cùng một số tính năng nổi trội làm cho nó trở thành ứng cử viên chính cho môi trường này. Các tính năng này đã dẫn tới quyết định của 3GPP sử dụng IPv6 cho các dịch vụ mới với các phiên bản về sau của UMTS. Để các nhà khai thác di động động có thể tận dụng được các ưu điểm của IPv6, cần phải xem xét một cách tỉ mỉ khi thực hiện các quyết định như về vấn đề địa chỉ, bảo mật, quản lý di động trong mạng của mình. Để có thể tận dụng được giao diện vô tuyến một cách hiệu quả, các nhà khai thác và thiết kế mạng phải đảm bảo rằng mạng của mình hỗ trợ các cơ chế được xác định trong các cơ quan tiêu chuẩn để phục vụ cho mục đích này. Tại Việt Nam phương pháp phù hợp để chuyển sang IPv6 là nên chọn phương cách một hệ thống dùng song song cả IPv4 và IPv6 thì hợp lý hơn là phải đầu tư cho hai hệ thống một lúc. Về mặt kỹ thuật, việc chuyển sang IPv6 tại Việt Nam không phải là điều khó khăn. Internet ở nước ta mới phát triển và các hệ thống máy móc hầu hết đều được đầu tư mới, mà đa phần những hệ thống thiết bị mới đều có thể hỗ trợ IPv6. Tất cả thiết bị mạng nói chung của các nhà cung cấp dịch vụ Internet tại Việt Nam đều có khả năng hỗ trợ IPv6. Ngay cả các hệ thống đầu cuối như Windows XP của Microsoft cũng có khả năng này. 112 TÀI LIỆU THAM KHẢO Tiếng Việt [1]. Chu Ngọc Anh, Nguyễn Phi Hùng, Phạm Vĩnh Hòa (2003), “IPv6 cho mạng thông tin di động thế hệ mới”, Tài liệu hội nghị khoa học lần thứ năm, tr.167-176. [2]. TS.Nguyễn Quý Minh Hiển, TS.Đỗ Kim Bằng (2002), Mạng viễn thông thế hệ sau, NXB Bưu điện Tiếng Anh [3]. B. Carpenter e K. Moore (2001), Connection of IPv6 Domains via IPv4 Clouds, RFC3056. [4] G.De Marco, P.Asprino, A.Fresa, M.Longo (2003), Developing new generation network services, IEEE Communication magazine 2003 [5]. J. Bound, L. Toutain, F. Dupont, H. Afifi e A. Durand (2001), Dual Stack Transition Mechanism (DSTM), Gen. [6]. JJYH-CHENG CHEN, TAO ZHANG (2004), IP-Based Next-Generation Wireless Networks, John Wiley & Sons, Inc. [7]. Juha Korhonen (2001), Introduction to 3G Mobile Communications, Artech House, Boston.London [8]. Karim El Malki (2003), IPv6 in Mobile Networks, Ericsson. [9]. K.H.Lee, K.O.Lee, K.C.Park (2003), Ar-chitecture to be deployed on strategies of Next Generation Networks, IEEE Communication magazine 2003 [10]. Ramjee Prasad, Werner Mohr & Walter Konhouser (2000), Third Generation Mobile Communication Systems, Artech House, Boston.London.

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

  • pdf000000208034R.pdf
Tài liệu liên quan