news 2026/2/17 6:16:25

【Linux】 Linux网络编程入门:Soket编程详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Linux】 Linux网络编程入门:Soket编程详解

【Linux】Linux 网络编程入门:Socket 编程详解

Socket 是 Linux(以及几乎所有类 Unix 系统)网络编程的基石。
掌握 Socket 编程,是理解网络通信、服务器开发、分布式系统、微服务通信的基础。

本文从零开始,逐步带你理解Socket 的本质 → 基本 API → 完整 TCP 服务器/客户端 → 常见模型,适合初学者快速上手,也适合有一定基础的人查漏补缺。

1. Socket 是什么?(最核心的概念)

一句话总结:

Socket 是操作系统提供的一种抽象,用于在不同主机(或同一主机不同进程)之间进行双向通信。

它本质上是内核中一段通信端点的描述,包含:

  • 协议族(IPv4 / IPv6 / Unix Domain)
  • 传输层协议(TCP / UDP)
  • IP 地址
  • 端口号

在 Linux 中,Socket 是一个文件描述符(fd),可以用read/write/close等系统调用操作。

2. Socket 编程核心 API 一览表

分类函数原型作用常见参数说明返回值含义
创建socket(int domain, int type, int protocol)创建 socketdomain: AF_INET / AF_INET6 / AF_UNIX≥0:文件描述符,-1:失败
绑定bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen)给 socket 绑定 IP + 端口0 成功,-1 失败
监听listen(int sockfd, int backlog)设置被动监听(服务器)backlog:半连接队列长度建议值0 成功,-1 失败
接受连接accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen)接受客户端连接,返回新连接 fdaddr 用于返回客户端地址≥0:新连接 fd,-1:失败
连接connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen)客户端主动发起连接0 成功,-1 失败
发送数据send(int sockfd, const void *buf, size_t len, int flags)发送数据flags:常用 0 / MSG_DONTWAIT / MSG_NOSIGNAL>0:发送字节数,0:连接关闭,-1:错误
接收数据recv(int sockfd, void *buf, size_t len, int flags)接收数据>0:接收字节数,0:对方关闭,-1:错误
关闭close(int sockfd)关闭 socket0 成功,-1 失败

3. TCP 服务器完整示例(最经典的写法)

#include<stdio.h>#include<stdlib.h>#include<string.h>#include<unistd.h>#include<arpa/inet.h>#include<sys/socket.h>#definePORT8888#defineBACKLOG128#defineBUF_SIZE1024intmain(){intserver_fd,client_fd;structsockaddr_inserver_addr,client_addr;socklen_tclient_len=sizeof(client_addr);charbuffer[BUF_SIZE];// 1. 创建 socketserver_fd=socket(AF_INET,SOCK_STREAM,0);if(server_fd==-1){perror("socket failed");exit(EXIT_FAILURE);}// 2. 地址重用(避免 TIME_WAIT 导致 bind 失败)intopt=1;setsockopt(server_fd,SOL_SOCKET,SO_REUSEADDR,&opt,sizeof(opt));// 3. 绑定地址server_addr.sin_family=AF_INET;server_addr.sin_addr.s_addr=INADDR_ANY;// 监听所有网卡server_addr.sin_port=htons(PORT);if(bind(server_fd,(structsockaddr*)&server_addr,sizeof(server_addr))==-1){perror("bind failed");exit(EXIT_FAILURE);}// 4. 开始监听if(listen(server_fd,BACKLOG)==-1){perror("listen failed");exit(EXIT_FAILURE);}printf("Server listening on port %d...\n",PORT);while(1){// 5. 接受连接(阻塞式)client_fd=accept(server_fd,(structsockaddr*)&client_addr,&client_len);if(client_fd==-1){perror("accept failed");continue;}charclient_ip[INET_ADDRSTRLEN];inet_ntop(AF_INET,&client_addr.sin_addr,client_ip,INET_ADDRSTRLEN);printf("New connection from %s:%d\n",client_ip,ntohs(client_addr.sin_port));// 6. 读写数据ssize_tn=read(client_fd,buffer,BUF_SIZE-1);if(n>0){buffer[n]='\0';printf("Received: %s\n",buffer);// 回显write(client_fd,"Server received: ",17);write(client_fd,buffer,n);}// 7. 关闭客户端连接close(client_fd);}close(server_fd);return0;}

4. TCP 客户端完整示例

