UNIX 网络编程 chapter 4
基本TCP套接字編程
4.2 socket 函數
// 創建套接字文件描述符 #include <socket/socket.h> //返回:若成功則返回非負描述符,出錯則為-1 int socket(int family, int type, int protocol); //example : socket(AF_INET, SOCK_STREAM, IPPROTO_TCP)
4.3 connect 函數
#include <sys/socket.h> int connect(int sockfd, const struct sockaddr *servaddr, socklen_t addrlen);TCP套接字
1. 調用connect會激發TCP的“三次握手”
2. 若TCP客戶沒有收到SYN分節的響應, 返回ETIMEDOUT錯誤。
3. 客戶發送SYN分節后,收到RST響應,表明在指定的端口上沒有進程在等待與之連接, 返回ECONNREFUSES錯誤。
4. 若客戶發送的SYN在中間某個路由器上引起了一個"destination unreachable"ICMP錯誤. 返回EHOSTUNREACH 或 ENETUNTREACH錯誤
5.調用connect失敗后,都必須調用close函數關閉當前的套接字,如要再次調用connect函數,必須先重新調用socket函數
產生RST的三個條件:
目的地為某端口的SYN到達,然而該端口上沒有正在監聽的服務器;
TCP想取消一個已有連接;
TCP接收到一個根本不存在的連接上的分節。
4.4 bind 函數
int bind(int sockfd, const struct sockaddr *servaddr, socklen_t addrlen); // 成功返回0,出錯返回-1//IPv4 通配地址 struct sockaddr_in servaddr; servaddr.sin_addr.s_addr = htonl (INADDR_ANY); //IPv6 通配地址 struct sockaddr_in6 servaddr6; servaddr.sin6_addr= in6addr_any;
進程綁定非通配IP地址到套接字上的常見例子是為多個組織提供web服務器的主機上(unp/v3/P83 挺有意思)
bind函數返回的常見錯誤是EADDRINUSE:地址已經被使用
4.5 listen 函數
int listen (int sockfd, int backlog) //成功:返回0,出錯則返回-1backlog: 內核應該為相應套接字排隊的最大連接個數
內核為每個監聽的套接字維護兩個隊列:
未完成連接隊列:
由某個客戶端發出并到達服務器,而服務器正在等待完成相應的TCP三路握手過程,這些套接字處于SYN_RCD狀態
已完成連接隊列:
每個已完成三次握手過程的客戶對應其中一項。這些套接字處于ESTABLISHED狀態。
未完成連接隊列的個數+已完成連接隊列的個數不超過backlog
4.10 getpeername 和 getsockname
getsockname返回與某個套接字關聯的本地協議地址,getpeername返回與某個套接字關聯的外地協議地址。
struct sockaddr_in cltaddr;socklen_t len = sizeof (cltaddr);if (getsockname(sockfd, (struct sockaddr*)(&cltaddr), &len) < 0){err_sys("getsockname err."); }總結
以上是生活随笔為你收集整理的UNIX 网络编程 chapter 4的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 新版微信小程序即将上线 新增微信支付功能
- 下一篇: 嵌入式_makefile简单语法介绍