news 2026/4/16 10:56:27

【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/4/16 10:54:43

C#每日面试题-简述密封类

C#每日面试题-简述密封类 在C#面试中&#xff0c;密封类&#xff08;Sealed Class&#xff09;是高频基础考点&#xff0c;看似简单&#xff08;“不能被继承”一句话就能概括&#xff09;&#xff0c;但面试官往往会追问其底层逻辑、使用场景及与其他类的区别——这正是“简单…

作者头像 李华
网站建设 2026/4/7 16:47:33

74 CountDownLatch倒计数器详解

CountDownLatch倒计数器详解 本文深入剖析Java并发工具CountDownLatch的核心原理和应用场景,详解倒计数机制、等待归零、并发任务协调、超时控制等关键技术,掌握多线程任务同步的最佳实践。 1 CountDownLatch核心原理 为什么需要CountDownLatch? 在企业级并发开发中,经常遇…

作者头像 李华
网站建设 2026/4/16 10:52:06

CANN shmem 内存池设计与跨进程虚拟地址映射原理

相关链接&#xff1a; CANN 组织主页&#xff1a;https://atomgit.com/cannshmem 仓库地址&#xff1a;https://atomgit.com/cann/shmem 前言 CANN SHMEM&#xff08;Shared Memory Library&#xff09;作为一套面向多机多卡场景的高性能内存通信库&#xff0c;其核心能力在于…

作者头像 李华
网站建设 2026/4/11 22:29:07

【Java 开发日记】我们来说一下 TCP 的三次握手四次挥手过程

【Java 开发日记】TCP 三次握手与四次挥手详解 在 Java 开发中&#xff0c;我们经常使用 Socket、Netty、Spring WebFlux、Dubbo、Kafka、Redis 等网络通信框架&#xff0c;这些底层都依赖 TCP 协议。所以理解 TCP 的三次握手和四次挥手 是网络编程的基础&#xff0c;也是面试…

作者头像 李华
网站建设 2026/4/16 10:17:43

某金融风控平台完成文档数据库替换,7天平稳上线!

——一位干过12个国产化项目的测试从业者&#xff0c;分享真实实践 上周三晚上10点&#xff0c;我蹲在客户机房角落啃冷包子&#xff0c;盯着监控大屏上那条刚跑完的压测曲线&#xff1a;QPS稳定在8600&#xff0c;平均响应217ms&#xff0c;错误率0.00%。旁边运维同事拍我肩&a…

作者头像 李华
网站建设 2026/4/15 18:10:44

实战CVE-2024–3094漏洞:从检测工具到Ansible自动化修复方案

我与CVE-2024–3094的经历以及xz漏洞检查与修复脚本 你们大多数人可能已经知道了最近爆出的 CVE-2024–3094。如果还不了解&#xff0c;这里简单介绍一下&#xff1a;这是一个在Linux社区引起轩然大波的重要漏洞。你可以在此处阅读更多相关信息。 作为负责多台Linux系统的管理…

作者头像 李华