#include<stdio.h>#include<stdlib.h>#include<string.h>#include<unistd.h>#include<arpa/inet.h>#include<sys/socket.h>#defineSERVER_IP"127.0.0.1"#definePORT8888#defineBUF_SIZE1024intmain(){intsock;structsockaddr_inserv_addr;charbuffer[BUF_SIZE];// 1. 创建 socketsock=socket(AF_INET,SOCK_STREAM,0);if(sock==-1){perror("socket failed");exit(EXIT_FAILURE);}// 2. 设置服务器地址serv_addr.sin_family=AF_INET;serv_addr.sin_port=htons(PORT);if(inet_pton(AF_INET,SERVER_IP,&serv_addr.sin_addr)<=0){perror("Invalid address");exit(EXIT_FAILURE);}// 3. 连接服务器if(connect(sock,(structsockaddr*)&serv_addr,sizeof(serv_addr))==-1){perror("connect failed");exit(EXIT_FAILURE);}printf("Connected to server %s:%d\n",SERVER_IP,PORT);// 4. 发送数据constchar*message="Hello from client!";send(sock,message,strlen(message),0);// 5. 接收响应ssize_tn=read(sock,buffer,BUF_SIZE-1);if(n>0){buffer[n]='\0';printf("Server reply: %s\n",buffer);}close(sock);return0;}

5.常见 Socket 编程模型对比(选择题/面试常考)

模型并发能力代码复杂度资源占用适用场景备注
多进程(fork)连接数少、每个连接处理时间长经典 Apache prefork 模式
多线程中高连接数中等pthread / C++ std::thread
IO 多路复用高并发、短连接select / poll / epoll(Linux 首选)
事件驱动极高高并发服务器libevent / libev / libuv / epoll
协程中~高极低高并发、业务逻辑复杂libco / boost.coroutine / C++20 coroutine

6. 学习进阶路线建议(Linux 网络编程)

阶段重点内容推荐练习
入门socket / bind / listen / accept / connect / read / write / close实现 echo 服务器/客户端
中级setsockopt / getsockopt / SO_REUSEADDR / SO_KEEPALIVE / TCP_NODELAY处理 TIME_WAIT、粘包、半包
进阶select / poll / epoll / epoll ET / LT 模式实现高并发 echo server
高级非阻塞 IO + 状态机 / Reactor / Proactor / 协程网络库实现简易 Redis 服务器 / Web 服务器
实战muduo / libevent / nginx / redis 网络模块阅读理解真实项目中的网络模型

7. 小结:一句话记住 Socket 编程本质

“Socket 编程 = 创建通信端点 + 绑定地址(服务器) + 建立连接 + 数据收发 + 关闭连接”

如果你现在想继续深入某个具体方向,可以直接告诉我:

随时说,我可以继续手把手带你写代码或深入讲解。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/17 4:04:46

超实用!AI教材生成工具推荐,快速产出低查重优质教材

整理教材中的知识点真是个“精细活”&#xff0c;最难的就是如何找到平衡和衔接的方式&#xff01;我们总是担心会漏掉重要的核心知识点&#xff0c;又恐怕把控不好难度的层次——小学的教材往往写得太深奥&#xff0c;让学生难以理解&#xff1b;而高中的教材则可能显得太简单…

作者头像 李华
网站建设 2026/2/16 9:15:12

76 ThreadLocal线程变量

ThreadLocal线程变量 本文深入剖析ThreadLocal线程变量的核心原理与实战应用,详解set/get/remove操作机制、内存泄漏原因分析、弱引用与强引用的关系,以及在企业级项目中的最佳实践。 1 ThreadLocal是什么? 为什么需要ThreadLocal? 在多线程并发编程中,我们经常遇到这样的场…

作者头像 李华
网站建设 2026/2/17 7:18:10

77 ThreadLocal最佳实践

ThreadLocal最佳实践 本文深入剖析ThreadLocal在企业级应用中的最佳实践,涵盖资源清理、AOP自动管理、线程池复用陷阱、父子线程传递等核心场景,并结合实战案例讲解如何正确使用ThreadLocal避免内存泄漏。 为什么要掌握ThreadLocal最佳实践? 在实际开发中,ThreadLocal使用不当…

作者头像 李华
网站建设 2026/2/17 5:01:54

五大经典排序算法:插入、希尔、冒泡、选择、堆排序全攻略

五大经典排序算法全攻略&#xff1a;插入、希尔、冒泡、选择、堆排序 这五个算法是学习排序算法时最常遇到的“入门进阶”组合&#xff0c;它们在思想、复杂度、稳定性、适用场景上各有特点&#xff0c;非常适合对比学习。 下面按从简单到相对复杂的顺序详细讲解&#xff0c;…

作者头像 李华
网站建设 2026/2/17 14:30:33

2026年第一季度时序数据库3大迁移难点全解析——从“审慎评估”到“平稳过渡”的实施路径

金仓时序数据库替换实战&#xff1a;3大迁移难点全解析——从“审慎评估”到“平稳过渡”的实施路径 在智能电网实时负荷监测、医院重症监护设备毫秒级生命体征采集、工业物联网产线振动数据高频回传等关键业务场景中&#xff0c;时间维度的数据连续性与处理时效&#xff0c;直…

作者头像 李华