.\" 本man頁版權所有(C)1999 Andi Kleen. .\" 可能已作修改的該頁拷貝版本要獲得授權許可,需一字不捺地包括本header(頭標識),而 .\" 且在作了較大修改的情況下,修改作者和日期需添加到header中. .\" 中文版版權所有 riser,BitBIRD www.linuxforum.net 2000 .TH UDP 7 "1998年10月2日" "Linux 手冊頁" "Linux 程式員手冊" .SH NAME (名字) udp \- IPv4 上面的 UDP 協議. .SH SYNOPSIS (總覽) .B #include .br .B #include .br .B udp_socket = socket(PF_INET, SOCK_DGRAM, 0); .SH DESCRIPTION(描述) 這是一個 RFC768 中的使用者數據報協議的實現. 它實現無連接的, 不可靠的數據報信息包服務. 信息包可能在它們傳輸到達之前重新排序或者重復. UDP 通過生成和檢查校驗和來俘獲傳輸錯誤. 當創建一個 UDP 套接字時, 它的本地和遠程地址是不確定的. 可以使用帶一個有效目的地址作為參數的 .BR sendto (2) 或者 .BR sendmsg (2) 立即發送數據報.如果套接字上調用了 .BR connect (2) 時, 則設置預設的目的地址, 數據報可以使用 .BR send (2) 或者 .BR write (2) 發送而不需要指定目的地址. 也可以通過傳遞一個地址給 .BR sendto (2) 或者 .BR sendmsg (2) 來發送到其它目的地址. 為了接收信息包,套接字必須首先用 .BR bind (2) 綁定一個本地地址, 如果沒有這麼做, 套接字層在第一個使用者接收請求時將自動分配一個本地端口. 所有接收操作只返回一個信息包. 當信息包小於所傳遞的緩沖區時, 則只返回那些數據, 當信息包大於所傳遞的緩沖區時,則截斷信息包並設置 .B MSG_TRUNC 標誌. IP 選項可以使用描述於 .BR ip "(7)" 中的套接字選項發送或接收. 只有打開了合適的 sysctl 時, 核心才處理它們(不過即使關閉了它們, 仍然會傳遞給使用者). 參見 .BR ip "(7)" . 如果設置了 .B MSG_DONTROUTE 標誌,則發送時目的地址必須指向一個本地接口地址, 而且信息包只發到該接口. 當 UDP 的總長超過接口 MTU(Maximum Transmission Unit 最大傳輸單元)時, UDP 會對信息包進行分段. 一個更為網路友好的可選方法是使用 path MTU discovery(路徑MTU發現), 它描述於 .BR ip (7) 中的 .B IP_PMTU_DISCOVER 部分. .SH ADDRESS FORMAT (地址格式) UDP 使用 IPv4 的 .B sockaddr_in 地址格式,其描述於 .BR ip (7) 中. .SH ERROR HANDLING (錯誤處理) 所有重大錯誤都會以錯誤返回值的方式傳遞給使用者, 即使套接字沒有連接亦如此.這種處理方式有別於許多其它的 BSD 套接字實現方法, 除非套接字連接上, 否則那些方法不會傳遞任何錯誤, Linux 的處理方式遵循 .B RFC1122 的要求. 為了與以前的代碼相容,可以設置 .B SO_BSDCOMPAT SOL_SOCKET 選項令只在套接字已連接的情況下接收遠程錯誤( .B EPROTO 和 .BR EMSGSIZE ) 除外. 最好是修復代碼並適當地處理錯誤, 而不要打開該選項. 本地產生的錯誤總是傳遞. 當打開了 .B IP_RECVERR 選項時, 所有錯誤可以存儲在套接字錯誤隊列中, 並可以通過帶 .B MSG_ERRQUEUE 標識設置的 .BR recvmsg (2) 來接收. .SH ERRORS (錯誤) 所有列在 .BR socket (7) 或 .BR ip (7) 中的錯誤都可以在一個 UDP 套接字上收發時收到. .B ECONNREFUSED 沒有與目的地址相關聯的接收者. 這可能由於在前面一個通過該套接字發送的信息包而引發. .SH VERSIONS(版本) IP_RECVERR 是 Linux 2.2 中的新功能. .SH CREDITS(尾注) 本手冊頁的作者為 Andi Kleen. .SH SEE ALSO(另見) .BR ip (7), .BR socket (7), .BR raw (7). RFC768: 使用者數據報協議. .br RFC1122: 主機需求 .br RFC1191: 描述 path MTU discovery (路徑MTU查找). .SH "[中文版維護人]" .B riser .SH "[中文版最新更新]" .BR 2001/07/19 .SH "《中國linux論壇man手冊頁翻譯計劃》:" .BI http://cmpp.linuxforum.net