Chương 8 Lớp ứng dụng Application Layer

Các lớp bên dưới: cung cấp dịch vụ vận chuyển dữ liệu cho lớp ứng dụng không thực sự giao tiếp với người sử dụng. lớp ứng dụng cũng cần có các giao thức hỗ trợ để cho phép các ứng dụng thực hiện được các chức năng của mình.

pdf56 trang | Chia sẻ: lylyngoc | Lượt xem: 1790 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Chương 8 Lớp ứng dụng Application Layer, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
1MẠNG MÁY TÍNH Chương 8 LỚP ỨNG DỤNG Application Layer 2Giới thiệu  Các lớp bên dưới: cung cấp dịch vụ vận chuyển dữ liệu cho lớp ứng dụng không thực sự giao tiếp với người sử dụng.   lớp ứng dụng cũng cần có các giao thức hỗ trợ để cho phép các ứng dụng thực hiện được các chức năng của mình. 38.1- Hệ thống tên miền DNS 8.1.1- Không gian tên miền  Các ứng dụng máy chủ theo địa chỉ mạng tương ứng của chúng.  Địa chỉ này thường rất khó nhớ  sử dụng ký tự chữ cái để thay thế cho các địa chỉ mạng.  Do mạng chỉ hiểu được các địa chỉ có các cơ chế để chuyển đổi chuỗi mã ASCII thành địa chỉ mạng  Khi số lượng các máy tính và máy chủ nối đến mạng quá lớn  quản lý tập trung để tránh xung đột về tên phần tử mạng. Đó là lý do ra đời của Hệ thống tên miền (DNS) 4Hệ thống tên miền DNS  Cấu trúc DNS  cấu trúc phân cấp dạng cây theo miền tên  hệ thống cơ sở dữ liệu phân tán 5Hệ thống tên miền DNS  Trên cùng là nút gốc các nút cha, nút con,… cuối cùng là các nút lá  Mỗi server quản lý DNS sẽ ứng với một nút của cây  Mỗi nút biểu diễn một miền trong hệ thống DNS  Mỗi miền có một hay nhiều miền con và có một máy chủ DNS tương ứng quản lý hệ thống tên trong miền đó 6Hệ thống tên miền DNS  Nút: Độ dài tên không quá 63 ký tự Nút kề nhau không được có cùng tên Nút gốc có nhãn rỗng, ký hiệu “.”  Miền con: Tạo thành từ mỗi nút của không gian tên Các nút bên dưới có thể đi đến được các nút đó 7Hệ thống tên miền DNS  Cơ chế phân giải Để gắn một tên miền vào một địa chỉ IP, một chương trình ứng dụng sẽ gọi một thủ tục trong thư viện gọi là Bộ phân giải tên miền (Resolver) và truyền tham số tên cho nó. Bộ phân giải tên sẽ gửi gói dữ liệu dạng UDP cho máy chủ DNS, tại đây máy chủ DNS sẽ tìm kiếm và cung cấp một địa chỉ IP tương ứng cho Bộ phân giải tên. Căn cứ vào địa chỉ IP này, chương trình có thể thiết lập kết nối TCP với đầu cuối hoặc gửi gói dữ liệu UDP 8Hệ thống tên miền DNS 98.1.2- Bản ghi tài nguyên RR  Mỗi tên miền đều có thể có một tập bản ghi tài nguyên liên quan  Bản ghi tài nguyên = (IP + tài nguyên khác).  Chức năng chính của DNS là gán tên miền vào bản ghi tài nguyên.  Các bản ghi tài nguyên ở dạng mẫu tự ASCII Domain_name Time_to_live Class Type Value 10 Bản ghi tài nguyên  Domain_name: chỉ miền mà bản ghi áp dụng.  Time_to_live: biểu thị thời gian sống của bản ghi.  Class:  Internet: trường này có giá trị là IN.  Non-internet: giá trị khác  Type: chỉ loại bản ghi  11 Văn bản dạng mã ASCIIMô tả máy chủ DNSTXT CPU và Hệ ĐH bằng ký tựCấu hình của ServerHINFO Tên danh định của đ/c IPCon trỏ ánh xạ đ/c IP sang tên miền PTR Tên miềnSD khi khai báo nhiều tên miền cùng trỏ đến 1 đ/c CNAME Tên của máy chủ miềnMáy chủ tên miền/ miền quản lý NS Ưu tiên, miền sẵn sàng nhận thưXĐ máy chủ email cho một tên miền MX Số nguyên 32-bitĐịa chỉ IP của một máy chủ nào đó A Các tham số của miền (số id, email, TTL,…) Khởi tạo quyền (máy chủ này là nơi lưu trữ dl về miền) SOA Giá trịÝ nghĩaType 12 8.1.3- Máy chủ tên miền  Hệ thống Internet được chia thành hơn 200 miền cấp cao, mỗi miền chứa một số lượng lớn các máy chủ và được chia thành nhiều miền con theo phân cấp.  Một tên miền cấp cao: tổ chức và địa lý.  Ví dụ:.gov; .int; ... (ISO 3166 ) 13 Không gian tên miền  Tên miền đầy đủ: Tên các nút từ nút lá đến nút gốc Phân cách bằng dấu chấm “.” Ví dụ:  Các miền cấp cao (mức đỉnh): Miền tổ chức: tên gồm 3 ký tự Ví dụ: com, edu, gov, … Miền địa lý: các mã quốc gia gồm 2 ký tự Ví dụ: uk, vn, ca, fr, … 14 Không gian tên miền  Tên miền của một nút: Dãy các nhãn từ nút đó đến nút của cây Các nhãn trong tên miền cách nhau bằng dấu chấm “.” Độ dài tên miền tối đa là 255 ký tự Tên miền tuyệt đối kết thúc bằng dấu chấm “.” Ví dụ: www.microsoft.com. Tên miền tương đối không kết thúc bằng dấu chấm và sẽ được phần mềm cục bộ ghép đầy đủ khi xử lý Một miền là miền con của miền khác nếu tên miền đó chứa tên miền kia 15 Không gian tên miền Mô tảMiền (domain) Các tổ chức không thuộc một trong các loại trênorg Một mạng không thuộc các loại phân vùng khácnet Các tổ chức quân sựmil Các tổ chức quốc tếint Các tổ chức chính phủgov Các tổ chức giáo dụcedu Các tổ chức thương mại, doanh nghiệpcom (commercial) Miền tổ chức 16 Không gian tên miền Việt Namvn Nhật Bảnjp Ý it Quốc gia tương ứngMiền (domain) CHLB Đứcde Phápfr Phần Lanfi Canada ca Bỉbe Áoat Úcau Miền địa lý 17 Máy chủ tên miền  Có thể sử dụng một máy chủ tên miền để chứa toàn bộ cơ sở dữ liệu DNS  Thực tế:  máy chủ này sẽ bị quá tải vì số lượng tên miền quá lớn,  máy chủ này ngừng hoạt động Internet sẽ không làm việc được. Zone 18 Máy chủ tên miền  Zone Mỗi zone là một phần của hệ thống tên miền (tree) Chứa một name server lưu thông tin của miền đó 19 Hoạt động  Dựa trên mô hình client/server Client đưa ra một truy vấn đến DNS server Sau đó DNS server tìm kiếm trong CSDL và phản hồi lại thông tin tìm được Client DNS Server Truy vấn www.microsoft.com  IP ? Phản hồi địa chỉ IP 20 Hoạt động Quá trình truy cập trang web www.yahoo.com 1. Truy vấn địa chỉ IP của tên vùng www.yahoo.com? 4. Phản hồi lại trang chủ của www.yahoo.com 2. Địa chỉ IP của www.yahoo.com là 209.191.93.52 3. Truy xuất trang chủ tại địa chỉ 209.191.93.52 DNS Server Client 209 .191.93.52 21 Hoạt động 22 8.2 Hệ thống thư điện tử  Năm 1982, hệ thống thư điện tử của ARPANET xuất hiện tương ứng với chuẩn RFC 821 (giao thức truyền dẫn) và RFC 822 (khuôn dạng bản tin). Sau đó chúng được chỉnh sửa lại thành các chuẩn của mạng Internet là RFC 2821 và RFC 2822. 23 8.2.1- Kiến trúc và các dịch vụ  Hệ thống thư điện tử bao gồm 2 thành phần  Tác tử người dùng: cho phép người sử dụng đọc và gửi mail. Đây chính là các chương trình cục bộ cung cấp các phương thức dựa vào câu lệnh, bảng chọn (menu) hoặc đồ họa để tương tác với hệ thống thư điện tử.  Tác tử truyền bản tin: cho phép chuyển bản tin từ nguồn đến đích. Chúng thường là các nhân (deamon) của hệ thống hoạt động như các tiến trình nền  Hầu hết các hệ thống đều cho phép người sử dụng tạo hộp thư để lưu trữ thư nhận được. Người ta thường sử dụng các câu lệnh để tạo và hủy hộp thư, duyệt nội dung thư, chèn và xóa bản tin khỏi hộp thư, ... 24 Kiến trúc và các dịch vụ  Hệ thống thư điện tử hỗ trợ 5 chức năng cơ bản sau: Kết cấu bản tin: liên quan đến tiến trình tạo bản tin và trả lời Chuyển giao bản tin: liên quan đến việc di chuyển bản tin từ nguồn đến đích nhận Thông báo: báo cho người gửi biết tình trạng của bản tin Hiển thị bản tin nhận được để người nhận có thể đọc. Sắp xếp/ bố trí: đây là bước cuối cùng, nó liên quan đến các thao tác mà người nhận làm đối với bản tin đã nhận được. 25 Kiến trúc và các dịch vụ  Kết cấu một thư gồm 3 phần: bao thư (envelop), phần đầu (header) và phần thân (body) Envelop: đóng gói bản tin. Chứa các thông tin cần thiết để truyền bản tin (đ/c nhận, mức độ ưu tiên, bảo mật,…) Header: chứa các thông tin liên đến tác tử người dùng 26 8.2.2- Tác tử người dùng  Một tác tử người dùng một chương trình /bộ đọc thư, có thể hiểu được các lệnh để tạo thư, nhận thư và phản hồi thư cũng như các thao tác đối với hộp thư. Gửi thư điện tử  Nội dung  nội dung bản tin  địa chỉ đích  các thông số cần thiết khác.  Bản tin có thể được tạo bởi các bộ soạn thảo, chương trình xử lý văn bản.  Địa chỉ của người nhận phải tuân theo khuôn dạng mà tác tử người dùng có thể hiểu được. 27 Tác tử người dùng Đọc thư điện tử  Khi tác tử người dùng khởi động, nó tìm kiếm thư gửi đến trong hộp thư của người sử dụng trước khi hiển thị. Sau đó nó có thể thông báo số lượng các bản tin trong hộp thư hoặc liệt kê danh sách các thư nhận được. 28 8.2.3- Cấu trúc bản tin  Chuẩn RFC 822  Bản tin bao gồm một bao thư gốc, các trường mào đầu, dòng ký tự trống và nội dung bản tin. Return-Path Receiced Sender From Bcc Cc To Ý nghĩaHeader 29 Cấu trúc bản tin  Ngoài ra, phần header còn chứa một số thông tin khác 30 Cấu trúc bản tin  Chuẩn MIME (The Multipurpose Internet Mail Extensions)  Chuẩn RFC 822: sử dụng cho bản tin gồm tiếng Anh và ký tự theo mã ASCII  Thực tế, bản tin có thể chứa: Chữ có dấu. Không theo mẫu tự Latin (alphabet). Chữ tượng hình Đa phương tiện  => Chuẩn MIME 31 Cấu trúc bản tin  Chuẩn MIME Tiếp tục sử dụng cấu trúc của RFC 822 Thêm vào cấu trúc của phần thân Xác định kỹ thuật mã hóa cho nội dung không phải là mã ASCII 32 Cấu trúc bản tin  Content-Type 33  Ví dụ 34 8.2.4- Truyền bản tin  Hệ thống truyền bản tin liên quan đến việc chuyển mạch bản tin từ nguồn gửi đến đích. Một phương pháp đơn giản để thực hiện việc này là thiết lập một kết nối từ máy nguồn đến máy đích và sau đó chuyển bản tin.  Giao thức  SMTP  ESMTP (Extended Simple Mail Transport Protocol ) 35 SMTP  Là một giao thức sử dụng mã ASCII đơn giản  Thiết lập một kết nối TCP - cổng 25.  Nhân của hệ thống thư điện tử sẽ lắng nghe cổng 25 thông qua giao thức SMTP. Nếu chấp nhận kết nối  sao chép bản tin và đưa vào hộp thư tương ứng. Nếu không phân phát được bản tin tạo ra thông báo lỗi chứa phần đầu của bản tin và gửi trả lại nơi phát bản tin 36 SMTP  Sau khi thiết lập kết nốiTCP đến cổng 25, máy gửi thư hoạt động như một máy khách (client), đợi máy nhận lúc này hoạt động như máy chủ (server) ra thông báo trước.  Máy chủ bắt đầu gửi một dòng văn bản chứa nhận dạng và thông báo chuẩn bị sẵn sàng nhận thư. Nếu quá trình này không xảy ra thì, máy khách sẽ giải phóng kết nối và lặp lại quá trình trên.  Nếu máy chủ sẵn sàng nhận thư điện tử, máy khách sẽ thông báo người gửi và người nhận thư. Nếu tồn tại người nhận thì máy chủ sẽ cho phép máy khách gửi thư. Sau khi máy khách gửi thư và máy chủ chấp nhận, thư sẽ không được kiểm tra lỗi vì kết nối TCP cung cấp kết nối tin cậy. 37 38 8.2.5- Phân phối bản tin đến người nhận  Vấn đề Thiết lập một kết nối TCP đến người nhận và sau đó truyền bản tin trên kết nối đó.  Tất cả các máy trạm trên mạng muốn trao đổi bản tin đều phải vào mạng (on-line).  Giải pháp Xây dựng một tác tử chuyển giao bản tin trên máy chủ ISP để nhận thư điện tử và lưu thư vào hộp thư nằm trên máy chủ ISP. 39 Phân phối bản tin đến người nhận  Để người nhận thư có thể lấy được thư từ máy chủ ISP về  giao thức cho phép tác tử chuyển giao bản tin trên máy người nhận kết nối được với tác tử chuyển giao bản tin trên máy chủ ISP và sao chép bản tin từ máy chủ về máy người nhận thư. POP3 (Post Office Protocol - Giao thức bưu điện tử).  IMAP (Internet Message Access Protocol - Giao thức truy cập thông điệp Internet). Webmail. 40 POP3  Giao thức này dùng để giữ kết nối giữa máy người gửi và máy người nhận thông qua mạng Internet trong trường hợp cả 2 máy đều cùng có mặt trên mạng và trong trường hợp người nhận không lên mạng 41 POP3  POP3 được bắt đầu khi người sử dụng khởi động bộ nhận thư.  Bộ nhận thư sẽ gọi máy chủ ISP và thiết lập một kết nối TCP với tác tử chuyển giao bản tin ở cổng 110.  Khi thiết lập được kết nối, POP3 sẽ thực hiện tuần tự tiến trình sau: Chứng thực Giao dịch Cập nhật 42 POP3 43 IMAP  Giao thức POP3 sẽ hoạt động có hiệu quả khi một người sử dụng chỉ có một địa chỉ thư điện tử trên một ISP và luôn truy cập từ một máy tính. Nếu việc nhận thư được thực hiện ở nhiều máy và nhiều nơi khác nhau thì tất cả các thư của một người nào đó sẽ bị phân tán rải rác khắp nơi.   IMAP (RFC 2060)  Tất cả các thư điện tử sẽ được lưu giữ trong máy chủ vô thời hạn và ở trong nhiều hộp thư,  Cung cấp các cơ chế mở rộng cho phép đọc được các bản tin hoặc một phần bản tin mà không cần chuyển bản tin về máy người nhận 44 POP3 vs. IMAP 45 Webmail  Webmail sử dụng các tác tử chuyển giao bản tin để lắng nghe cổng 25 đối với kết nối SMTP vào. Một kết nối TCP được thiết lập để gửi các lệnh SMTP.  Khi người sử dụng đăng nhập vào trang web, nếu đăng nhập thành công, máy chủ sẽ tìm kiếm hộp thư của người sử dụng và liệt kê danh sách thư điện tử có trong đó theo định dạng của trang web 46 World Wide Web 47 World Wide Web  WWW là một hệ thống thông tin phi cấu trúc. Bao gồm các Server cung cấp t.tin theo định dạng siêu văn bản và các Client (trình duyệt) nhận thông tin/hiển thị thông tin theo yêu cầu NSD  Sử dụng giao thức HTTP (HypterText Transfer Protocol). 48 World Wide Web  Các thành phần của www Clients Nhà cung cấp dịch vụ Internet (ISP) Hệ thống truyền dẫn, Routers và switches Servers 49 World Wide Web  Cách thức một trình duyệt lấy một web page Client gửi một yêu cầu đến server để lấy trang web. Một yêu cầu có cấu trúc theo giao thức HTTP chứa một địa chỉ trang web đó (còn gọi là URL- Uniform Resource Locator). Một địa chỉ trang web có cấu trúc như sau: 50 World Wide Web  Một trang web là một tài liệu điện tử được viết bằng HTML hoặc các ngôn ngữ khác.  Trang web có thể chứa văn bản, hình ảnh, video, ảnh động và âm thanh, các dữ liệu tương tác.  Mỗi trang web có một địa chỉ duy nhất URL xác định vị trí của nó trên server.  Các trang web chứa siêu liên kết đến các trang web khác. 51 World Wide Web  Web site: Một website là một hay nhiều trang web có nội dung liên quan, được tổ chức lưu trữ theo cấu trúc và liên kết với nhau bởi các siêu liên kết (hyperlink). Người dùng có thể duyệt hết các trang web bằng các sử dụng các siêu liên kết giữa các trang web này 52 World Wide Web  Cookies Lưu thông tin về người dùng (user) đã truy cập vào server để sử dụng lại các thông tin này  Phân biệt người dùng nào đã đăng ký rồi  Thương mại điện tử: xác định hàng đã bỏ vào shopping cart  Customized web portal: yahoo, gmail,… Khi người dùng yêu cầu 1 trang web, server gắn thêm các thông tin vào trang web trả về này  Cookies RFC 2109 53 World Wide Web  Cấu trúc Content: chứa các thông tin mà Server có thể dùng lại 54 World Wide Web  Static Web Dữ liệu chứa trong máy chủ, chỉ có thể hiện thị và không thể thay đổi  Dynamic Web 55 Ví dụ về truyền thông của SMTP Sau khi kết nối giữa người gửi (trình khách) và người nhận (trình chủ) đã được thiết lập, những việc làm sau đây là những việc hoàn toàn hợp lệ, đối với một phiên giao dịch dùng giao thức SMTP. Các hệ thống máy tính đều có thể thiết lập một kết nối, bằng cách dùng những dòng lệnh của phần mềm telnet, trên một máy khách. Chẳng hạn: telnet www.example.com 25 khởi động một kết nối SMTP từ máy gửi thông điệp đến máy chủ www.example.com. 56 S: 220 www.example.com ESMTP Postfix C: HELO mydomain.com S: 250 Hello mydomain.com C: MAIL FROM: S: 250 Ok C: RCPT TO: S: 250 Ok C: DATA S: 354 End data with . C: Subject: test message C: From: sender@mydomain.com C: To: friend@example.com C: C: Hello, C: This is a test. C: Goodbye. C: . S: 250 Ok: queued as 12345 C: QUIT S: 221 Bye