Skip to content

Latest commit

 

History

History
744 lines (433 loc) · 29.3 KB

update.md

File metadata and controls

744 lines (433 loc) · 29.3 KB

更新日志

2018-10-16

  • 修复:修复zExpression无法对1.0e-2浮点识别的bug
  • 修复:crossSocket接口反复释放的一个严重bug
  • 修复:xNat内创穿透断线重连不稳定的bug,新版本的xNat公网服务器,只会在内网连接后,才会侦听端口,两端运行中现在会极其稳定
  • 优化:xNat在手机也可以做内网穿透服务,优化了wiki或则4G,3G连接不稳定造成的通讯问题
  • 安全:新增傻瓜化使用的抗量子密码支持(sha3),在密码货币系统非常常见,经过验证已经与wiki一致, https://en.wikipedia.org/wiki/SHA-3
  • 安全:因为sha3有大量的迭代计算,在摩尔定律使用秀儿算法是无法被破解的,同时sha3的计算性能也远远不如fastmd5,也许有数千倍差异,但是,使用sha3来存储和验证密码会万无一失

重新支持了5大美国国家标准技术研究所(NIST)高级加密标准算法,如下

2018-9-29

  • 修复:FPC中Enum为4 byte定义会丢失符号位的问题
  • 修复:Synapse的接口在连接失败时,会尝试切换IPV4+IPV6重新连接
  • 修复:Syanpse客户端在连接失败时不返回状态
  • 工艺:新增线性事件支持库,LinerAction.pas
  • 工艺:新增查询服务器支持(类似dns,主要针对万物互联需求:物联网设备太多,调度服务器不够用,可使用查询服务器分担),HostQuery.pas
  • 工艺:兼容基于FPC对IOT的支持:从底层到高级,大规模统一调整命名,此项调整会影响很多工程的代码细节
// 本项目中的回调分为3种
// call:   直接指针回调,fpc+delphi有效
// method: 方法回调,会继承一个方法宿主的地址,fpc+delphi有效
// proc:   匿名过程回调,只有delphi有效

// 如果本项调整对于改造现有工程有一定的工作量,请使用字符串批量处理工具
// 在任何有回调重载的地方,方法与函数,均需要在后缀曾加回调类型首字母说明

//
RunOp 变更为 RunOpP() // 后缀加P表示匿名类型回调
RunOp 变更为 RunOpM() // 后缀加M表示方法类型的回调
RunOp 变更为 RunOpC() // 后缀加C表示指针类型的回调

SendStreamCmd 变更为 SendStreamCmdP() // 后缀加P表示匿名类型回调
SendStreamCmd 变更为 SendStreamCmdM() // 后缀加M表示方法类型的回调

2018-9-21

兼容 fpc 3.0.0,可正常编译,建议使用fpc 3.0.4 or last

2018-9-18

新平台,新平台测试通过,在新平台树莓派3B+,操作系统 Ubuntu16.04 Mate 下测试成功

新增几个技术文档

DoStatusIO.pas库

  • 优化,干掉后台线程刷新,改用DoStatus方法替代线程,最简单的使用方法:在你的主循环中,加一句DoStatus不要给参数
  • 优化,减少对某些库的依赖性

其它优化

  • 优化,FPC3.0.4编译出来的程序,整体性能向前提升10%
  • 优化,Delphi编译出来的程序,整体性能向前提升10%
  • 优化,精细调整服务器主循环:特别说明,在Console模式下后台服务器程序中,必须加上线程同步检查:CheckThreadSynchronize,否则系统Console后台不能正常工作

2018-9-15

本次更新,大幅提升底层库的稳定性

重大更新

  • 新接口,同时支持fpc+delphi:新增基于Synapse的通讯接口
  • 内网穿透核心技术,同时支持fpc+delphi:新增内网穿透的开发库,由xNatService.pas,xNatClient.pas,xNATPhysics.pas三个小库组成,只需5行代码即可驱动,可使用ZServer支持的任意通讯接口工作。已通过5万ip/每分钟连续4小时的压力穿透测试。
  • IoT物联网,只限fpc:对IoT平台的支持,基于fpc在各平台完整支持了Synapse通讯接口,包括:ARM Linux(IoT需求),Linux x86+x64,OSX x86+x64,Win x86+x64
  • 稳定和安全,大规模取替底层库使用inline的机制

