`
snowhui
  • 浏览: 8352 次
  • 性别: Icon_minigender_1
  • 来自: 河北
社区版块
存档分类
最新评论

C# 实现的多线程异步Socket数据包接收器

阅读更多
几天前在博问中看到一个C# Socket问题,就想到笔者2004年做的一个省级交通流量接收服务器项目,当时的基本求如下:

  接收自动观测设备通过无线网卡、Internet和Socket上报的交通量数据包 全年365*24运行的自动观测设备5分钟上报一次观测数据,每笔记录约2K大小 规划全省将有100个左右的自动观测设备(截止2008年10月还只有30个)

   当时,VS2003才发布年多,笔者也是接触C#不久。于是Google了国内国外网,希望找点应用C#解决Socket通信问题的思路和代码。最后,找到了两篇帮助最大的文章:一篇是国人写的Socket接收器框架,应用了独立的客户端Socket会话(Session)概念,给笔者提供了一个接收服务器的总体框架思路;另一篇是美国人写的,提出了多线程、分段接收数据包的技术方案,描述了多线程、异步Socket的许多实现细节,该文坚定了笔者采用多线程和异步方式处理Socket接收器的技术路线。

   具体实现和测试时笔者还发现,在Internet环境下的Socket应用中,需要系统有极强的容错能力:没有办法控制异常,就必须允许它们存在(附加源代码中可以看到,try{}catch{}语句较多)。对此,笔者设计了一个专门的检查和清理线程,完成无效或超时会话的清除和资源释放工作。

   依稀记得,国内框架作者的名称空间有ibm,认为是IBM公司职员,通过邮件后才知道其人在深圳。笔者向他请教了几个问题,相互探讨了几个技术关键点。可惜,现在再去找,已经查不到原文和邮件了。只好借此机会,将本文献给这两个素未谋面的技术高人和同行,也盼望拙文或源码能给读者一点有用的启发和帮助。

  1、主要技术思路

   整个系统由三个核心线程组成,并由.NET线程池统一管理:

  侦听客户端连接请求线程:ListenClientRequest(),循环侦听客户端连接请求。如果有,检测该客户端IP,看是否是同一观测设备,然后建立一个客户端TSession对象,并通过Socket异步调用方法BeginReceive()接收数据包、EndReceive()处理数据包 数据包处理线程:HandleDatagrams(),循环检测数据包队列_datagramQueue,完成数据包解析、判断类型、存储等工作 客户端状态检测线程:CheckClientState(),循环检查客户端会话表_sessionTable,判断会话对象是否有效,设置超时会话关闭标志,清楚无效会话对象及释放其资源 2、主要类简介

   系统主要由3个类组成:

  TDatagramReceiver(数据包接收服务器):系统的核心进程类,建立Socket连接、处理与存储数据包、清理系统资源,该类提供全部的public属性和方法 TSession(客户端会话):由每个客户端的Socket对象组成,有自己的数据缓冲区,清理线程根据该对象的最近会话时间判断是否超时 TDatagram(数据包类):判

  断数据包类别、解析数据包


  3、关键函数和代码

   下面简介核心类TDatagramReceiver的关键实现代码。

  3.1  系统启动

   系统启动方法StartReceiver()首先清理资源、创建数据库连接、初始化若干计数值,然后创建服务器端侦听Socket对象,最后调用静态方法ThreadPool.QueueUserWorkItem()在线程池中创建3个核心处理线程。

Code
///
///  启动接收器
///
public bool StartReceiver()
{
    try
    {
        _stopReceiver = true;

        this.Close();

        if (!this.ConnectDatabase()) return false;

        _clientCount = 0;
        _datagramQueueCount = 0;
        _datagramCount = 0;
        _errorDatagramCount = 0;
        _exceptionCount = 0;

        _sessionTable = new Hashtable(_maxAllowClientCount);
        _datagramQueue = new Queue<TDatagram>(_maxAllowDat
分享到:
评论

相关推荐

    C#实现的多线程异步Socket数据包接收器框架[整理].pdf

    【C#实现的多线程异步Socket数据包接收器框架】 C#中的多线程异步Socket数据包接收器框架是一种高效且可靠的方法,用于处理来自多个客户端的数据传输。在给定的描述中,我们可以看到这个框架是为了解决交通流量数据...

    C__实现的多线程异步Socket数据包接收器框架

    在C#中实现多线程异步Socket数据包接收器框架是构建高性能网络通信系统的关键。这个框架的设计目的是为了能够高效地处理多个并发的Socket连接,同时具备强大的错误处理和资源管理能力。以下是对该框架的主要技术和...

    C#中使用异步Socket实现点对点通信

    总结,C#中使用异步Socket实现点对点通信涉及多线程、非阻塞I/O、并发处理和网络协议等复杂概念。理解并熟练掌握这些知识点,对于构建高效、可靠的P2P应用程序至关重要。通过分析提供的源代码和资源,可以更深入地...

    c# UDP 局域网异步通讯实现广播,接收发送string数据

    这个例子展示了如何创建一个持续监听的接收器,每当接收到数据时,它会调用`ReceiveCallback`并打印出接收到的字符串。 总结一下,实现C# UDP局域网异步通信的关键步骤包括: 1. 创建`UdpClient`实例。 2. 配置广播...

    C#多线程扫描器

    "C#多线程扫描器"是一个利用C#语言特性实现的高效扫描工具,可能用于端口扫描或网络监控等场景。下面我们将详细讨论多线程的概念、C#中的多线程实现以及端口扫描的相关知识。 1. **多线程基础**: - **线程**:...

    SuperSocket Socket C# 通讯详细介绍

    它可以是基于TCP或UDP的,并且支持多线程、异步操作。 2. **Session**: 代表一个客户端的连接,每个客户端连接都会创建一个对应的Session对象。Session提供了数据收发、状态管理和生命周期管理的功能。 3. **...

    基于C#和Socket的实时语音通话系统

    总结来说,"基于C#和Socket的实时语音通话系统"是一个涉及网络编程、音频处理、多线程技术以及用户交互等多个领域的复杂项目,需要开发者具备扎实的编程基础和深入的系统理解能力。这个系统不仅可以直接使用,也具有...

    C#SuperSocket服务端与客户端通信实例

    - **多线程/异步处理**: 对于高并发场景,服务端可能需要使用多线程或异步操作来处理多个客户端请求,避免阻塞。 在提供的压缩包文件"SuperSocket"中,你应该能找到更详细的示例代码和文档,帮助你进一步理解和实践...

    C# socket通讯服务端

    多线程或异步编程模型可以用来实现并发。 - **错误处理和异常捕获**:在网络通信中,网络中断、数据包丢失等情况是常态。良好的错误处理机制能够保证服务的稳定性和可靠性。 - **安全策略**:考虑到网络安全,...

    C#实现网段扫描,C#是主推语言,你们是否有兴趣用C#来实现对局域网IP地址的扫描,尝试一下自己写的快乐,那么请跟我来。

    为了提高扫描速度,可以使用多线程或多任务技术,如`Task`类,同时处理多个IP地址。此外,还可以使用异步编程,如`async/await`关键字,以减少阻塞。 通过以上步骤,你可以构建一个基本的C#网段扫描程序。当然,...

    C#实现网络发送接收统计程序源码.rar

    5. **多线程与异步编程**:为了确保程序的响应性和避免阻塞主线程,网络发送接收通常会在后台线程或使用异步操作来完成。C#的Task类和async/await关键字是实现异步编程的主要工具,它们可以使得程序在等待网络操作...

    C#多客户机同步

    开发者需要掌握TCP/IP协议原理,熟悉C#的异步编程、多线程、锁等机制,以及数据序列化和错误处理等技能,才能有效实现高效、可靠的多客户机同步应用。在实际开发过程中,还需要根据具体需求选择合适的设计模式和架构...

    C#写的魔兽世界登录器

    总结,C#开发魔兽世界登录器是一个综合性的项目,涉及网络通信、数据加密、UI设计、多线程、异常处理等多个方面,需要扎实的编程基础和良好的问题解决能力。通过这个项目,开发者不仅可以提升C#编程技能,还能深入...

    C#扫描器源码

    【C#扫描器源码】是一个使用Visual Studio开发的端口扫描工具,它展示了如何利用C#编程语言来实现网络端口的扫描功能。端口扫描是网络安全领域中常见的技术,用于检测网络上的设备开放了哪些端口,以便了解网络服务...

    ARTNET c# 开源代码

    6. **多线程与并发**:在处理多个网络连接或同时控制多个灯光设备时,多线程和并发编程是必不可少的。 7. **硬件接口**:了解如何将接收到的DMX数据转换为对实际硬件设备的操作,可能涉及到串口通信、USB设备驱动或...

    C#超级通信调试工具源码

    6. **多线程与并发**:为了处理多个并发连接,开发者通常会使用多线程或多任务。C#的Thread和Task类以及并发控制结构(如Mutex、Semaphore等)可以帮助开发者有效地管理并发执行。 7. **异步编程**:在处理网络请求...

    C# IP地址段端口扫描器

    综上所述,开发一个C# IP地址段端口扫描器需要掌握网络编程基础、Socket操作、异步编程、多线程管理、异常处理和性能优化等多个方面的知识。通过不断实践和学习,我们可以创建出功能强大、效率高的端口扫描工具。

    QQ 源代码 c#版

    2. **多线程**:为了实现并发处理,如同时接收消息和发送消息,QQ程序通常会使用多线程。C#中的Thread类和Task类提供了异步执行任务的能力,可以避免阻塞主线程,提高用户体验。 3. **UI设计**:QQ的用户界面(UI)...

    SOCKET封装类

    CServer可能会提供简便的方法来处理并发连接,如多线程或异步I/O,以提高服务器性能。 3. **CClient类**:CClient类负责客户端的套接字操作,如创建套接字、连接到服务器、发送和接收数据。客户端通常会有一个明确...

    C# 测试网络速度 源码

    这可以通过多线程或异步编程实现,如Task类或async/await关键字。 6. **数据大小的处理**:在实际测试中,我们需要处理各种数据块大小,以观察不同条件下网络速度的变化。可以设置不同的数据包大小,然后计算相同...

Global site tag (gtag.js) - Google Analytics