C#高性能大容量SOCKET并发(六):超时Socket断开(守护线程)和心跳包

本文主要是介绍C#高性能大容量SOCKET并发(六):超时Socket断开(守护线程)和心跳包,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://blog.csdn.net/SQLDebug_Fan/article/details/20465195


守护线程

在服务端版Socket编程需要处理长时间没有发送数据的Socket,需要在超时多长时间后断开连接,我们需要独立一个线程(DaemonThread)来轮询,在执行断开时,需要把Socket对象锁定,并调用CloseClientSocket来断开连接,具体处理代码如下:

[csharp]  view plain  copy
  1. namespace SocketAsyncSvr  
  2. {  
  3.     class DaemonThread : Object  
  4.     {  
  5.         private Thread m_thread;  
  6.         private AsyncSocketServer m_asyncSocketServer;  
  7.   
  8.         public DaemonThread(AsyncSocketServer asyncSocketServer)  
  9.         {  
  10.             m_asyncSocketServer = asyncSocketServer;  
  11.             m_thread = new Thread(DaemonThreadStart);  
  12.             m_thread.Start();  
  13.         }  
  14.   
  15.         public void DaemonThreadStart()  
  16.         {  
  17.             while (m_thread.IsAlive)  
  18.             {  
  19.                 AsyncSocketUserToken[] userTokenArray = null;  
  20.                 m_asyncSocketServer.AsyncSocketUserTokenList.CopyList(ref userTokenArray);  
  21.                 for (int i = 0; i < userTokenArray.Length; i++)  
  22.                 {  
  23.                     if (!m_thread.IsAlive)  
  24.                         break;  
  25.                     try  
  26.                     {  
  27.                         if ((DateTime.Now - userTokenArray[i].ActiveDateTime).Milliseconds > m_asyncSocketServer.SocketTimeOutMS) //超时Socket断开  
  28.                         {  
  29.                             lock (userTokenArray[i])  
  30.                             {  
  31.                                 m_asyncSocketServer.CloseClientSocket(userTokenArray[i]);  
  32.                             }  
  33.                         }  
  34.                     }                      
  35.                     catch (Exception E)  
  36.                     {  
  37.                         Program.Logger.ErrorFormat("Daemon thread check timeout socket error, message: {0}", E.Message);  
  38.                         Program.Logger.Error(E.StackTrace);  
  39.                     }  
  40.                 }  
  41.   
  42.                 for (int i = 0; i < 60 * 1000 / 10; i++) //每分钟检测一次  
  43.                 {  
  44.                     if (!m_thread.IsAlive)  
  45.                         break;  
  46.                     Thread.Sleep(10);  
  47.                 }  
  48.             }  
  49.         }  
  50.   
  51.         public void Close()  
  52.         {  
  53.             m_thread.Abort();  
  54.             m_thread.Join();  
  55.         }  
  56.     }  
  57. }  

心跳包

有超时连接,相对应的需要设计心跳包,心跳包用来检测连接和维护连接状态,心跳包的原理是客户端发送一个包给服务器,服务器收到后发一个响应包给客户端,通过检测是否有返回来判断连接是否正常,心跳包实现放在BaseSocketProtocol.DoActive方法中。

[csharp]  view plain  copy
  1. public bool DoActive()  
  2. {  
  3.     m_outgoingDataAssembler.AddSuccess();  
  4.     return DoSendResult();  
  5. }  

具体由各个协议是否决定调用,如控制协议ControlSocketProtocol实现心跳协议如下:

[csharp]  view plain  copy
  1. public override bool ProcessCommand(byte[] buffer, int offset, int count) //处理分完包的数据,子类从这个方法继承  
  2. {  
  3.     ControlSocketCommand command = StrToCommand(m_incomingDataParser.Command);  
  4.     m_outgoingDataAssembler.Clear();  
  5.     m_outgoingDataAssembler.AddResponse();  
  6.     m_outgoingDataAssembler.AddCommand(m_incomingDataParser.Command);  
  7.     if (!CheckLogined(command)) //检测登录  
  8.     {  
  9.         m_outgoingDataAssembler.AddFailure(ProtocolCode.UserHasLogined, "");  
  10.         return DoSendResult();  
  11.     }  
  12.     if (command == ControlSocketCommand.Login)  
  13.         return DoLogin();  
  14.     else if (command == ControlSocketCommand.Active)  
  15.         return DoActive();  
  16.     else if (command == ControlSocketCommand.GetClients)  
  17.         return DoGetClients();  
  18.     else  
  19.     {  
  20.         Program.Logger.Error("Unknow command: " + m_incomingDataParser.Command);  
  21.         return false;  
  22.     }  
  23. }  
DEMO下载地址: http://download.csdn.net/detail/sqldebug_fan/7467745
免责声明:此代码只是为了演示C#完成端口编程,仅用于学习和研究,切勿用于商业用途。水平有限,C#也属于初学,错误在所难免,欢迎指正和指导。邮箱地址:fansheng_hx@163.com。

这篇关于C#高性能大容量SOCKET并发(六):超时Socket断开(守护线程)和心跳包的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/319930

相关文章

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

Java中如何正确的停掉线程

《Java中如何正确的停掉线程》Java通过interrupt()通知线程停止而非强制,确保线程自主处理中断,避免数据损坏,线程池的shutdown()等待任务完成,shutdownNow()强制中断... 目录为什么不强制停止为什么 Java 不提供强制停止线程的能力呢?如何用interrupt停止线程s

C#文件复制异常:"未能找到文件"的解决方案与预防措施

《C#文件复制异常:未能找到文件的解决方案与预防措施》在C#开发中,文件操作是基础中的基础,但有时最基础的File.Copy()方法也会抛出令人困惑的异常,当targetFilePath设置为D:2... 目录一个看似简单的文件操作问题问题重现与错误分析错误代码示例错误信息根本原因分析全面解决方案1. 确保

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

C#高效实现Word文档内容查找与替换的6种方法

《C#高效实现Word文档内容查找与替换的6种方法》在日常文档处理工作中,尤其是面对大型Word文档时,手动查找、替换文本往往既耗时又容易出错,本文整理了C#查找与替换Word内容的6种方法,大家可以... 目录环境准备方法一:查找文本并替换为新文本方法二:使用正则表达式查找并替换文本方法三:将文本替换为图

Spring Security 前后端分离场景下的会话并发管理

《SpringSecurity前后端分离场景下的会话并发管理》本文介绍了在前后端分离架构下实现SpringSecurity会话并发管理的问题,传统Web开发中只需简单配置sessionManage... 目录背景分析传统 web 开发中的 sessionManagement 入口ConcurrentSess