惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

有赞技术团队
有赞技术团队
Security Archives - TechRepublic
Security Archives - TechRepublic
大猫的无限游戏
大猫的无限游戏
The GitHub Blog
The GitHub Blog
Google DeepMind News
Google DeepMind News
Vercel News
Vercel News
U
Unit 42
L
LangChain Blog
M
MIT News - Artificial intelligence
S
SegmentFault 最新的问题
月光博客
月光博客
MongoDB | Blog
MongoDB | Blog
Jina AI
Jina AI
博客园 - 聂微东
H
Hackread – Cybersecurity News, Data Breaches, AI and More
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
Recent Announcements
Recent Announcements
Engineering at Meta
Engineering at Meta
Hacker News - Newest:
Hacker News - Newest: "LLM"
V2EX - 技术
V2EX - 技术
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
阮一峰的网络日志
阮一峰的网络日志
F
Fortinet All Blogs
D
DataBreaches.Net
Hacker News: Ask HN
Hacker News: Ask HN
W
WeLiveSecurity
N
News | PayPal Newsroom
量子位
Help Net Security
Help Net Security
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
N
News and Events Feed by Topic
Webroot Blog
Webroot Blog
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
人人都是产品经理
人人都是产品经理
S
Security @ Cisco Blogs
Y
Y Combinator Blog
H
Heimdal Security Blog
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
Stack Overflow Blog
Stack Overflow Blog
Attack and Defense Labs
Attack and Defense Labs
S
Secure Thoughts
P
Privacy International News Feed
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
SecWiki News
SecWiki News
Last Week in AI
Last Week in AI
AI
AI
Recorded Future
Recorded Future
C
Cyber Attacks, Cyber Crime and Cyber Security
Microsoft Security Blog
Microsoft Security Blog
P
Privacy & Cybersecurity Law Blog

博客园 - toong

envoy DDOS HTTP/2 Bomb CVE-2026-47774 安全漏洞分析 P2P与FRP与websocket python运行虚拟化环境 大模型从0到1 绑定网卡中断后是否需要设置RFS 现代C++ envoy timeout 说明 观察中断的脚本 /proc/interrupts openssl查看编译时选项设置的方法 内核ipsec转发优化方法 提高ipsec多核并行能力的优化方法之一 tc qdisc 的burst如何设置 bash模拟netstat取值的脚本 linux内核对MSI网卡队列的smp_affinity亲和CPU选择 bash多并发--进程池数量控制 bash单例模式 linux 分析中断 linux 查看 ipsec 丢包 linux内核rps与rfs机制分析 linux获取CPU利用率的快捷命令 开启openssl legacy的方法
linux socket reuse port 小测试
toong · 2026-01-06 · via 博客园 - toong

nginx就是 reuse port的, 指多个socket 绑在同一个 IP+port上进行监听。

内核会为其新建连接进行负载均衡。

随手做了个小测试如下:

image

代码

// 简单的单线程TCP服务器
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>                
#include <arpa/inet.h>     
                                                
#define PORT 8888
#define BUFFER_SIZE 1024
                                                                                                 
int main() {
    int server_fd, client_fd;
    struct sockaddr_in server_addr, client_addr; 
    socklen_t addr_len = sizeof(client_addr);                                                    
    char buffer[BUFFER_SIZE];
    int opt = -1;                  
                     
    // 创建socket
    server_fd = socket(AF_INET, SOCK_STREAM, 0); 
    if (server_fd < 0) {                
        perror("socket创建失败");                                                                
        return 1;                           
    }    
                                                
    // 设置SO_REUSEADDR选项 - 允许地址重用
/*    if (setsockopt(server_fd, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt)) < 0) {
        perror("setsockopt(SO_REUSEADDR)失败");                                                  
        close(server_fd);     
        return -1;
    }                                  
*/                                                                                               
    // 设置端口重用选项
    if (setsockopt(server_fd, SOL_SOCKET, SO_REUSEPORT, &opt, sizeof(opt)) < 0) {
        perror("setsockopt(SO_REUSEPORT)失败");
        close(server_fd);
        return 1;
    }
    // 配置服务器地址                                                                                                                                                              19:27:25 [1/86]
    server_addr.sin_family = AF_INET;                                                                                                                                                             
    server_addr.sin_addr.s_addr = INADDR_ANY;
    server_addr.sin_port = htons(PORT);
     
    // 绑定
    if (bind(server_fd, (struct sockaddr*)&server_addr, sizeof(server_addr)) < 0) {
        perror("绑定失败");
        return 1;
    }
     
    // 监听
    if (listen(server_fd, 5) < 0) {
        perror("监听失败");
        return 1;
    }
     
    printf("TCP服务器启动,监听端口 %d\n", PORT);
     
    while (1) {
        // 接受连接
        client_fd = accept(server_fd, (struct sockaddr*)&client_addr, &addr_len);
        if (client_fd < 0) {
            perror("接受连接失败");
            continue;
        }
         
        printf("客户端已连接: %s:%d\n", 
               inet_ntoa(client_addr.sin_addr),  
               ntohs(client_addr.sin_port));
         
        // 处理客户端
        while (1) {
            memset(buffer, 0, BUFFER_SIZE);
            int n = recv(client_fd, buffer, BUFFER_SIZE - 1, 0);
            if (n <= 0) break;
             
            printf("收到: %s", buffer);
            send(client_fd, buffer, strlen(buffer), 0);
        }
         
        printf("客户端断开连接\n");
        close(client_fd);
    }
     
    close(server_fd);
    return 0;
}