CommunicationFramework.pas库及周边支持

  • 优化,稳定性提升,深度考虑安全性
  • 安全,重做了p2pVM的验证系统(每个p2pVM握手时,都会用不同的验证方式)
  • 安全,p2pVM第一次握手时,必须有验证码
  • 工艺,新增2种协议模式:cpZServer(原来的通讯协议),cpCustom(外部自定义的通讯协议)
  • 工艺,重做外部自定义通讯协议的开发工艺:开发自定义通讯协议时,不用再考虑同步异步问题
  • 工艺,ProgressBackground全部统一替换成Progress
  • 工艺,TCommunicationFrameworkServer服务器触发DoClientConnectAfter会区分协议,cpZServer,cpCustom会有各自处理机制
  • 安全,在TCommunicationFramework中以性能换取了Progress的稳定性,客户端+服务器在高并发环境下不会再在这个地方出现异常报告了
  • 周边:极小概率bug,修复CrossSocket的连接池释放时发生异常的问题(delphi)
  • 周边:控制台模式服务器bug,修复ICS,Syanpse,Indy服务器在Console应用模式中不触发线程同步的问题(delphi)
  • 周边:小概率bug,修复ICS服务器使用StopService偶发性的出现卡死的bug
  • 周边:合并了最新更新的CrossSocket内核
  • 周边:优化,在MemoryStream64.pas库中对ZLib使用解压时,会预先分配内存或则文件空间,避免因为MemoryManager频繁Realloc造成性能耗损(在FPC方向程序中,性能可以相对提供10%)

TextParsing.pas库及其周边支持

  • 大幅提升的解析性能,使用不变,相较以前,性能向前提升90%
  • 新增可替代蚂蚁机制的文本探头技术
  • 优化大规模解析程序的复杂度:降低50%
  • 修复对123{abc}这种写法的误判行为

TextDataEngine.pas库

  • 重做数据结构支持,使用与以前不变
  • 新增了对THashStringList的内置支持(相对THashVariantList,性能更加优异)

ListEngine.pas库

  • 安全:对已生成的Hash会使用安全校验措施(我实测Hash的事故率为0,但是有网友报告说Hash会莫名其妙报错,我现在加了一个安全措施,如果还遇到hash无法命中,请检查自己的bug)

百度翻译api服务器

  • 由于百度不再提供免费翻译api,我们首次运行百度翻译api服务器时,会生成一个配置文件,它会指引你如何注册翻译api的账号

本次新增两套Demo

  • ZServer4D对大规模后台验证服务器的工艺,比如你后台有Oracle这类大型数据库,该Demo详细描述了三方验证工艺
  • XNat内网穿透库的Demo

2018-7-6

  • 大幅修正底层库的命名规则
  • 对fpc/86/64平台支持,全部基础库支持Linux下的无故障编译和运行
  • 对fpc编译器3.1.1全面支持
  • 新增对mips,树莓派的大小字节序支持
  • 修复对32位fpc编译器不认for用Int64的问题
  • 修复字符串在fpc编译器运行于linux发生异常的问题
  • 新增pascal预编译工具,将pascal代码规范成c风格的全部统一大小写,全面兼容Linux区分大小写文件名的机制
  • 本次更新未对树莓派支持
  • 本次更新未对fpc的跨平台服务器体系支持(synapse)
  • 本次更新未对双通道的用户身份验证事件的回调做支持
  • 本次更新未对反向代理更新,反向代理工具系列将留在下次更新一并升级

2018-5-26 基于云服务器的开发工艺在本次已经升级

  • 删除了云服务器模型1.0及其Demo
  • 原商业云服务器框架2.0被移动至Demo中
  • 新版本云服务器模型并入到了 ServiceApiModel 中
  • 新版本的云服务器模型具备低门槛的技术基因,支持了在Linux系统架设云服务器后台,整个模型只有一个300行代码的群集调度服务器,外加两个附属Demo和一份调度服务器的用法详解文档
  • 新增一个HPC服务器的使用Demo
  • 新增技术文档,BatchStream机制详解.pdf
  • 新增技术文档,HPC服务器的工作机制详解.pdf
  • 新增技术文档,延迟反馈机制详解.pdf
  • 新增技术文档,云调度服务器用法详解.pdf
  • 本次更新未对反向代理更新,反向代理工具系列将留在下次更新一并升级

