高性能 socket 组件 hp-买球官网平台

 

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

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

通用性

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

可用性

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

高性能

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

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

伸缩性

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

   (项目买球官网平台主页:,下载地址:)


*** v3.1.1 更新 ***

 > 增加导出纯 c 函数的动态链接库 hpsocket4c.dll:

-----------------
  1. 增加代码文件 hpsocket4c.h 和 hpsocket4c.cpp,用于创建 hpsocket4c.dll
  2. 导出纯 c 函数,让其它语言(如:c/c#/delphi 等)能方便地使用 hpsocket
  3. hpsocket4c.dll 使用方法
    方法一:
    ------------------------------------------------------------------------------
    (0) (c/c   程序)包含 hpsocket4c.h 头文件
    (1) 调用 ::create_hp_xxxlistener() 函数创建监听器对象
    (2) 调用 ::create_hp_xxx(plistener) 函数创建 hpsocket 对象
    (3) 调用 ::hp_set_fn_xxx_onyyy(plistener, ...) 函数设置监听器的回调函数
    (4) 调用相关导出函数操作 hpsocket 对象
    (5) ...... ......
    (6) 调用 ::destroy_hp_xxx(psocket) 函数销毁 hpsocket 对象
    (7) 调用 ::destroy_hp_xxxlistener(plistener) 函数销毁监听器对象
    方法二:
    ------------------------------------------------------------------------------
    (1) 应用程序把需要用到的导出函数封装到特定语言的包装类中
    (2) 通过包装类封装后,以面向对象的方式使用 hpsocket
  4. 动态链接库发行版本
    (1) x86/hpsocket4c.dll		- (32位/mbcs/release)
    (2) x86/hpsocket4c_d.dll	- (32位/mbcs/debug)
    (3) x86/hpsocket4c_u.dll	- (32位/unicode/release)
    (4) x86/hpsocket4c_ud.dll	- (32位/unicode/debug)
    (5) x64/hpsocket4c.dll		- (64位/mbcs/release)
    (6) x64/hpsocket4c_d.dll	- (64位/mbcs/debug)
    (7) x64/hpsocket4c_u.dll	- (64位/unicode/release)
    (8) x64/hpsocket4c_ud.dll	- (64位/unicode/debug)

> 全面启用 buffer pool 缓存机制:

-----------------
  1. common/src 增加代码文件 bufferpool.h 和 bufferpool.cpp,实现 buffer pool 缓存机制
  2. 通过 buffer pool 缓存机制提升内存使用效率,减少动态内存分配和释放操作,避免内存空洞
  3. ictcpclient 用 citempool 和 titemlist 实现发送缓冲区
  4. cudpclient 用 citempool 和 titemlist 实现发送缓冲区
  5. ctcppullclient 用 citempool 和 titemlist 实现发送缓冲区和 pull 缓冲区
  6. ctcppullserver 用 cbufferpool 和 tbuffer 实现 pull 缓冲区

> 其它更新:

-----------------
  1. hpsocket.dll 和 hpsocket4c.dll 使用 /mt(d) 选项重新编译,消除对运行时库的依赖
  2. iserver 增加接口方法 disconnectlongconnections() 用于断开所有超长连接
  3. iserver 删除接口方法 getconnectioncrisec()
  4. iclient 增加方法 get/setfreebufferpoolsize()、get/setfreebufferpoolhold() 用于设置 buffer pool 缓存大小和阀值
  5. ipullserver 删除方法 get/setfreepullbufferpool()、get/setfreepullbufferhold()
  6. 增加示例工程 testecho-4c,展示 hpsocket4c.dll 的使用方法

> 升级说明:

-----------------
  1. 使用 hp-socket v3.0.2 及以前版本的应用程序可以安全升级到 hp-socket v3.1.1
  2. 如果工程想通过导入 hpsocket4c.dll 的方式使用 hp-socket,请参考 testecho-4c 示例工程

*** v3.0.2 更新 ***

 > 把 hp-socket 编译为动态链接库:

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

  1. 应用程序可以通过导入源代码或动态链接库方式使用 hp-socket
  2. 动态链接库使用方法
    方法一:
    ------------------------------------------------------------------------------
    (0) 应用程序包含 socketinterface.h 和 hpsocket.h 头文件
    (1) 调用 hp_create_xxx() 函数创建 hpsocket 对象
    (2) 使用完毕后调用 hp_destroy_xxx() 函数销毁 hpsocket 对象
    方法二:
    ------------------------------------------------------------------------------
    (0) 应用程序包含 socketinterface.h 和 hpsocket.h 头文件
    (1) 创建 cxxxwrapper 包装器,通过包装器智能指针使用 hpsocket 对象
  3. 动态链接库发行版本
    (1) x86/hpsocket.dll      - (32位/mbcs/release)
    (2) x86/hpsocket_d.dll    - (32位/mbcs/debug)
    (3) x86/hpsocket_u.dll    - (32位/unicode/release)
    (4) x86/hpsocket_ud.dll   - (32位/unicode/debug)
    (5) x64/hpsocket.dll      - (64位/mbcs/release)
    (6) x64/hpsocket_d.dll    - (64位/mbcs/debug)
    (7) x64/hpsocket_u.dll    - (64位/unicode/release)
    (8) x64/hpsocket_ud.dll   - (64位/unicode/debug)

*** v3.0.1 更新 ***

 > 新增 udp 通信组件:

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

  1. 新增两个 udp 通信组件:cudpserver 为服务端组件,cudpclient 为客户端组件
  2. 服务端组件 cudpserver 采用 iocp 通信模型
  3. 客户端组件 cudpclient 采用 event select 通信模型
  4. udp 通信组件的接口与原 tcp 通信组件一致,简单实用
  5. udp 通信组件内置通信线路自动监测机制
  6. 新增 udp 通信组件示例工程 testecho-udp

> 代码重构与优化:

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

  1. 规范所有接口、类以及代码文件的命名
  2. 重构和优化了大量组件代码
  3. 服务端组件加入读写锁机制,有效平衡处理性能与安全性
  4. 服务端组件的 socket 对象缓存列表设置了锁定时间,提高访问的安全性

*** v2.2.3 更新 ***

 > 连接 id 的数据类型改为 ‘connid’:

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

  1. 在sockethelper.h 中定义 connid 数据类型(默认:typedef ulong_ptr connid)
  2. 应用程序可以把 connid 定义为其希望的类型(如:ulong / ulonglong 等)
  3. 为了便于移植与维护,应用程序的任何地方都应该用‘connid’类型引用连接 id

> 服务端 socket 组件支持为每个连接绑定附加数据:

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

  1. iserversocket 和 ciocpserver 增加方法 get/setconnectionextra()
  2. 通过上述两个方法,应用程序可以为每个连接绑定任意附加数据并把数据获取出来

*** v2.2.2 更新 ***

  > 优化心跳检测相关功能:

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

  1. iserversocket 和 iclientsocket 的 get/setkeepalivetimes() 方法改为 get/setkeepalivetime()
  2. ciocpserver 和 cclientsocket 的默认 keepalivetime 属性改为 5000
  3. ciocpserver 和 cclientsocket 的默认 keepaliveinterval 属性改为 3000

*** v2.2.1 更新 ***

> pull 模型支持:

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

  1. isocketlistener 增加 pull 模型数据接收通知方法 onreceive(dwconnid, int)
  2. 增加 pull socket 接口 ipullsocket,该接口的 fetch(dwconnid, pbuffer, ilength) 方法用于抓取通信数据

> server:

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

  1. 服务端 socket 接口 isocketserver 改名为 iserversocket
  2. 增加 pull server socket 监听器抽象类 cpullserversocketlistener
  3. 增加 pull server socket 接口 ipullserversocket
  4. 增加 pull server socket 实现类 ciocppullserver

> client:

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

  1. 客户端 socket 接口 isocketclient 改名为 iclientsocket
  2. 客户端 socket 实现类 csocketclient 改名为 cclientsocket
  3. 增加 pull client socket 监听器抽象类 cpullclientsocketlistener
  4. 增加 pull client socket 接口 ipullclientsocket
  5. 增加 pull client socket 实现类 cpullclientsocket

9
0
评论 共 2 条 请登录后发表评论
2 楼 2014-01-03 16:25
guaishou 写道
anybody say something ...

是否开源,作者,相同产品优势。
1 楼 guaishou 2013-12-27 13:55
anybody say something ...

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • 在数据库应用系统中,常常要对数据库进行备份。数据库备份包括数据库结构备份和数据库数据备份2部分。对于数据的备份主要是成批的复制、追加、删除和更改等操作,这种批量操作在专门的数据库开发工具中是利用append和copy等命令带上相应的命令子句完成。但在其他开发工具中并没有类似的命令,而是提供能完成类似功能的控件或对象,如在powerbuilder中就是利用数据管道来完成2个或同构或不同构的表之间的数据批处理。介绍了如何利用delphi的tbatchmove控件实现数据备份的方法以及由此产生的缓冲数据库的功能

  • (1)通过odbc+ado的方式连:with adocon1 dobeginclose;connectionstring:=( 'driver={mysql odbc 5.1 driver}; ' 'server=192.168.1.107; ' 'database=test; ' 'user=root; ' 'password=root; ' 'port=3406; ' 'option=3; '...

  • delphi 把数据库中的数据转换成xml格式 function replacestring(astring: string): string; begin result := stringreplace(astring, '&', '&', [rfreplaceall]); result := stringreplace(result, '...

  • datasource数据源简单理解 因为热爱,所以拼搏。 –ruider 什么是数据源 jdbc2.0 提供了javax.sql.datasource接口,它负责建立与数据库的连接,当在应用程序中访问数据库时 不必编写连接数据库的代码,直接引用datasource获取数据库的连接对象即可。用于获取操作数据connection对象。 数据源与数...

  • listbox删除 删除选中的某个:procedure tform1.button1click(sender: tobject); var i:integer;begin i:=0; while i 0) then begin items.move(itemindex, itemindex - 1); lst2.setfocus; ...

  • unit udblistbox;interfaceuses windows, messages, sysutils, variants, classes, graphics, controls, forms, dialogs, stdctrls, grids, dbgrids, db, extctrls, dbctrls, dbtables;type tf

  • pdf2image.dll如何修复?pdf2image.dll是电脑内十分重要的文件,它的丢失易导致游戏、应用软件等程序运行出现错误,致使程序无法正常运行,它的解决办法也是非常简单的,只要下载好pdf2image.dll文件,放置在对应系统的目录下面,运行补丁即可让程序正常运行它是一个电脑系统中必不可少、非常重要的dll文件,对于系统来说缺少相关文件至关重要,这时此dll文件就派上用场了若你的电脑不小心丢失了这个文件那可就麻烦了。 pdf2image.dll如何修复 1、从本站下载pdf2image.d

  • delphi与oracle数据库的连接在delphi中连接oracle数据库采用的是odac(oracle data access components)组件。odac 直接使用 oracle 调用接口 (oci)。使用odac的net选项而无需在客户机上安装oracle客户端来连接到oracle.在这种情况下,odac仅需要tcp/ip协议的支持,从而可以创建真正的、最小的数据库应用程序。安装完...

  • //excel的单元格拷贝粘贴procedure excel_copycells;var  sheet,xlapp,workbook,myrange1 ,myrange2: variant;begin  try    //创建对象    xlapp:=createoleobject(excel.application);      xlapp.displayalerts:=true;     

  • 存入varastream:tmemorystream;beginastream:=tmemorystream.create;tryimage1.picture.graphic.savetostream(astream);astream.position:=0;ifadoquery1.activethenbeginadoquery1.edit;tblobfield(adoquery...

  • 1-数据库分类 1)本地数据库 文件夹定位 dbase 文件定位 access .mdb 2)远程数据库服务——基于事务的机制处理多用户访问存在的问题 访问远程数据库中的元素步骤 首先要定位服务器 其次定位其中的数据库以及具体的元素(就是数据库中的表、视图、存储过程等) 主要有 interbase mysql sqlserver oracle ms 3) 2-delphi连接数据库步骤——以access数据库为例 1)添加adoconnection控件如图 2)选中它,设置其属性connect

  • 在下面这个delphi连接以及操作mysql数据库中,我们以最简单展示,没有考虑异常等情况,我在其中加了两个按钮,一个是连接数据库,一个是从连接的数据库查询一个数据, 源码下载地址:http://download.csdn.net/detail/cq20110310/6854069 mysql:表student,在下面这个delphi连接以及操作mysql数据库中,我们以最简单展示,没有考虑异常等...

global site tag (gtag.js) - google analytics