在好例子网,分享、交流、成长!
您当前所在位置:首页Others 开发实例一般编程问题 → 基于Qt的多线程流水线异步服务器稳定版.zip

基于Qt的多线程流水线异步服务器稳定版.zip

一般编程问题

下载此实例
  • 开发语言:Others
  • 实例大小:3.51M
  • 下载次数:6
  • 浏览次数:112
  • 发布时间:2021-11-24
  • 实例类别:一般编程问题
  • 发 布 人:js2021
  • 文件格式:.zip
  • 所需积分:2
 

实例介绍

【实例简介】
本资源设置1个资源分,您可以下载作为捐献。 如果您有Git,还可以从http://www.goldenhawking.org:3000/goldenhawking/zoom.pipeline直接签出最新版本 (上一个版本“一种可伸缩的全异步C/S架构服务器实现”是有问题的,现在已经完成更改)。 服务由以下几个模块组成. 1、 网络传输模块。负责管理用于监听、传输的套接字,并控制数据流在不同线程中流动。数据收发由一定规模的线程池负责,实现方法完全得益于Qt的线程事件循环。被绑定到某个Qthread上的Qobject对象,其信号-槽事件循环由该线程负责。这样,便可方便的指定某个套接字对象使用的线程。同样,受惠于Qt的良好封装,直接支持Tcp套接字及SSL套接字,且在运行时可动态调整。(注:编译这个模块需要Qt的SSL支持,即在 configure 时加入 -openssl 选项) 2、 任务流水线模块。负责数据的处理。在计算密集型的应用中,数据处理负荷较重,需要和网络传输划分开。基于普通线程池的处理模式,也存在队列阻塞的问题——若干个客户端请求的耗时操作,阻塞了其他客户端的响应,哪怕其他客户端的请求很短时间就能处理完毕,也必须排队等待。采用流水线线程池避免了这个问题。每个客户端把需要做的操作进行粒度化,在一个环形的队列中,线程池对单个客户端,每次仅处理一个粒度单位的任务。单个粒度单位完成后,该客户端的剩余任务便被重新插入到队列尾部。这个机制保证了客户端的整体延迟较小。 3、 服务集群管理模块。该模块使用了网络传输模块、任务流水线模块的功能,实现了跨进程的服务器ßà服务器链路。在高速局域网中,连接是快速、稳定的。因此,该模块被设计成一种星型无中心网络。任意新增服务器节点选择现有服务器集群中的任意一个节点,接入后,通过广播自动与其他服务器节点建立点对点连接。本模块只是提供一个服务器到服务器的通信隧道,不负责具体通信内容的解译。对传输内容的控制,由具体应用决定。 4、 数据库管理模块。该模块基于Qt的插件式数据库封装QtSql。数据库被作为资源管理,支持在多线程的条件下,使用数据库资源。 5、 框架界面。尽管常见的服务运行时表现为一个后台进程,但为了更好的演示服务器的功能,避免繁琐的配置,还是需要一个图形界面来显示状态、设置参数。本范例中,界面负责轮训服务器的各个状态,并设置参数。设置好的参数被存储在一个ini文件中,并在服务开启时加载。 6、应用专有部分模块。上述1-4共四个主要模块均是通用的。他们互相之间没有形成联系,仅仅是作为一种资源存在于程序的运行时(Runtime)之中。应用专有部分模块根据具体任务需求,灵活的使用上述资源,以实现功能。在范例代码中,实现了一种点对点的转发机制。演示者虚拟出一些工业设备,以及一些操作员使用的客户端软件。设备与客户端软件在成功认证并登录后,需要交换数据。改变这个模块的代码,即可实现自己的功能。
【实例截图】
【核心代码】
4744300845164069363.zip
└── zpserver
├── Certs
│   ├── demoCA
│   │   ├── cacert.pem
│   │   ├── crlnumber
│   │   ├── index.txt
│   │   ├── index.txt.attr
│   │   ├── private
│   │   │   └── cakey.pem
│   │   └── serial
│   ├── localhost
│   │   ├── ca_cert.pem
│   │   ├── svr_cert.pem
│   │   └── svr_privkey.pem
│   ├── openssl_cert_make_cmd.txt
│   └── openssl.exe
├── DatabaseMod
│   ├── readme.txt
│   └── smartlink_svr.sqlite
├── FunctionalClientTest
│   ├── FunctionalClientTest.pro
│   ├── main.cpp
│   ├── maindialog.cpp
│   ├── maindialog.h
│   ├── maindialog.ui
│   ├── qghtcpclient.cpp
│   └── qghtcpclient.h
├── LICENSE
├── QTcpClientTest
│   ├── main.cpp
│   ├── qghtcpclient.cpp
│   ├── qghtcpclient.h
│   ├── qtcpclienttest.cpp
│   ├── qtcpclienttest.h
│   ├── QTcpClientTest.pro
│   ├── qtcpclienttest.qrc
│   ├── qtcpclienttest.ui
│   └── Resources
│   ├── 0062.png
│   ├── 0098.png
│   ├── 010-3.png
│   ├── 0104.png
│   ├── 0109.png
│   ├── 0126.png
│   ├── 019-1.png
│   ├── 019-3.png
│   ├── 033-1.png
│   ├── 049-1.png
│   ├── 0_9.png
│   ├── 10-3.png
│   ├── 165c, 180c.png
│   ├── 19-1.png
│   ├── 27_Martin.png
│   ├── 3018.png
│   ├── 37.png
│   ├── 3floppy_mount-1.png
│   ├── 3floppy_mount-2.png
│   ├── 3floppy_mount-3.png
│   ├── 3floppy_mount.png
│   ├── 3floppy_unmount-1.png
│   ├── 3floppy_unmount-2.png
│   ├── 3floppy_unmount-3.png
│   ├── 3floppy_unmount-4.png
│   ├── 3floppy_unmount.png
│   ├── 4003.png
│   ├── 4011.png
│   ├── 4013.png
│   ├── 4018.png
│   ├── 4021.png
│   ├── _40Icon Silver Reverse.png
│   ├── A-1 009.png
│   ├── Alienware (13).png
│   ├── Alienware (27).png
│   ├── Alienware (28).png
│   ├── Alienware (29).png
│   ├── Backup-1.png
│   ├── BackUp-4.png
│   ├── Backup drive.png
│   ├── Battery (1).png
│   ├── Battery Charged.png
│   ├── Battery -No charge.png
│   ├── Blizzard17.png
│   ├── bluetooth256.png
│   ├── Burn CD-1.png
│   ├── cn10.png
│   ├── cn11.png
│   ├── cn12.png
│   ├── cn13.png
│   ├── cn1.png
│   ├── cn2.png
│   ├── cn3.png
│   ├── cn4.png
│   ├── cn5.png
│   ├── cn6.png
│   ├── cn7.png
│   ├── cn8.png
│   ├── cn9.png
│   ├── coffee.png
│   ├── Color, Blueberry.png
│   ├── Color, Bondi-1.png
│   ├── Color, Bondi.png
│   ├── Color Classic Green.png
│   ├── Color Classic, Performa 250, 275.png
│   ├── Color Classic.png
│   ├── Color, Grape.png
│   ├── Color, Graphite.png
│   ├── Color, Indigo.png
│   ├── Color, Lemon.png
│   ├── Color, Lime.png
│   ├── Color, Ruby.png
│   ├── Color, Sage.png
│   ├── Color, Strawberry.png
│   ├── Color, Tangerine.png
│   ├── Color, Titanium.png
│   ├── Crystal_folder09.png
│   ├── Crystal_folder10.png
│   ├── Crystal_folder18.png
│   ├── Crystal_folder19.png
│   ├── Digital Image Bmp.png
│   ├── DimageViewer.png
│   ├── Folder Graphite-1.png
│   ├── Folder Online aqua.png
│   ├── hanukkah_03.png
│   ├── +_Sign_Alt.png
│   ├── +_Sign.png
│   ├── terminalserver.png
│   └── Thumbs.db
├── README.md
├── ZoomPipeline_FuncSvr
│   ├── cluster
│   │   ├── cross_svr_messages.h
│   │   ├── zp_clusternode.cpp
│   │   ├── zp_clusternode.h
│   │   ├── zp_clusterterm.cpp
│   │   └── zp_clusterterm.h
│   ├── database
│   │   ├── databaseresource.cpp
│   │   └── databaseresource.h
│   ├── dialogaddressinput.cpp
│   ├── dialogaddressinput.h
│   ├── dialogaddressinput.ui
│   ├── main.cpp
│   ├── network
│   │   ├── zp_netlistenthread.cpp
│   │   ├── zp_netlistenthread.h
│   │   ├── zp_net_threadpool.cpp
│   │   ├── zp_net_threadpool.h
│   │   ├── zp_nettransthread.cpp
│   │   ├── zp_nettransthread.h
│   │   ├── zp_tcpclient.cpp
│   │   ├── zp_tcpclient.h
│   │   ├── zp_tcpserver.cpp
│   │   └── zp_tcpserver.h
│   ├── pipeline
│   │   ├── zp_pipeline.cpp
│   │   ├── zp_pipeline.h
│   │   ├── zp_pltaskbase.cpp
│   │   ├── zp_pltaskbase.h
│   │   ├── zp_plworkingthread.cpp
│   │   └── zp_plworkingthread.h
│   ├── resource.qrc
│   ├── Resources
│   │   ├── 0062.png
│   │   ├── 0098.png
│   │   ├── 010-3.png
│   │   ├── 0104.png
│   │   ├── 0109.png
│   │   ├── 0126.png
│   │   ├── 019-1.png
│   │   ├── 019-3.png
│   │   ├── 033-1.png
│   │   ├── 049-1.png
│   │   ├── 0_9.png
│   │   ├── 10-3.png
│   │   ├── 165c, 180c.png
│   │   ├── 19-1.png
│   │   ├── 27_Martin.png
│   │   ├── 3018.png
│   │   ├── 37.png
│   │   ├── 3floppy_mount-1.png
│   │   ├── 3floppy_mount-2.png
│   │   ├── 3floppy_mount-3.png
│   │   ├── 3floppy_mount.png
│   │   ├── 3floppy_unmount-1.png
│   │   ├── 3floppy_unmount-2.png
│   │   ├── 3floppy_unmount-3.png
│   │   ├── 3floppy_unmount-4.png
│   │   ├── 3floppy_unmount.png
│   │   ├── 4003.png
│   │   ├── 4011.png
│   │   ├── 4013.png
│   │   ├── 4018.png
│   │   ├── 4021.png
│   │   ├── _40Icon Silver Reverse.png
│   │   ├── A-1 009.png
│   │   ├── Alienware (13).png
│   │   ├── Alienware (27).png
│   │   ├── Alienware (28).png
│   │   ├── Alienware (29).png
│   │   ├── Backup-1.png
│   │   ├── BackUp-4.png
│   │   ├── Backup drive.png
│   │   ├── Battery (1).png
│   │   ├── Battery Charged.png
│   │   ├── Battery -No charge.png
│   │   ├── Blizzard17.png
│   │   ├── bluetooth256.png
│   │   ├── Burn CD-1.png
│   │   ├── cn10.png
│   │   ├── cn11.png
│   │   ├── cn12.png
│   │   ├── cn13.png
│   │   ├── cn1.png
│   │   ├── cn2.png
│   │   ├── cn3.png
│   │   ├── cn4.png
│   │   ├── cn5.png
│   │   ├── cn6.png
│   │   ├── cn7.png
│   │   ├── cn8.png
│   │   ├── cn9.png
│   │   ├── coffee.png
│   │   ├── Color, Blueberry.png
│   │   ├── Color, Bondi-1.png
│   │   ├── Color, Bondi.png
│   │   ├── Color Classic Green.png
│   │   ├── Color Classic, Performa 250, 275.png
│   │   ├── Color Classic.png
│   │   ├── Color, Grape.png
│   │   ├── Color, Graphite.png
│   │   ├── Color, Indigo.png
│   │   ├── Color, Lemon.png
│   │   ├── Color, Lime.png
│   │   ├── Color, Ruby.png
│   │   ├── Color, Sage.png
│   │   ├── Color, Strawberry.png
│   │   ├── Color, Tangerine.png
│   │   ├── Color, Titanium.png
│   │   ├── Crystal_folder09.png
│   │   ├── Crystal_folder10.png
│   │   ├── Crystal_folder18.png
│   │   ├── Crystal_folder19.png
│   │   ├── Digital Image Bmp.png
│   │   ├── DimageViewer.png
│   │   ├── Folder Graphite-1.png
│   │   ├── Folder Online aqua.png
│   │   ├── hanukkah_03.png
│   │   ├── +_Sign_Alt.png
│   │   ├── +_Sign.png
│   │   └── terminalserver.png
│   ├── smartlink
│   │   ├── st_clientnode_app_imp.cpp
│   │   ├── st_clientnode_applayer.cpp
│   │   ├── st_clientnode_applayer.h
│   │   ├── st_clientnode_basetrans.cpp
│   │   ├── st_clientnode_basetrans.h
│   │   ├── st_client_table.cpp
│   │   ├── st_client_table.h
│   │   ├── st_cross_svr_msg.h
│   │   ├── st_cross_svr_node.cpp
│   │   ├── st_cross_svr_node.h
│   │   ├── st_message.h
│   │   └── st_msg_applayer.h
│   ├── ZoomPipeline_FuncSvr.pro
│   ├── ZoomPipeline_FuncSvr_zh_CN.ts
│   ├── zpmainframe.cpp
│   ├── zpmainframe.h
│   └── zpmainframe.ui
└── zoomPipeline.pro

16 directories, 253 files

标签:

实例下载地址

基于Qt的多线程流水线异步服务器稳定版.zip

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

发表评论

(您的评论需要经过审核才能显示)

查看所有0条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警