2018-5-26 基于云服务器的开发工艺在本次已经升级

  • 删除了云服务器模型1.0及其Demo
  • 原商业云服务器框架2.0被移动至Demo中
  • 新版本云服务器模型并入到了 ServiceApiModel 中
  • 新版本的云服务器模型具备低门槛的技术基因,支持了在Linux系统架设云服务器后台,整个模型只有一个300行代码的群集调度服务器,外加两个附属Demo和一份调度服务器的用法详解文档
  • 新增一个HPC服务器的使用Demo
  • 新增技术文档,BatchStream机制详解.pdf
  • 新增技术文档,HPC服务器的工作机制详解.pdf
  • 新增技术文档,延迟反馈机制详解.pdf
  • 新增技术文档,云调度服务器用法详解.pdf
  • 本次更新未对反向代理更新,反向代理工具系列将留在下次更新一并升级

2018-5-21

  • 完全移除Pasmp,并行线程的触发面积现在是根据Cpu*2进行展开,安全并行化仍然保持支持Linux,IOS,Android,windows,OSX等主流系统
  • 新增HPC内核(延迟线程技术)
  • HPC内核暂无Demo,稍等几天会补充上Demo
  • 新增10种云服务器种类,稍等几天会补充上Demo
  • CrossSocket客户端的连接池现在会自动释放
  • ICS客户端在关闭时,会自动释放内存(检测内存泄漏可以用ICS,无泄漏后,再换成DIOCP or Cross)
  • 已测试过所有服务器,无内存泄漏,ICSSever,IndyServer,DIOCP,CrossSocketServer
  • 修复CrossSocket服务器的连接在关闭后,仍然可以获取到客户端IP的问题
  • TDataFrameEngine新增对TListPascalString,TListString, THashStringList支持
  • ZDB新增压缩+Copy信息反馈机制,当我们大量使用StorePos在记录条目位置,这时候ZDB被压缩后,StorePos将会变化,ZDB现在能够反馈这一变化
  • ZDB网络数据库同步支持ZDB的StorePos变化反馈机制,当ZDB被压缩或则Copy时,客户端将搜到StorePos变化事件
  • TPascalString的GetChar机制更改:当Index超过字符串长度时,返回#0
  • TUPascalString面向FPC设计的Unicode字符串同步更新GetChar机制,与TPascalString一致
  • CoreClasses中的更新:LockObject+LockID,兼容所有平台与并行化调用
  • Geometry2DUnit,2D相关支持的几何库大量更新
  • 本次所有更新均已在FPC(3.0.4)+Laz(1.8)下测试通过
  • 本次更新了大量内核基础库,已做过系统测试,建议更新
  • 本次更新并没有新增Demo

2018-4-27

本次主要更新基础库,对服务器框架无任何修改

  • 内核ListEngine单元支持了巨型链表,巨型Text文件的存储(可以支持上亿行的文本格式读取)
  • ZDB新增CSV文件数据导入
  • 小幅修改部分函数命名
  • 默认情况下,zServer会关闭并行接口,打开并行接口请自行修改zDefine.inc
  • 在雷电模拟器测试通过了所有手机端的数据收发
  • TPascalString字符串现在拥有更严格的内存分配

本次更新已做过深度测试。如果在开发中的项目,正在使用zServer服务器,可以选择更新

2018-4-12

修复内核中的内存越界bug:该bug的症状为无故提示内存无法访问,通过正常debug很难排除,这是是内存越界时所造成的bug

修复TwoFish加密算法bug

已合并近期更新的crossSocket

因为FastKDTree属于统计学领域,在此次更新已移除,如果如果需要使用FastKDTree请访问

https://github.com/PassByYou888/zAnalysis

2018-3-13

修复 17.外部协议实现范式 在关闭窗口时出现的异常问题。感谢人在旅途qq563791686

2018-3-6

新增地基库: 高速K维空间树(FastKDTree),最大可以支持2048个纬度的2分空间搜索,FastKDTree支持数据存储和读取,支持货币/单/双浮点/整型 等等单位

修复SmithWaterman算法漏洞

小幅提升内核字符串处理性能

修复部分编译错误

2018-3-1

在TPascalString内核中新增模糊字符串对比函数(SmithWaterman),优化与测试完成

