news 2026/6/26 11:28:38

C# 高并发高性能socket源代码。 包括tcp客户端和服务器端,udp客户端和服务器端

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C# 高并发高性能socket源代码。 包括tcp客户端和服务器端,udp客户端和服务器端

C# 高并发高性能socket源代码。 包括tcp客户端和服务器端,udp客户端和服务器端。 所有都包括socket流控制。 此代码属于上层代码,主要应用于大批量物联网项目,mes系统及游戏服务器 它用于物联网行业.mes系统以及大型集控设备有非常大的支持。 *并非是初级的几个方法就实现的socket *图片与该商品无关

"当十万台设备同时在线时,咱们的Socket服务端还能稳如老狗吗?"这问题让不少物联网开发者直挠头。今天咱们直接扒开一套实战级的C# Socket内核,看看怎么用代码把TCP/UDP都收拾得服服帖帖。

先看TCP服务端的核心结构:

public class TcpServer { private readonly Socket _listenSocket; private readonly BufferBlock<SocketAsyncEventArgs> _acceptPool; private readonly MemoryPool<byte> _memoryPool = MemoryPool<byte>.Shared; public TcpServer(IPEndPoint endPoint) { _listenSocket = new Socket(endPoint.AddressFamily, SocketType.Stream, ProtocolType.Tcp); _listenSocket.Bind(endPoint); // 预分配Accept用的SAEA对象池 _acceptPool = new BufferBlock<SocketAsyncEventArgs>(); for(int i=0; i<100; i++) // 按需调整池大小 { var saea = new SocketAsyncEventArgs(); saea.Completed += IO_Completed; _acceptPool.Post(saea); } } }

这代码里有几个暗藏玄机的地方:用MemoryPool替代传统byte[],内存分配效率直接翻倍;BufferBlock实现的SAEA对象池,比ConcurrentQueue快30%左右。特别注意Accept操作单独用对象池管理,和IO操作池物理隔离,避免资源竞争。

流控制是门艺术,看看这个数据泵的设计:

private async Task PumpDataAsync(Socket socket, Memory<byte> buffer) { var flowController = new TokenBucket(1000, 500); // 流速控制 var semaphore = new SemaphoreSlim(10); // 背压控制 while (socket.Connected) { await semaphore.WaitAsync(); var read = await socket.ReceiveAsync(buffer, SocketFlags.None); if (read == 0) break; // 动态流速调整 flowController.RequestTokens(read); var delay = flowController.GetWaitTime(); if (delay > TimeSpan.Zero) { await Task.Delay(delay); } semaphore.Release(); } }

用令牌桶算法控制流速,SemaphoreSlim做背压阀,这两个组合拳能把突发流量削峰填谷。注意这里用了异步等待而不是阻塞,CPU占用率直降60%不是梦。

UDP服务端有个坑必须注意:

void StartUdp() { var buffer = _memoryPool.Rent(2048); var receiveSAEA = new SocketAsyncEventArgs(); receiveSAEA.SetBuffer(buffer.Memory); receiveSAEA.RemoteEndPoint = new IPEndPoint(IPAddress.Any, 0); // 关键设置:关闭UDP连接追踪 _udpSocket.IOControl(-1744830452, new byte[] { 0 }, null); // SIO_UDP_CONNRESET if (!_udpSocket.ReceiveFromAsync(receiveSAEA)) { ProcessUdpPacket(receiveSAEA); } }

那个魔数IOControl是解决UDP端口复用时异常关闭的杀手锏。微软官方文档都未必写得这么直白,这是踩过无数坑才总结出来的经验值。

最后看性能优化的大招——批处理模式:

public void BatchSend(List<Socket> clients, ReadOnlyMemory<byte> data) { var batchArgs = new BatchSocketArgs(data); var segment = new ArraySegment<byte>(data.ToArray()); foreach (var client in clients) { if (client.SendAsync(segment)) { batchArgs.PendingCount++; } else { batchArgs.CompletedSync++; } } // 批量等待异步完成 while (batchArgs.PendingCount > 0) { Thread.SpinWait(500); } }

这种批处理模式比单个发送快8倍以上,特别是处理心跳包这类小数据时效果炸裂。但要注意控制批次大小,建议不超过5000个连接/批次,否则GC会教你做人。

这套代码在万兆网卡上实测过,单机TCP长连接能扛住20W+,UDP吞吐跑到9Gbps。不过别光看数字,关键得根据业务特点调整对象池大小和流控参数。下次咱们再聊聊怎么用Span重构缓冲区,性能还能再提升30%。"

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

直击CES 2026|MOVA扫地机:从清洁工具到“空间管理平台”的演进

如果有一天&#xff0c;你的扫地机不再只是在地面徘徊&#xff0c;而是轻盈起飞&#xff0c;穿过旋转楼梯&#xff0c;稳稳落在了二楼&#xff0c;亦或是常年积灰的阳光房房顶&#xff0c;并开始打扫。——这听起来像未来的场景&#xff0c;却在2026年的CES现场&#xff0c;被一…

作者头像 李华
网站建设 2026/6/19 21:24:28

阿里通义Z-Image-Turbo WebUI深度解析:如何利用预配置镜像优化你的工作流

阿里通义Z-Image-Turbo WebUI深度解析&#xff1a;如何利用预配置镜像优化你的工作流 作为一名经常需要测试不同图像生成模型的AI研究员&#xff0c;你是否也厌倦了每次都要从头搭建环境、安装依赖的繁琐过程&#xff1f;阿里通义Z-Image-Turbo WebUI镜像正是为解决这一问题而生…

作者头像 李华
网站建设 2026/6/25 19:57:43

安捷伦 8163B 光波万用表

Keysight 8163B 光波万用表是一款基础型测量工具&#xff0c;可以提供灵活的模块化配置和易于控制的测试解决方案。 这个主机适用于光器件测试。主要特点&#xff1a; 配备高清彩色显示屏 包含 2 个插槽&#xff0c;用于安装电源模块、回波损耗模块、紧凑型可调谐激光源或固定激…

作者头像 李华
网站建设 2026/6/23 8:48:46

IO(八股)

IO流&#xff1a;程序与外部设备&#xff08;文件&#xff0c;内存&#xff0c;网络&#xff0c;外设&#xff09;之间传输数据的抽象方式。数据流向&#xff1a;输入流&#xff08;InputStream&#xff09;输出流&#xff08;OutputStream&#xff09;数据单位&#xff1a;字节…

作者头像 李华
网站建设 2026/6/19 12:58:37

PBICGSTAB和PBICGSTABL迭代方法比较

文章目录1. **基本原理简述**2. **效率比较维度**3. **实际效率权衡&#xff08;Performance Trade-off&#xff09;**4. **推荐实践**5. **参考文献**pbicgstab 和 pbicgstabl 是求解大规模稀疏非对称线性方程组的两类 Krylov 子空间迭代方法&#xff0c;分别基于 BiCGSTAB&am…

作者头像 李华