ESFramework ——成熟的C#网络通信框架(跨平台)

ESFramework网络通信框架是一套性能卓越、稳定可靠、强大易用的跨平台通信框架。也是.net平台首屈一指的成熟的C#网络通信框架。从最初的单纯的C#网络通信框架,历经10年,已经发展为支持包括安卓、IOS、Xamarin等多个平台的跨平台通信框架。其支持应用服务器集群。其内置了消息的收发与自定义处理(支持同步/异步模型)、消息广播、P2P通道、文件传送(支持断点续传)、心跳检测、断线重连、登录验证、在线用户管理、好友与群组管理、性能诊断等功能。基于ESFramework,您可以方便快捷地开发出诸如即时通讯系统(IM)、网络教学系统、视频会议系统等各种优秀的网络通信应用。此外,我们在长期实践中所积累的丰富经验,更将成为您强大的技术保障,从开发到上线直至后续运维,全程为您保驾护航,让您高枕无忧。具体而言,ESFramework 具有如下特性:(可跳过概要介绍,直接进入开发手册目录 或 Demo下载

1.高性能C#网络通信框架

ESFramework底层使用IOCP模型,采用C#语言编写而成,数据收发与处理达到最高性能。当前主流配置的服务器(如至强4核双CPU、4-8G内存)可轻松处理10000个同时在线连接,每秒处理50000个以上的请求。当然,最终能达到的并发,更取决于具体应用的业务逻辑,如果业务逻辑复杂、处理单个请求都对CPU和内存的消耗都比较高,那么就会导致并发数下降,这时也许就要优化我们的业务逻辑代码了、或者使用更多的服务器来分担负载(比如迁移到ESPlatform)。关于ESFramework的性能测试的更多内容可以参见ESFramework 4.0 性能测试

2.可靠、稳定

ESFramework通信框架起始于2004年,从0.1版本不断完善和优化到今天4.0版本已经有8年时间,其内核(ESFramework.dll)已经相当成熟稳定,所有已经发现的内核bug都已被解决,而且自2009年以来,没有新的内核的bug被发现。从最初的单纯的C#网络通信框架,历经10年,已经发展为支持包括安卓、IOS、Xamarin等多个平台的跨平台通信框架。另外,ESFramework只会在需要时才使用必要的资源(如CPU、内存),并且会及时释放持有的资源,不会有内存泄露等情况发生。如果您的业务逻辑代码没有bug,那么基于ESFramework的服务端正常运行一年,都不用重启一次。

3.功能强大丰富

现有的大多数通信框架仅仅解决了通信层的问题,而且几乎都是部分地解决。而ESFramework不仅仅完整地解决了通信层的需求,并且也解决了绝大多数通信系统中都关注的应用层的重要问题,这使得基于ESFramework开发分布式通信系统更迅速、更高效。

在通信层:ESFramework 支持TCP/UDP、文本协议/二进制协议、服务端/客户端以及它们组合的任意方式,并提供多种通信引擎供服务端开发人员和客户端开发人员使用。

在应用层:ESFramework 内置了在线用户管理、消息拦截、消息同步调用、回复异步调用、通道智能选择、客户端登录验证、心跳检测、消息优先级、断线自动重连、在线状态改变自动通知(好友与组友)、重登陆模式选择、完整的异常日志、文件传送(支持断点续传)、组广播、带ACK机制的信息发送、高效的二进制序列化器、等等功能。

在安全性:ESFramework 内置了常见的重要安全机制以防止恶意用户在应用层对服务端进行试探或攻击。这些机制有:消息格式完整验证、消息加密、验证未绑定的消息、绑定连接、关闭空连接等。

4.可靠的P2P通信

ESFramework提供了基于TCP和UDP的P2P通信(不仅是局域网,还支持广域网P2P通信),而且基于UDP的P2P做了增强,以保证基于UDP的P2P通信也像TCP一样可靠。在客户端之间需要高频通信的分布式系统中(如IM系统等),可靠的P2P通信将为您节省巨大的带宽和服务器成本。