该算法属于生物基因工程学科 Smith-Waterman的维基百科地址 https://en.wikipedia.org/wiki/Smith%E2%80%93Waterman_algorithm

2018-2-28

为新项目增加了备注信息

修复了zExpression对c字符串的转义处理

2018-2-26

修复在三方雷电模拟器中客户端收发数据发生崩溃的问题

重制了内置原子锁,新版本的内置原子锁现在可以支持高并发,支持Linux。( 使用内置原子锁需要在zDefine.inc打开 CriticalSimulateAtomic )

修复zExpression切割分段不正确问题

2018-2-25

zExpression新增自定义表达式符号支持

zExpression新增自定义表达式符号的演示

zExpression修复嵌套函数参数不能正确展开接口的问题

zExpression修复解析引擎的数字探头不能识别16进制自然数和函数问题

zExpression修复字符串和数字匹配联合的问题

zExpression支持c代码风格0x16进制语法

2018-2-16

小幅提审字符串相关的处理性能

2018-2-9

新增百度翻译后台服务模型,支持最新的Ubuntu16.04LTS服务器版,同样也支持Windows服务器

已并入CrossSocket新版本接口,CrossSocket新版本接口的详细情况已在代码中备注,我修改过的Cross内容也已备注(尊重开源)

小幅修了zExpression的OpCache问题

在UnicodeMixedLib中新增了umlURLEncode

2018-2-7

项目内置的CrossSocket接口现在已经支持linux,我实测的Linux服务器版本为Ubunto16.04 LTS,感谢CrossSocket作者,感谢群友

修正Linux HelloWorld服务器主循环吃cpu资源问题

2018-2-6

Tools新增pascal,c,c++字符串申明互转,字符串10/16进制互转

在 Exameples/19.词法引擎TextParsing的用法演示/ 中新增zExpression的用法,包括if实现,html和文本宏替换,二进制保存和读取op

新增zExpression到主线工程 开源地址 https://github.com/PassByYouOfTeam/zExpression

zExpression 基本用法演示

var
  rt: TOpCustomRunTime;
  v : Variant;
