c# socket多连接(如何达到10万个客户端)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c# socket多连接(如何达到10万个客户端)相关的知识,希望对你有一定的参考价值。

c# socket多连接(如何达到10万个客户端) 每个连接的数据处理量很小
需要长连接

无论是采用TCP协议还是UDP协议
1)仔细分析瞬时的链接数:是在1秒之内有10万个并发连接,还是在1小时内有10万个,或者是在1天内有10万个。这个很重要。
2)测试一个连接从连接建立-->发送接收处理-->关闭连接所需要的运行时间
3)采用异步处理。Socket异步处理是出来大并发连接数量的不二选择。异步处理本质上是多线程的,而且使用线程池。借助线程池能够提供线程处理性能。根据1)和2)分析的结果有可能需要调整线程池默认线程数量。
4)如果采用TCP协议,完成处理后,一定要关闭Accept建立的客户端连接;否则,会过度消耗系统资源,导致你的程序处理能力下降甚至崩溃。
5)如果采用UDP协议,不需要关闭服务端SOCKET
6)一个SOCKET理论上最大能处理65535个连接。也许你需要建立多个SOCKET才能满足这么高的并发连接数量。究竟需要建立多少个SOCKET,还是由1)和2)的结果决定。
============
既然数量量小,就没有长连接的必要!
长时间连接而不传数据,这样的很浪费服务器资源
参考技术A 需不需要长连接,如果不需要,客户端连上去之后发送完数据库断掉就行了。如果你指的10W长连接,单机有点问题,资源和带宽可能都不够。 参考技术B 单机是做不到。这个是在集群的模式猜可以做到。
win系统本身还有内核的进程数的限制。

如果同时并发这么高。
你算一下 一天得多少访问。

c# 解决Socket问题——由于目标机器积极拒绝,无法连接

关于单机出现这种问题不多赘述,主要阐述服务机和客户机出现这种问题的解决办法。

1.检查防火墙

这种问题出现的最多,特别是你的服务机还是买的各家的云产品,比如阿里云就是到防火墙中添加出入站规则,Azure则是有个对应的出入站配置。将你的TCP和UDP对应使用的端口打开。如果觉得麻烦可以将1—65535端口都打开这里特别说下Azure会定期检查你的服务机的不安全行为,可能回擅自将你打开所有端口的配置删除。具体操作不赘述,网上一大堆添加防火墙规则的教程。

2.检查服务机端口是否被占用。(意义不大)

第二种问题的几率很小,因为你的服务端程序起来的时候如果端口被占用或直接报错。所以如果起来,但是没报错,基本不会是端口占用问题,不过以防万一可以打开cmd,使用"netstat -an"命令查看活动的端口号,看看自己的服务器端口是否正在被监听。

3.套接字绑定ip问题

目前网上大多数demo的写法都是绑定的"127.0.0.1"这是非常不正规的写法,因为是大多都是单机demo,不会出现问题,但是一旦分开就暴露出来了,所以正规的写法应该"你的Socket套接字对象.Bind(new IPEndPoint(IPAddress.Any, port));"

将127.0.0.1改成IPAddress.Any则问题解决。

以上是关于c# socket多连接(如何达到10万个客户端)的主要内容,如果未能解决你的问题,请参考以下文章

C# 1000个socket客户端并发

C# Winform 多线程 SOCKET 文件上传,下载

C#如何指定网络(网卡)利用socket通信呢?

Java千百问_02基本使用(012)_如何编写多线程Socket程序

C# socket超时释放端口

如何在 C# 中解决跨域策略安全异常