13 Star 37 Fork 11

D10.天地弦 / diocp-v5

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
README.md 2.32 KB
一键复制 编辑 原始数据 按行查看 历史
D10.天地弦 提交于 2019-04-03 17:57 . * ECHO 服务器关闭泄漏问题

diocp5

快速开始

从那里得到:
 git更新(推荐同步更新)
  1.https://github.com/ymofen/diocp-v5
  2.https://gitee.com/ymofen/diocp-v5
最新版zip下载
  https://codeload.github.com/ymofen/diocp-v5/zip/master

FAQ文档:
  http://note.youdao.com/noteshare?id=2b40e5d99f39a57512d739f0a5a8a3ee


设置Delphi环境变量
  DIOCP5_HOME=E:\workspace\diocp-v5

搜索路径
  $(DIOCP5_HOME)\Source

FAQ

Q:同时启动两个Diocp服务, 为什么一个处理逻辑慢, 会影响到另外一个服务也变慢

A: Diocp底层默认共享同一个IocpEngine, 多个Diocp服务都是由同一个Iocp引擎驱动。可以用下面的办法进行优化
  1>. 每个DiocpTcpServer可以单独设置IocpEngine. 
      代码:FTcpServer.BindDiocpEngine(TIocpEngine.Create, true);
  2>. 加大默认IocpEngine工作线程, IocpEngine默认的工作线程数量:cpu核数* 2-1
  3>. 如果逻辑代码比较复杂,可以吧逻辑处理投递到另外的线程中执行。
  4>. Http服务逻辑处理是由diocpTask进行逻辑处理的,diocpTask默认的工作线程数量: cpu * 2 -1,
      可以引用diocp_task.pas, 在初始化app时进行设定 iocpTaskManager.setWorkerCount(50);
      可以在APP编译条件中指定QDAC_QWorker, 切换使用qworkers线程池

注意的一些事情

HTTP协议

关于ResponseStream, ResponesAFile

如果使用这两个过程响应Http, Diocp会分块发送数据,直达发送所有的数据发送完成,然后进行判断是否需要关闭连接。所以您不需要进行其他的响应(SendResponse), 也不需要执行ResponseEnd,也不能提前把Stream进行释放,Diocp的Http会接管处理他。

目录说明:

samples                        下面是各种DEMO
source                         目录下面是源代码

可以先从下面的DEMO中了解diocp的工作原理
  samples\ECHO
  samples\simple
  samples\StringDEMO

关于文档帮助

DIOCP QQ 群: 638127021  
DIOCP官方社区: www.diocp.org

关于捐助:

DIOCP5遵循BSD协议,你可以任意的用于商业项目和自由的项目中而不用通知我,
如果你觉得DIOCP5对你有帮助而你刚好又想对DIOCP5进行捐助,请联系作者,或者直接进行捐助:

捐助的支付宝:
账号:ymofen@diocp.org
户名: 杨茂丰
Delphi
1
https://gitee.com/ymofen/diocp-v5.git
git@gitee.com:ymofen/diocp-v5.git
ymofen
diocp-v5
diocp-v5
master

搜索帮助