begin
  // rt为ze的运行函数支持库
  rt := TOpCustomRunTime.Create;
  rt.RegOp('myAddFunction', function(var Param: TOpParam): Variant
    // (a+b)*0.5
    begin
      Result := (Param[0] + Param[1]) * 0.5;
    end);
  rt.RegOp('myStringFunction', function(var Param: TOpParam): Variant
    begin
      Result := Format('字符串长度为:%d', [Length(VarToStr(Param[0]) + VarToStr(Param[1]))]);
    end);

  // 简单数学表达式
  v := EvaluateExpressionValue(False, '1000+{ 这里是备注 ze可以识别pascal和c的备注以及字符串写法 } myAddFunction(1+1/2*3/3.14*9999, 599+2+2*100 shl 3)', rt);
  DoStatus(VarToStr(v));

  // 简单字符串表达式,ze的默认文本处理格式为Pascal
  v := EvaluateExpressionValue(False, 'myStringFunction('#39'abc'#39', '#39'123'#39')', rt);
  DoStatus(VarToStr(v));

  // 简单字符串表达式,我们使用c的文本格式
  v := EvaluateExpressionValue(tsC, 'myStringFunction("abc", "123")', rt);
  DoStatus(VarToStr(v));

  disposeObject(rt);
end;

2018-2-5

修复使用json传输时因为utf8无法解码的bug,感谢 清风qq274838061

新增zExpression句法引擎

2018-2-3

新增一套部署Ubuntu服务器开发环境文档

新增基于Ubuntu16.04 LTS 版本的Linux支持,新增一套Linux下的服务器Demo

新增一个词法Demo,简单演示了怎样分析函数,怎样处理声明(后续会继续增加词法程序范式)

2018-2-1

ZDB网络数据库现在支持基于CompleteBuffer的FastPost,可以支持到每秒10000条以上记录量通过服务器存储

删除数据条目的机制改为安全队列

删除了Tools目录中的EXE

2018-1-31

在CoreClasses.pas中新增一个原子锁的后背支持功能:CriticalSimulateAtomic,用临界区替代Atomic,在delphi下打开它会让并行功能效率降低,但是它可以兼容所有平台和fpc

修复了p2pVM中的echo,用于模拟tcp链接中的keepalive

2018-1-30

新增了P2PVM第二篇技术文档,简单编写,没画图

新增了一份基于FastMD5的性能对比测试(在Examples中可以找到,需要安装Mormot感谢南极土著qq4499972)

最近的新版本尚未在Linux测试,请尽量使用Windows做后台

此次更新以调优为主,调优内容:

修改了通讯框架的数据结构,以Inline方式优化,小幅减少函数调用频率

修改了基于TDataFrameEngine的Json存储格式,此格式以后可以恒定下来

所有的演示内容重新测试和编译

云框架2.0的内容重新测试和编译

Tools目录中的所有工程,已追加了.OXC(FRP的编译打包文件)

将TPeerClient更名为TPeerIO,仍然留有老的TPeerClient指向,不会影响项目编译和升级

在TPeerIO创建时,增加了一个更加安全的原子锁,已测试调优过Cross,ICS,Indy,DIOCP等等接口

取消了AllowPrintCommand属性,以QuietMode代替

用一个已经跑过百万在线的后台项目重新编了一次新版本,并且测试全部通过

2018-1-29

通讯新增DIOCP接口 DIOCP是国人所开发的稳定服务器项目 因为呼声较高 所以我今天做了DIOCP的底层接口并且测试通过

新增帮助开发者自行开发网络接口的范例库(source\developerRefrence)

大幅优化TPascalStrings库

新增FastMD5 FastMD5开源地址

通讯数据结构 TDataFrameEngine 已支持Json打包,Json引擎基于优秀开源项目 JsonDataObjects

修复一个小型bug 在云服务器框架2.0中 我们基于雾服务器做表达式计算时 写1*2.1 会出现表达式错误的问题

新增一个制作底层通讯库IO接口的小文档

2018-1-25

修复一处不常见的内存泄漏:泄漏症状为,服务器发送一条待反馈的消息SendStreamCMD,在等待反馈中,客户端断线,这时候发生泄漏

对多媒体机制的CompleteBuffer现在可以兼容匿名函数

新增一处实现定制化协议的标准范式Demo,内附详细使用说明,"Examples\17.外部协议实现范式"

p2pVM隧道性能小幅提升10%,在100万压测Demo下能明显感觉性能提高

2018-1-24

新增多媒体机制支持 多媒体通讯

新增p2pVM隧道技术体系,并且新增基于隧道的服务器开发工艺 p2pVM隧道技术说明

新增两套p2pVM隧道技术体系的服务器Demo,分别是可以带100万压测的Demo,改造认证双通道为p2pVM技术体系的Demo,内容太多,这里就不贴图和源码了

新增两套文档,分别是p2pVM隧道技术体系介绍和多媒体支持的CompleteBuffer介绍文档

优化indy通讯对手机平台的容错性(ipv4+ipv6)

2018-1-19

在内网穿透工具中加入了NAT端口非对称映射功能(感谢阿木和十指间的挥洒)

在MH库中新增的上下文分析,并且在内存分析钩子的Demo中也增加该功能的演示代码

内核会自行判断ipv4和ipv6的地址版本,如果使用域名,会根据定义自动优先级选择AAAA和A记录,100%支持苹果ipv6过审

重做了indy的connect方法,ics,indy,cross均新增异步链接(类似6万并发,零阻塞,高频率触发),双通道现在均支持异步链接

indy的connect阻塞被缩短在1秒内

重做wait机制,在indy中,现在使用心跳检测可以用零阻塞机制,和keepalive的效率相同

小幅调整FilePackageWithZDB的UI样式,小幅修正FilePackageWithZDB的ui

在"4.登陆式双向交互服务器框架"中,新增了精确时间戳同步的演示

在Demo中新增了双通道和单向链接的异步方法,这些方法都有写明使用

修改了几个UnicodeMixedLib的核心函数

小幅优化PascalString内核

2018-1-16

提交了内网穿透Shell工具全部的源代码,编译时必须包含ZServer4D的服务器框架,在源码目录有OXC包的下载地址

新增了内网穿透的自动化工具,分别是ZSGatewayMiniClient,ZSGatewayMiniServ,相当于内网穿透工具的2.0版本

重做了内网穿透工具的使用说明文档

FilePackageWithZDB现在可以打开OXC压缩文件

2018-1-16

新增内网穿透 宅服架设说明

新增云服务器框架2.0 云服务器框架2.0说明

新增单元库的介绍文档,单元库介绍

新增DoStatusIO线程无关性支持

新增数模引擎

新增文件打包工具,开放源码

新增将文件编码成pascal代码的工具,开放源码

新增.drp源码排序工具,开放源码

维护ObjectData,修改了部分方法

现在SendStreamCmd时DataFrameEngine参数可以为nil

client.SendStreamCmd('xx cmd', nil, procedure(Sender: TPeerClient; ResultData: TDataFrameEngine)
begin
end) 

2018-1-3

在演示源码中说明部分使用中的坑(感谢好人一生平安路)

修改了物理断线检测机制

Inline函数可以通过zDefine.inc进行定义

2017-12-30

重做压力测试客户端的链接方法,6万并发压力测试客户端性能向前提高1000倍,1秒可以完成6万并发连接

优化了压力测试服务器性能,抗上万压测只会消耗单cpu 10%资源

核心压缩库已被并入主线工程,并且提供了和Delphi/fpc可以进行比较的Demo工程(支持ARM)

服务器端有个大改动:不再支持用户遍历方法,同时服务器内核不在使用链表来管理客户端,所有客户端全部改用Hash数组来管理

此类方法已被替代为匿名函数来工作,同时服务器对链接实例的管理也不再支持链表,从内核到外围,全部使用哈希数组进行管理,这些升级和改动,都是为下一步1000万并发做的铺垫

	// 曾经的老写法很不安全,已废弃
	LockClient;
	for i:=0 to client.count-1 do
	  client.sendcommand(xx) 
	UnLockClient;

新的遍历方法

// 后台安全写法1,
Server.ProgressPerClient(Procedure(peerClient:TPeerClient)
begin
  client.sendcommand(xx)
end);
// 后台安全写法2
RecvTunnel.GetClientIDPool(IDPool);
for pcid in IDPool do
  if RecvTunnel.Exists(pcid) then
   begin
	 RecvTunnel.ClientFromID[pcid].sendcommand(xx);
   end;

新增服务器的内存Hook库(傻瓜,暴力,非常暴力的释放和管理内存),同时也新增了内存管理领域开发工艺Demo,MH库支持FPC和Delphi

type
  PMyRec = ^TMyRec;

  TMyRec = record
    s1: string;
    p: PMyRec;
  end;

var
  p : PMyRec;
  i : Integer;
  hl: TPointerHashNativeUIntList;
begin
  // 200万次的大批量记录内存申请,最后一次性释放
  // 这种场景情况,可以用于批量释放泄漏的内存

  // 我们内建20万个Hash数组进行存储
  // BeginMemoryHook的参数越大,面对对大批量存储的高频率记录性能就越好,但也越消耗内存
  MH_3.BeginMemoryHook(200000);

  for i := 0 to 200 * 10000 do
    begin
      new(p);
      new(p^.p);
      // 模拟字符串赋值,高频率触发Realloc调用
      p^.s1 := '111111111111111';
      p^.s1 := '1111111111111111111111111111111111';
      p^.s1 := '11111111111111111111111111111111111111111111111111111111111111';
      p^.p^.s1 := '1';
      p^.p^.s1 := '11111111111111111111';
      p^.p^.s1 := '1111111111111111111111111111111111111';
      p^.p^.s1 := '11111111111111111111111111111111111111111111111111111111111111111111111111';

      if i mod 99999 = 0 then
        begin
          // 这里是迭代调用,我们不记录,将MH_3.MemoryHooked设置为False即可
          MH_3.MemoryHooked := False;
          Button1Click(nil);
          Application.ProcessMessages;
          // 继续记录内存申请
          MH_3.MemoryHooked := True;
        end;
    end;
  MH_3.EndMemoryHook;

  DoStatus('总共内存分配 %d 次 占用 %s 空间,地址跨度为:%s ', [MH_3.HookPtrList.Count, umlSizeToStr(MH_3.GetHookMemorySize).Text,
    umlSizeToStr(NativeUInt(MH_3.GetHookMemoryMaximumPtr) - NativeUInt(MH_3.GetHookMemoryMinimizePtr)).Text]);

  MH_3.HookPtrList.Progress(procedure(NPtr: Pointer; uData: NativeUInt)
    begin
      // 现在我们可以释放该地址
      FreeMem(NPtr);
    end);
  MH_3.HookPtrList.PrintHashReport;
  MH_3.HookPtrList.SetHashBlockCount(0);
end;

新增的内存Hook库已在ZDB内部有效应用

2017-12-20

修复链接池重复链接的Bug(感谢好人一生平安路)

新增LZ77哈夫曼和BRRC压缩算法,请自行对比ZLib性能及压缩率

因为是公有服务器框架,处于安全考虑,通讯包协议在首尾各增加4byte作为验证标记,发行时可以有80亿的独特协议包数据(你只需要从80亿的数值选择一个独特的验证序,别人就算有ZS源码也无法访问你的服务器)

2017-12-15

修复了底层hash函数库因为没有传递对象,导致云服务器的状态列表不更新的问题

2017-12-15

新增6万压测Demo

ZDB新增一组提交数据条目和大图片捆绑的Demo,每张图片各2M,此机制可用于任何Stream数据,请参考并且依次类推

ZDB新增安全缓存,其工作机制为:当触发数据库写操作时,开始计时,如果5秒内没有第二次写操作,就会将回写缓存立即写入文件。主要用于保护数据库文件损坏。

ZDB和ZServer均已在Linux下测试通过

2017-12-10

新增ZDB服务器Demo,新增ZDB IN FMX Demo,已在所有手机测试通过,所有的详细说明都内附在Demo源码中

将ZDB数据库的查询能力向前优化了15倍,内存消耗也因此提高了10%,默认单库体量为500万条,如果服务器内存在16G以上,需要自行在ZDBEngine中修改最大Cache和退火参数

修复了单通道客户端Indy,ICS,CrossSocket在发出链接后的ID不更新问题(感谢AK47)

在EZServer增加了使用Special实例的方法(感谢AK47)

2017-12-8

新增大数据库引擎ZDB的网络服务器Demo,并且内附了详细功能说明 Demo说明

在ZDB中新增压缩,拷贝,替换等等底层功能

将ZDB的退火系统改成了自动化功能,只需要设置几个参数即可

新增带有验证机制的ZDB服务模型

2017-12-6

新增单机数据引擎,新增分布式和网络数据引擎

新增单机数据库Demo

新增20k链接压力测试,服务器光速响应,并且无内存泄漏

通讯内核新增批次化BigStream支持

通讯内核新增special接口

通讯内核新增了很多状态机

修复了CrossSocket在退出时报异常的问题

优化内核Hash性能

优化了文件读写内核,内部集成了回写和预读缓存机制,小幅降低IO消耗频率

群集中心服务器可以一键开发和部署

2017-11-29

修复fpc对CommunicationFrameworkDoubleTunnelIO.pas单元的兼容性

匿名函数在异步回调系统是非常好的机制,Zserver4d新增匿名函数支持,同时新增了一套匿名函数的支持Demo

处于安全考虑,在ICS,Indy,CrossSocket服务器端从现在开始,均不支持WaitSend的阻塞通讯模式,客户端仍然支持WaitSend

2017-11-27

修复indy接口的服务器,新版的Zserver4D在IndyServer将不再支持WaitSend阻塞化模式,必须使用异步,在CrossSocket,ICS在服务器仍然可以使用WaitSend,Indy,ics,CorossSocket的客户端支持保持不变,新版的IndyServer会更加稳定

因为某些低版本的Windows不支持精确计时器,CoreCipher取消了并行化编码库支持,改为定义,在没有定义使用异步编码时,将不会使用PasMP

修复了MD5支持算法,在x86,x64,arm下现在超过4G的md5计算均能一致

针对freepascal编译器改动:将ListEngine的string定义全部更新成了SystemString,完全兼容UnicodeString

2017-11-25

测底修复了BitStream的内存拷贝问题,现在收发大型Stream均不会拷贝内存,能做到以最低开销承载1000个用户同时下载2G以上的文件

修复了所有的服务器的内存泄漏(注意:但是客户端仍然会有泄漏,因为客户端设计就是采用不考虑回收的粗犷方式)

内部机理做了小幅调整,处理内部工作某些函数重新命名

新增了一套基于Indy接口在移动平台做服务器的使用Demo

2017-11-24

新增登录式高级云服务器的作用介绍

更新了在IOCP中使用WSASend因为缓冲区问题发送失败的bug 感谢ak47的测试回报