5.高伸缩性的群集平台

ESPlatform平台支持基于ESFramework的应用程序的Cluster(群集),其内置了3种最常用的负载均衡策略。仅仅通过修改几行代码就可以将一个基于ESFramework的应用程序平滑迁入到ESPlatform平台中,以实现多台应用服务器的Cluster,从而应对日益增长的巨大并发。使用ESPlatform群集,我们可以非常方便地在运行时动态添加/移除应用服务器(AS)实例节点。

6.跨平台网络通信框架

跨平台是ESFramework网络通信框架的重要目标之一,ESFramework通过提供多平台的客户端引擎来实现这一点。其服务端由C#语言开发而成。基于ESFramework开发的不同平台的客户端之间可以相互通信,如此,异构环境将变得透明化。ESFramework已支持的平台如下图所示:

    

 

7.服务端性能诊断

ESFramework网络通信框架在服务端内置了性能跟踪诊断功能。如果基于ESFramework构建的服务端在运行时,遇到性能问题或某些故障,那么可以开启诊断功能,ESFramework将自动跟踪每种类型消息的处理情况,之后通过分析日志,就可以很快发现问题所在。

8.适用范围广

ESFramework 可以用于任何需要分布式通信的软件系统中,而且其群集功能还可以支持那些同时在线用户数巨大的系统。比如,即时通讯系统(IM),大型多人在线游戏(MMORPG)、在线网页游戏(WebGame)、文件传送系统(FTS)、数据采集系统(DGS)、分布式OA系统等等。

9.文档齐全、接口清晰规范

ESFramework提供的所有接口和API都具有良好的C#编码风格,与.NET Framework完全一致。我们提供了MSDN风格的帮助文档、Demo源码、ESFramework开发手册系列文章供您研究和学习使用ESFramework进行开发。

10.历史经验分享

我们在过去的10多年里,ESFramework从最初的单纯的C#网络通信框架,已经发展为支持包括安卓、IOS、Xamarin等多个平台的跨平台网络通信框架,早已是.net平台首屈一指的成熟的网络通信框架。我们团队在十多年间基于ESFramework开发了很多网络通信系统,也为诸多客户提供技术支持和运行故障排查服务,所以,在以下方面积累了丰富的经验:如基于ESFramework的最佳开发实践、服务端性能瓶颈排查、服务端运行故障排查、性能优化等等。如果您是第一次基于ESFramework进行二次开发,那么,我们分享的这些经验将为您的项目上线运行提供更强大的后续保障。 

 

补充说明:关于ESFramework网络通信框架更详细的介绍,请参见详细说明或转到 Demo下载 

如果对您的项目来说,ESFramework太重量级,敬请了解轻量级通信引擎StriveEngine

如果您需要开发网络语音视频通信相关的应用,敬请了解我的另一作品OMCS网络语音视频框架

 

 版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-10-14 15:22:35

ESFramework ——成熟的C#网络通信框架(跨平台)的相关文章

ESFramework网络通信框架介绍之(2)――网络通信消息NetMessage

