socket连接数受端口号的限制?谬论
mhr18 2025-05-28 18:50 13 浏览 0 评论
初学网络的同学对 socket 可能会有误解:
服务器能接受的最大连接数跟端口的个数 65536 有关系!
为什么会有这样的误会?
服务器端的程序无非是这样的:
socket(); //创建socket
bind(); //绑定IP和端口号
listen(); //设置监听队列
fd = accept(); //建立TCP连接
socket 绑定的端口号用于监听客户端的连接使用,所以在写客户端代码的时候,每次都是向指定的端口号发起连接,这个端口号一定是服务器绑定的端口号。
accept 相当于是在服务器和客户端之间建立了一个「专属通道」。很多同学会错误地理解成:执行 accept 的时候,服务器会挑一个空闲的端口,和客户端建立连接。
其实,这样理解并不对。
端口
怎么理解端口?
我们平时说的端口一般都是指逻辑端口,比如浏览器用的 80 端口,FTP 工具用的 21 端口。由于网络工具众多,于是对网络端口做了编号,从 0 到 65535。
其中 0 - 1023 是公认的端口号,就是已经被一些知名的软件给占用了。留给我们程序里面使用的是 1024 - 65535。
accept 并没有占用新的端口
为了更好地理解,我们写个程序验证下。
test_server.c
socket();
bind();
listen();
while (1)
{
accept();
pthread_create();
}
最简单的一种并发服务器,为每个客户端启动一个线程。
运行后查看端口的使用情况:
此时服务器进程只占用了 8000 端口用于监听。
启动两个客户端,向服务器发起请求:
图上显示已经很清楚了。
一个连接来自 114.67.xxx.140 的 50544 端口;
一个连接来自 106.14.xxx.205 的 57310 端口。
但是对于服务器本身来说,一直都是用 8000 这个端口跟客户端建立连接。
所以,端口的个数跟服务器的并发数没有直接关系。并不会因为端口满了,就不能处理客户端的连接请求。
socket通过绑定操作占领 8000 端口,接下来其他程序将不能使用 8000 端口。一旦 8000 端口收到数据,系统都会转发给该程序,所以不会出现微信好友发送的数据,被QQ给收到了。可以简单地理解成,操作系统通过端口号,把不同的应用程序区分开。
那 accept 建立的新的连接怎么理解?如果没有新增端口,服务器怎么区分不同的客户端?
socket 建立的 TCP 连接包含了两个信息,一个是源 IP 和端口,就是数据来自哪里,一个是目的IP和端口,就是把数据发送到哪。
虽然他们用的都是 8000 端口,但是socket可以根据源 IP 和端口号区分出不同的连接,在Linux里面,就是对应不同的文件描述符。所以不用担心数据会乱掉。
相关视频推荐
tcp/ip accept,11个状态,细枝末节的秘密,还有哪些你不知道?
网络原理tcp/udp,网络编程epoll/reactor,面试中正经“八股文”
学习地址:C/C++Linux服务器开发/后台架构师【零声教育】-学习视频教程-腾讯课堂
需要C/C++ Linux服务器架构师学习资料加qun812855908获取(资料包括C/C++,Linux,golang技术,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,TCP/IP,协程,DPDK,ffmpeg等),免费分享
服务器的并发数量受什么限制?
硬件
比如服务器的核数、内存大小等等,核数越多,内存越大,当然能处理的连接也就越多。
系统资源
比如文件数量,这直接决定了系统最多支持多少个文件描述符,一旦超过,将无法继续接受客户端的连接。
程序结构
能够支持并发的服务器,可以选择的模型有很多,比如多线程、select、epoll + 单线程、epoll + 多线程等等。实际上,由于线程会占用内核资源,所以它并不算一个好的解决方案,select 或者 epoll 更受欢迎。
总的来说,要想实现高并发模型,需要多核的服务器,具备超大内存,调整系统参数(比如ulimit、nf_conntrack等等),最后还要针对项目需求写出合适的软件结构。只有软硬件配合起来,才能处理更多的连接请求。
相关推荐
- 一文读懂Prometheus架构监控(prometheus监控哪些指标)
-
介绍Prometheus是一个系统监控和警报工具包。它是用Go编写的,由Soundcloud构建,并于2016年作为继Kubernetes之后的第二个托管项目加入云原生计算基金会(C...
- Spring Boot 3.x 新特性详解:从基础到高级实战
-
1.SpringBoot3.x简介与核心特性1.1SpringBoot3.x新特性概览SpringBoot3.x是建立在SpringFramework6.0基础上的重大版...
- 「技术分享」猪八戒基于Quartz分布式调度平台实践
-
点击原文:【技术分享】猪八戒基于Quartz分布式调度平台实践点击关注“八戒技术团队”,阅读更多技术干货1.背景介绍1.1业务场景调度任务是我们日常开发中非常经典的一个场景,我们时常会需要用到一些不...
- 14. 常用框架与工具(使用的框架)
-
本章深入解析Go生态中的核心开发框架与工具链,结合性能调优与工程化实践,提供高效开发方案。14.1Web框架(Gin,Echo)14.1.1Gin高性能实践//中间件链优化router:=...
- SpringBoot整合MyBatis-Plus:从入门到精通
-
一、MyBatis-Plus基础介绍1.1MyBatis-Plus核心概念MyBatis-Plus(简称MP)是一个MyBatis的增强工具,在MyBatis的基础上只做增强不做改变,为简化开发、提...
- Seata源码—5.全局事务的创建与返回处理
-
大纲1.Seata开启分布式事务的流程总结2.Seata生成全局事务ID的雪花算法源码3.生成xid以及对全局事务会话进行持久化的源码4.全局事务会话数据持久化的实现源码5.SeataServer创...
- Java开发200+个学习知识路线-史上最全(框架篇)
-
1.Spring框架深入SpringIOC容器:BeanFactory与ApplicationContextBean生命周期:实例化、属性填充、初始化、销毁依赖注入方式:构造器注入、Setter注...
- OpenResty 入门指南:从基础到动态路由实战
-
一、引言1.1OpenResty简介OpenResty是一款基于Nginx的高性能Web平台,通过集成Lua脚本和丰富的模块,将Nginx从静态反向代理转变为可动态编程的应用平台...
- 你还在为 Spring Boot3 分布式锁实现发愁?一文教你轻松搞定!
-
作为互联网大厂后端开发人员,在项目开发过程中,你有没有遇到过这样的问题:多个服务实例同时访问共享资源,导致数据不一致、业务逻辑混乱?没错,这就是分布式环境下常见的并发问题,而分布式锁就是解决这类问题的...
- 近2万字详解JAVA NIO2文件操作,过瘾
-
原创:小姐姐味道(微信公众号ID:xjjdog),欢迎分享,转载请保留出处。从classpath中读取过文件的人,都知道需要写一些读取流的方法,很是繁琐。最近使用IDEA在打出.这个符号的时候,一行代...
- 学习MVC之租房网站(十二)-缓存和静态页面
-
在上一篇<学习MVC之租房网站(十一)-定时任务和云存储>学习了Quartz的使用、发邮件,并将通过UEditor上传的图片保存到云存储。在项目的最后,再学习优化网站性能的一些技术:缓存和...
- Linux系统下运行c++程序(linux怎么运行c++文件)
-
引言为什么要在Linux下写程序?需要更多关于Linux下c++开发的资料请后台私信【架构】获取分享资料包括:C/C++,Linux,Nginx,ZeroMQ,MySQL,Redis,fastdf...
- 2022正确的java学习顺序(文末送java福利)
-
对于刚学习java的人来说,可能最大的问题是不知道学习方向,每天学了什么第二天就忘了,而课堂的讲解也是很片面的。今天我结合我的学习路线为大家讲解下最基础的学习路线,真心希望能帮到迷茫的小伙伴。(有很多...
- 一个 3 年 Java 程序员 5 家大厂的面试总结(已拿Offer)
-
前言15年毕业到现在也近三年了,最近面试了阿里集团(菜鸟网络,蚂蚁金服),网易,滴滴,点我达,最终收到点我达,网易offer,蚂蚁金服二面挂掉,菜鸟网络一个月了还在流程中...最终有幸去了网易。但是要...
- 多商户商城系统开发全流程解析(多商户商城源码免费下载)
-
在数字化商业浪潮中,多商户商城系统成为众多企业拓展电商业务的关键选择。这类系统允许众多商家在同一平台销售商品,不仅丰富了商品种类,还为消费者带来更多样的购物体验。不过,开发一个多商户商城系统是个复杂的...
你 发表评论:
欢迎- 一周热门
-
-
Redis客户端 Jedis 与 Lettuce
-
高并发架构系列:Redis并发竞争key的解决方案详解
-
redis如何防止并发(redis如何防止高并发)
-
开源推荐:如何实现的一个高性能 Redis 服务器
-
redis安装与调优部署文档(WinServer)
-
Redis 入门 - 安装最全讲解(Windows、Linux、Docker)
-
一文带你了解 Redis 的发布与订阅的底层原理
-
Redis如何应对并发访问(redis控制并发量)
-
oracle数据库查询Sql语句是否使用索引及常见的索引失效的情况
-
Java SE Development Kit 8u441下载地址【windows版本】
-
- 最近发表
- 标签列表
-
- oracle位图索引 (63)
- oracle批量插入数据 (62)
- oracle事务隔离级别 (53)
- oracle 空为0 (50)
- oracle主从同步 (55)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)