`
guaishou
  • 浏览: 168970 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

【五一呈献】通用高性能 Windows Socket 组件 HP-Socket v2.1.1 正式发布

    博客分类:
  • C++
阅读更多

  HP-Socket 是一套通用的高性能 Windows Socket 组件包,包含服务端组件(IOCP 模型)和客户端组件(Event Select 模型),广泛适用于 Windows 平台的 TCP 通信系统。HP-Socket 对通信层实现完全封装,上层应用不必关注通信层的任何细节;HP-Socket 提供基于事件通知模型的 API 接口,能非常简单高效地整合到各类应用程序中;另外,为了让大家能更方便的学习 HP-Socket,特此精心制作了一个功能测试示例(Test Echo)和一个性能测试示例(Test Echo-PFM),用户可以通过这两个测试示例入手,迅速掌握组件的设计思想和使用方法。

----------------------------------------------------------------

 

通用性

  • 通信组件的唯一职责就是接受和发送字节流,绝对不能参与上层协议解析等工作;
  • 与上层使用者解耦、互不依赖,组件与使用者通过操作接口和监听器接口进行交互,组件实现操作接口为上层提供操作方法;使用者实现监听器接口把自己注册为组件的 Listener,接收组件通知。因此,任何使用者只要实现了监听器接口都可以使用组件;另一方面,甚至可以自己重新写一个实现方式完全不同的组件实现给使用者调用,只要该组件遵从组件的操作接口,这也是 DIP 设计原则的体现。

可用性

  可用性对所有通用组件都是至关重要的,如果太难用还不如自己重头写一个来得方便。因此,组件的操作接口和监听器接口设计得尽量简单易用(通俗来说就是“傻瓜化”),这两个接口的主要方法均不超过 5 个。另外,组件完全封装了所有的底层 Socket 通信,上层应用看不到任何通信细节,不必也不能干预任何通信操作,Socket 连接被抽象为 Connection ID,该参数作为连接标识提供给上层应用识别不同的连接。

 

高性能

  作为底层的通用组件,性能问题是必须考虑的,绝对不能成为系统的瓶颈。而另一方面,从实际出发,根据客户端组件与服务端组件的性能要求采用不同的 Socket 模型。组件在设计上充分考虑了性能、现实使用情景、可用性和实现复杂性等因素,确保满足性能要求的同时又不会写得太复杂。做出以下两点设计决策:

  • 客户端:在单独线程中实现 Socket 通信交互。这样可以避免与主线程或其他线程相互干扰;I/O 模型选择 Event Select 通信模型。
  • 服务端:采用 Windows 平台效率最高的 IOCP 通信模型;利用缓存池技术,在通信的过程中,通常需要频繁的申请和释放内存缓冲区,建立了动态缓存池, 只有当缓存池中没有可用对象时才创建新对象,而当缓存对象过多时则会压缩缓存池;另外,组件的动态内存通过私有堆(Private Heap)机制分配,避免与 new / malloc 竞争同时又减少内存空洞。

伸缩性

  可以根据实际的使用环境要求设置组件的各项性能参数(如:工作线程的数量、各种缓存池的大小、收发缓冲区的大小、Socket 监听队列的大小、Accep 派发的数目以及心跳检查的间隔等)。

  (轻踩这里访问 HP-Socket 项目主页 ^_*)


*** v2.1.1 更新 ***
> Server:
-----------------

  1. IServerSocketListener 取消 OnPrepareSocket(connID, socket) 通知方法
  2. IServerSocketListener 修改 OnAccept((connID, soClient) 通知方法,增加参数‘soClient’,用于实现原 OnPrepareSocket(connID, socket) 通知方法的功能
  3. IServerSocketListener 增加 OnPrepareListen(soListen) 通知方法,用于设置监听 socket 的 SOCKET 选项
  4. ISocketServer 增加方法 GetListenAddress(strAddress, usPort),用于获取监听 Socket 的地址信息
  5. ISocketServer 增加方法 GetClientAddress(connID, strAddress, usPort),用于某个客户端连接的地址信息
  6. 优化 Socket 缓存池和内存块缓存池管理
  7. 调整一些属性访问方法的方法名
  8. 修复BUG:特殊情形下可能出现死锁现象

> Client:
-----------------

  1. ISocketServer 增加方法 GetLocalAddress(strAddress, usPort),用于获取 Client Socket 的地址信息
  2. 优化数据发送方式,提升数据发送效率

> 其他更新:
-----------------

  1. 优化 TestEcho 和 TestEcho-PFM 测试程序
  2. 在 SocketHelper.h (.cpp) 中添加若干帮助函数
  3. 为 SocketHelper.h 中定义的所有接口、类和方法加入注释

*** v2.0.1 更新 ***

> Server:
-----------------

  1. IServerSocketListener 增加 OnPrepareSocket(connID, socket) 通知方法用于在使用 socket 前设置 SOCKET 选项或过滤客户端连接
  2. ISocketServer 增加方法 Disconnect(connID) 用于主动断开客户端连接 
  3. 增加 IServerSocketListener 的子类 CServerSocketListener,提供默认(空的)通知处理方法

> Client:

-----------------

  1. IClientSocketListener 增加 OnPrepareSocket(connID, socket) 通知方法用于在使用 socket 前设置 SOCKET 选项
  2. 支持异步 Connect:ISocketServer 的 Start() 方法增加一个参数 (BOOL bAsyncConnect) 设置是否采用异步 Connect
  3. 增加 IClientSocketListener 的子类 CClientSocketListener,提供默认(空的)通知处理方法。
  4. 修复BUG:超高负载情形下出现丢包现象

> 其他更新:
-----------------

  1. 支持 Windows x64 平台
  2. 优化 TestEcho 和 TestEcho-PFM 测试程序
  3. TestEcho 客户端程序加入“异步连接”示例
  4. TestEcho 服务端程序加入“连接过滤”和“主动断开连接”示例

CodeProject

分享到:
评论

相关推荐

    开发工具 commons-dbcp2-2.1.1

    开发工具 commons-dbcp2-2.1.1开发工具 commons-dbcp2-2.1.1开发工具 commons-dbcp2-2.1.1开发工具 commons-dbcp2-2.1.1开发工具 commons-dbcp2-2.1.1开发工具 commons-dbcp2-2.1.1开发工具 commons-dbcp2-2.1.1开发...

    jeecg-framework_v2.1.1-20130130.zip

    jeecg-framework_v2.1.1-20130130.zipjeecg-framework_v2.1.1-20130130.zipjeecg-framework_v2.1.1-20130130.zipjeecg-framework_v2.1.1-20130130.zipjeecg-framework_v2.1.1-20130130.zipjeecg-framework_v2.1.1-...

    Unlock-All-v2.1.1

    Unlock-All-v2.1.1 10/10/17 2.1.0 - New version to support ESXi 6.5, Workstation/Player 14 and Fusion 10 - Removed support for ESXi 6.0 - Added ESXi boot option to disable unlocker (nounlocker)

    commons-configuration2-2.1.1-API文档-中文版.zip

    赠送jar包:commons-configuration2-2.1.1.jar; 赠送原API文档:commons-configuration2-2.1.1-javadoc.jar; 赠送源代码:commons-configuration2-2.1.1-sources.jar; 赠送Maven依赖信息文件:commons-...

    apache-hive-2.1.1-bin.tar

    apache-hive-2.1.1-bin.tar apache-hive-2.1.1-bin.tar apache-hive-2.1.1-bin.tarapache-hive-2.1.1-bin.tar apache-hive-2.1.1-bin.tar apache-hive-2.1.1-bin.tarapache-hive-2.1.1-bin.tar apache-hive-2.1.1-...

    qt-vs-tools-msvc2013-2.1.1

    qt-vs-tools-msvc2013-2.1.1 安装以后就可以在Visual Studio中找到QT VS TOOLS了。 软件的具体功能问百度吧。

    QtScrcpy-win-x64-v2.1.1.zip

    在使用QtScrcpy-win-x64-v2.1.1之前,确保你的电脑系统是64位的Windows,并且已经安装了合适的Android SDK,其中包括了ADB组件。解压下载的zip文件后,按照安装指南进行操作,即可开始享受便捷的跨平台投屏体验。 ...

    phantomjs-2.1.1-windows

    phantomjs-2.1.1-windowsphantomjs-2.1.1-windowsphantomjs-2.1.1-windowsphantomjs-2.1.1-windowsphantomjs-2.1.1-windowsphantomjs-2.1.1-windowsphantomjs-2.1.1-windowsphantomjs-2.1.1-windowsphantomjs-2.1.1-...

    scrcpy-win64-v2.1.1最新版安卓手机投屏电脑便捷工具

    此版本的Scrcpy(v2.1.1)可能包含了性能优化和新功能,比如改进的延迟性能、更高的帧率、更低的资源占用等。这些更新旨在提供更加稳定和高效的使用体验。 值得注意的是,Scrcpy还支持反向控制,即在电脑上通过键盘...

    docker harbor-offline-installer-v2.1.1.tgz

    harbor-offline-installer-v2.1.1.tgz

    photoshop导入exr使用ACES工作流插件OpenColorIO-PS-v2.1.1-win.zip

    在这个场景中,"OpenColorIO-PS-v2.1.1-win.zip" 是一个为Photoshop定制的插件,用于支持ACES(Academy Color Encoding System)工作流。ACES是电影和电视行业的标准色彩管理系统,它确保了在制作流程中从拍摄到后期...

    mybatis-spring-boot-autoconfigure-2.1.1-API文档-中文版.zip

    赠送jar包:mybatis-spring-boot-autoconfigure-2.1.1.jar; 赠送原API文档:mybatis-spring-boot-autoconfigure-2.1.1-javadoc.jar; 赠送源代码:mybatis-spring-boot-autoconfigure-2.1.1-sources.jar; 赠送...

    qt-vs-tools-msvc2015-2.1.1

    下载解压就可以用

    cling-support-2.1.1.jar和cling-core-2.1.1.jar

    标题中的"cling-support-2.1.1.jar和cling-core-2.1.1.jar"是两个关键的Java档案文件,它们属于一个用于电视投屏功能的软件开发库。在这个场景下,"cling"是一个开源的Java库,专门设计来处理DLNA(Digital Living ...

    GP-卡规范V2.1.1完整版(中文带APDU指令)

    GP卡规范V2.1.1完整版(中文带APDU指令) GP卡规范V2.1.1是一份完整的开发规范说明书,旨在为开发者提供详细的指南,以便正确地开发和实施GP卡。该规范涵盖了GP卡的开发、测试、部署和维护等方面,提供了详细的技术...

    gp-premium-v2.1.1.zip

    GeneratePress Premium v2.1.1 是一个针对WordPress平台的高级主题插件,它扩展了基本的GeneratePress主题的功能和特性。GeneratePress是一款轻量级、高性能的主题,旨在提供卓越的用户体验和SEO优化,而...

    weibo4j-oauth2-2.1.1-beta3.1.1.jar(已使用IDEA构建成jar和jar源码)

    《微博API接入实战:解析weibo4j-oauth2-2.1.1-beta3.1.1.jar》 在当今社交媒体盛行的时代,微博作为中国最大的社交网络平台之一,其API接口的使用对于开发者来说至关重要。`weibo4j-oauth2-2.1.1-beta3.1.1.jar`是...

    mapbox-unity-sdk_v2.1.1.unitypackage

    mapbox的unity开发包。国内基于地理定位的增强现实开发的时候,其实很麻烦。Google地图的服务器在国外无法访问,百度和高德均未提供Unity的SDK,腾讯地图声称提供了Unity的SDK,但是是针对企业的,普通开发者连长啥...

    mapbox-unity-sdk_v2.1.1

    官网下载特别慢,下载下来放在百度网盘上 方便下载 适用于Unity平台的地图软件开发包(Maps SDK for Unity),是一个基于现实地图数据创建Unity应用的工具集。它让开发者可以与Mapbox提供的web服务接口(包括地图、...

    hive-jdbc-2.1.1-cdh6.2.0-standalone.jar

    hive-jdbc-2.1.1-cdh6.2.0(ieda等jdbc链接hive2.1.1);cdh6.2.0安装的hive2.1.1

Global site tag (gtag.js) - Google Analytics