火山PC【视窗】【HP-Socket】商业级高并发中间件开发课

这是一套关于数据库中间件开发的教程,涵盖了从基础知识到实际应用的各个环节,包括HP中间件、MySQL、JSON的介绍,通讯框架和数据通讯的建立,高性能键值表,协议封装,同步异步通讯,客户端及服务端操作数据库的各种操作,如查询、插入、更新和删除等,以及记录集的分页显示。通过本课程,学员将能够掌握商业级数据库中间件的开发技能。
摘要由CSDN通过智能技术生成

教程内容(每节课平均约20分钟):

1.数据库中间件-前言

2.数据库中间件-HP介绍

3.数据库中间件-mysql介绍

4.数据库中间件-JSON介绍 

5.数据库中间件-建立通讯框架

6.数据库中间件-建立数据通讯

7.数据库中间件-高性能键值表

8.数据库中间件-协议封装方法

9.数据库中间件-异步通讯改成同步

10.数据库中间件-编写中间件客户端记录集1

11.数据库中间件-编写中间件客户端记录集2

12.数据库中间件-连接mysql数据库

13.数据库中间件-客户端执行select查询请求

14.数据库中间件-服务端记录集组装成字节集

15.数据库中间件-服务端结果回传到客户端

16.数据库中间件-客户端插入记录insert into

17.数据库中间件-客户端更新删除记录 update delete 

18.数据库中间件-取记录数

19.数据库中间件-索引组取记录集1

20.数据库中间件-索引组取记录集2

21.数据库中间件-取最大页数

22.数据库中间件-取记录集分页

23.数据库中间件-记录集到超级列表框

24.数据库中间件-记录集到组合框到列表框

25.数据库中间件-整理代码课程完结

观看地址:【HP-Socket】商业级高并发中间件开发课-利快云视频课程 (lkuaiy.com)

并发许可,顾名思义就是可以并发使用的许可证。具体解释原理吧,也没啥,就是一些架构技巧思维的利用,来把原本低效率的代码,编写成高效率的解决方案! 具体的看我下面的例子吧。直接面对各种高并发场景下,面向多对象的靠谱读写。还可以进行各种扩展。适用于很多场景! 应用场景1: 假设服务器上有1-10个编号,有N个用户并发请求1-10编号。需要准确的记录1-10编号 每个编号分别被请求了多少次。包括非指定范围。1-N之间。不可预知的范围。包括以用户名 ,以IP  等等为唯一性的一种靠谱读写。 按照以往的解决方案。肯定是需要创建10个许可证。100个编号就需要100个许可证。很明显这样是不现实的。 并发许可 利用了 hashcode 并且求余数的方式来给请求分配许可证,可以最大程度的保证并发效率的最大化,并且遇到争夺许可证的几率变的特别小。甚至在一些低量请求中,许可证争夺几乎是不存在的。 应用场景2: 记录用户访问日志:在HPsocket中,单用户的访问日志,可以根据IP 来划分。如果没有并发许可,用户的访问日志是无法做到准确记录的,因为多线程写入的原因,注定了日志的记录会丢失。为了最大程度的提高并发效率。我们需要为单用户每次分配到的许可证都是一样的编号。这样才可以不影响其他用户的前提下实现并发的最大化。  比如:用户 123 用户321 hashcode后的许可证编号都是2  那编号2的许可证 仅限于 所有hashcode 后编号为2的用户在争夺许可证。其他的用户都是保持并发的。
HP-Socket 是一套通用的高性能 TCP/UDP/HTTP 通信框架,包含服务端组件、客户端组件和Agent组件,广泛适用于各种不同应用场景的 TCP/UDP/HTTP 通信系统,提供 C/C++、C#、Delphi、E(易语言)、Java、Python 等编程语言接口。HP-Socket 对通信层实现完全封装,应用程序不必关注通信层的任何细节;HP-Socket 提供基于事件通知模型的 API 接口,能非常简单高效地整合到新旧应用程序中。    为了让使用者能方便快速地学习和使用 HP-Socket ,迅速掌握框架的设计思想和使用方法,特此精心制作了大量 Demo 示例(如:PUSH 模型示例、PULL 模型示例、PACK 模型示例、性能测试示例以及其它编程语言示例)。HP-Socket 目前运行在 Windows 平台,将来会实现跨平台支持。 [15:47 2018/11/05] 同步更新到5.4.2正式版 [10:37 2018/10/23] 1、英文模块IHttpSyncClient组件大改 2、IWinHttp组件添加若干命令(PS:忘记是哪些了。。。) 3、升到5.4.2 rc3 版本 4、增加client同步例子 [10:30 2018/9/25] v5.4.2 更新: > SSL 组件更新: ----------------- 1、SSL 组件可以手工启动 SSL 握手,从而可以对 SSL/Https 通信执行代理服务器设置等前置操作 2、SSL 组件(Server/Agent/Client)增加以下接口方法支持手工启动 SSL 握手 1) StartSSLHandShake():手工启动 SSL 握手,当通信组件设置为非自动握手时,需要调用本方法启动 SSL 握手 2) SetSSLAutoHandShake():设置通信组件握手方式(默认:TRUE,自动握手) 3) IsSSLAutoHandShake():获取通信组件握手方式 > 其他功能更新: ----------------- 1、所有可能导致 Socket 关闭的组件接口方法都在 Socket 通信线程中异步触发 OnClose 事件 2、Server 与 Agent 组件的 DIRECT 发送策略也支持通过 GetPendingDataLength() 方法实现流控 3、Server 与 Agent 组件的 Disconnect() 方法不再支持‘非强制断开’(仍然保留bForce 参数),调用时都会强制断开 4、OnSend 事件支持 三种同步策略 1) OSSP_NONE:不同步(默认) 1) OSSP_CLOSE:同步 OnClose 1) OSSP_RECEIVE:同步 OnClose 和 OnReceive(只用于 TCP 组件) > 升说明: ----------------- 1、HP-Socket v5.4.2 完全兼容 HP-Socket v5.4.1 版本,可以直接替换升 [18:41 2018/8/27] 1、修复英文模块submit_task最后一个参数错误问题,莫名其妙变成了字节集 [11:04 2018/8/27] 1、更新hpsocket为 beta11 2、submit_task 提交的任务不用去管回调里面的ptask参数。内部自动处理。 [16:57 2018/8/24] 1、修复中文模块部分命令错误问题 2、修复英文模块几处命令错误问题 3、增加websocket例程,本来httpclient里面人,有些人就是装看不见。 4、更新hpsocket为 beta9 [12:57 2018/8/15] 1、修复模块汇编的bug,原因是取消了ww汇编库 [11:55 2018/8/15] 1、模块更新为beta8 2、新增api: HP_Agent_IsConnected  -->  Agent.IsConnected() HP_Client_IsConnected  -->  Client.IsConnected() HP_Server_IsConnected  -->  Server.IsConnected() [9:18 2018/8/6] 1、性能优化 2、由于某些人吐槽中文版模块吐槽的厉害,遂决定不再更新中文版。 3、\demo\old 目录下放的是以前旧的例程源码,并不再更新 [12:57 2018/8/1] 修改模块IBufferPtr类,具体调用方式查看 TestEcho-New-Agent.e TestEcho-New-Server.e TestEcho-Http-Serve.e TestEcho-Http-Serve-bigfile.e  改名为 TestEcho-Ht
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值