ESFramework网络通信框架与元数据 较之C++而言,.NET是一个更加"动态"的平台,其动态能力建立在反射机制之上,而反射的基础是"元数据".     上文已经提到过,如果一个框架要为我们的应用做更多的事情,那么这个框架必须建立更多的标准,必须对框架自己要处理的消息有更多的了解,所以,每个消息都要是自描述的,也就是说每个消息要包含它自己的"元数据".那么,"元数据"位于消息的何处了?你一定想到了,对,是消息头(Mess

ESFramework网络通信框架介绍之(1)――网络通信消息协议接口IContract

一.ESFramework网络通信框架与字节流        通过网络通信的系统之间(如客户端与服务端的通信)要想正常交互,它们必须有"共同的语言",这种语言就是消息协议.遵守消息协议的消息才能被我们的系统所理解.    我们知道,消息在网路上传输的是字节流,而我们主流的面向对象系统中处理的却是"对象",如何将从网络上接收到的字节流转化为"对象",又如何将"对象"转化为字节流以便通过网络传递给其他系统,这便是IContract

ESFramework网络通信框架 4.0 性能测试

  本实验用于测试ESFramework网络通信框架服务端引擎的性能,测试程序使用ESFramework 4.0版本. 一.准备工作 测试的机器总共有3台,都是普通的PC,一台作为服务器,两台作为客户端. 作为服务器是PC配置如下: 操作系统:Windows Server 2003 Enterprise Edition SP2 CPU:Pentium Dual-Core CPU E5400 @ 2.70GHz 内存:2G   二.测试策略        本实验所采用的策略是这样的: (1)每个客

ESFramework网络通信框架介绍之(3)――消息处理器和处理器工厂

一.ESFramework网络通信框架与消息处理器   无论是服务端还是客户端,都需要对接收到的消息进行处理,在ESFramework网络通信框架中,处理消息的组件称为消息处理器,所有的消息处理器都实现了接口IDataDealer:    1     public interface IDataDealer2     {        3         NetMessage  DealRequestMessage(NetMessage reqMsg) ;        4     }    

ESFramework网络通信框架介绍之(5)――消息分派器IMessageDispatcher

  从2004年7月开始,就一直从事N层C/S架构的服务端的开发,时至今日,慢慢的积累了一些开发经验,ESFramework网络通信框架体系便是这些经验的总结.ESFramework网络通信框架这是一套完全可复用的.灵活的.单纯的.支持N层C/S架构的网络通信框架,内置了对Tcp和Udp协议的支持.ESFramework网络通信框架不仅仅提供了一个基础的C/S框架和大量C/S应用中常用的组件,而且在ESFramework网络通信框架框架之上,引入的一个扩展层--ESFramework网络通信框架

《Ceph源码分析》——第3章,第1节Ceph网络通信框架

第3章Ceph网络通信本章介绍Ceph网络通信模块,这是客户端和服务器通信的底层模块,用来在客户端和服务器之间接收和发送请求.其实现功能比较清晰,是一个相对较独立的模块,理解起来比较容易,所以首先介绍它. 3.1 Ceph网络通信框架一个分布式存储系统需要一个稳定的底层网络通信模块,用于各节点之间的互联互通.对于一个网络通信系统,要求如下:高性能.性能评价的两个指标:带宽和延迟.稳定可靠.数据不丢包,在网络中断时,实现重连等异常处理.网络通信模块的实现在源代码src/msg的目录下,其首先定义了

CYQ.Data 数据框架 跨平台应用开发

昨天发布的一篇:CYQ.Data 数据框架 性能评测 为大伙揭开了CYQ.Data 的性能体验,在写数据方面,表现的相当接近原始的ADO.NET操作.   那在数据读取方面呢? 有兴趣的朋友可自行测试一下.   本篇为你揭开的是:CYQ.Data 能否跨平台应用开发? 相信大伙都有点知道,.NET 跨平台,目前也只能折腾Mono了.   杂七几句: 早些时期[从我的文章时期看,去年4月份],领导找我谈过话. 问:.NET 能不能跨平台,如果能跨平台,公司就没必要养一个Java的团队. 因为公司的

android 网络通信框架volly

1. 什么是Volley 在这之前,我们在程序中需要和网络通信的时候,大体使用的东西莫过于AsyncTaskLoader,HttpURLConnection,AsyncTask,HTTPClient(Apache)等,今年的Google I/O 2013上,Volley发布了.Volley是Android平台上的网络通信库,能使网络通信更快,更简单,更健壮. 这是Volley名称的由来: a burst or emission of many things or a large amount a

Android 网络通信框架Volley简介(Google IO 2013)

Volley主页 https://android.googlesource.com/platform/frameworks/volley  http://www.youtube.com/watch?v=yhv8l9F44qo&feature=player_embedded 1. 什么是Volley 在这之前,我们在程序中需要和网络通信的时候,大体使用的东西莫过于AsyncTaskLoader,HttpURLConnection,AsyncTask,HTTPClient(Apache)等,今年的G