一种基于Qt的可伸缩的全异步C/S架构server实现(一) 综述
本文向大家介绍一种基于Qt的伸缩TCP服务实现。该实现针对C/Sclient-服务集群应用需求而搭建。
连接监听、传输数据、数据处理均在独立的线程池中进行,依据特定任务不同,可安排负责监听、传输、处理的线程数目,从而在高传输负荷、高计算符合上达成取舍。数据处理採用流水线结构。以避免少量客户的密集计算请求影响其它client的处理。
本文相应的代码符合LGPL协议,可直接从https://github.com/goldenhawking/zpserver下载.
也可从http://download.csdn.net/detail/goldenhawking/7461157 下载
一、综述
在很多行业应用中。client-服务架构不可替代。
在client-服务架构下,服务扮演着重要的角色。
本文旨在介绍一种较为通用的服务实现形式。这个形式能够依据详细应用需求灵活配置。从而降低反复开发的时间。该服务实现至少支持下列两种需求。
第一类是转发型服务,主要负责沟通两个client之间的通信,本身不做复杂的处理。这样的服务一般要承受密集的连接,在某些应用中。还要承受沉重的传输负荷。典型的包含即时通信、两个内网之间的视频通信等。
第二类是计算型服务,主要负责接收client的原始数据。处理后把结果返回。
这样的服务一般执行在高性能server上,调用后台的并行计算、异构计算资源。处理后把结果返回给client。这些服务的client数量一般不多。但在某些应用中,当输入输出数据量大时,传输负荷也非常重。
为了满足上述两类需求,服务设计具备例如以下特点。
1、 可灵活设置监听port
2、 监听、传输、处理均在独立的线程池中执行。
3、 可依据须要。灵活设置传输、处理线程的数目。
4、 对某个单一client的处理。不会显著拖慢全部client的响应。
5、 须要支持分布式的集群服务,典型的情况是基于若干物理计算机构成的快速局域网实现进程集群。
6、 可同一时候支持SSL与普通TCP连接。
这些特点决定了本系统的架构设计。
(一)系统结构
服务由下面几个模块组成.
1、 网络传输模块。负责管理用于监听、传输的套接字,并控制数据流在不同线程中流动。
数据收发由一定规模的线程池负责,实现方法全然得益于Qt的线程事件循环。被绑定到某个Qthread上的Qobject对象。其信号-槽事件循环由该线程负责。这样,便可方便的指定某个套接字对象使用的线程。
相同,受惠于Qt的良好封装,直接支持Tcp套接字及SSL套接字。且在执行时可动态调整。(注:编译这个模块须要Qt的SSL支持,即在
configure 时增加 -openssl 选项)
2、 任务流水线模块。负责数据的处理。
在计算密集型的应用中,数据处理负荷较重,须要和网络传输划分开。
基于普通线程池的处理模式,也存在队列堵塞的问题——若干个client请求的耗时操作,堵塞了其它client的响应。哪怕其它client的请求非常短时间就能处理完毕。也必须排队等待。採用流水线线程池避免了这个问题。每一个client把须要做的操作进行粒度化,在一个环形的队列中,线程池对单个client,每次仅处理一个粒度单位的任务。单个粒度单位完毕后。该client的剩余任务便被又一次插入到队列尾部。这个机制保证了client的总体延迟较小。
3、 服务集群管理模块。该模块使用了网络传输模块、任务流水线模块的功能,实现了跨进程的serverßàserver链路。
在快速局域网中,连接是快速、稳定的。因此,该模块被设计成一种星型无中心网络。随意新增server节点选择现有server集群中的随意一个节点。接入后。通过广播自己主动与其它server节点建立点对点连接。本模块仅仅是提供一个server到server的通信隧道,不负责详细通信内容的解译。对传输内容的控制。由详细应用决定。
4、 数据库管理模块。
该模块基于Qt的插件式数据库封装QtSql。
数据库被作为资源管理。支持在多线程的条件下。使用数据库资源。
5、 框架界面。虽然常见的服务执行时表现为一个后台进程。但为了更好的演示server的功能。避免繁琐的配置,还是须要一个图形界面来显示状态、设置參数。
本范例中,界面负责轮训server的各个状态。并设置參数。设置好的參数被存储在一个ini文件里,并在服务开启时载入。
6、应用专有部分模块。上述1-4共四个主要模块均是通用的。
他们互相之间没有形成联系,不过作为一种资源存在于程序的执行时(Runtime)之中。
应用专有部分模块依据详细任务需求,灵活的使用上述资源,以实现功能。在范例代码中,实现了一种点对点的转发机制。演示者虚拟出一些工业设备。以及一些操作员使用的client软件。设备与client软件在成功认证并登录后,须要交换数据。改变这个模块的代码,就可以实现自己的功能。
(二) 设计性能
|
项目 |
指标说明 |
指标值 |
备注 |
|
支持的连接类型 |
取决于Qt的支持类型 |
SSL和Plain |
执行时同一时候支持两类. |
|
协议 |
Ipv4 TCP , IPV6 Tcp |
||
|
设计单进程连接数 |
在4\8传输线程配置下计算 |
1024\2048 |
取决于实际机器的性能和任务形式. |
|
设计集群规模 |
星型集群的规模受到节点数影响。 |
100节点,9900个跨server连接。 |
局域网中的连接数为节点数*(节点数-1)。 |
|
设计总用户规模 |
100节点、每节点2048个用户 |
20万 |
下一篇文章,将開始介绍各个模块的设计思路。先给出范例代码的測试编译环境:
1、Ubuntu 14.04 + Qt5.2.1 openSSL 自编译版
2、Win 7 x64 + VCExpress 2013 x64, x86 + Qt 5.2.1 openSSL自编译版
3、Win XP x86 + VC2010Express x86 + Qt5.2.1openSSL自编译版
主要界面:
一种基于Qt的可伸缩的全异步C/S架构server实现(一) 综述的更多相关文章
- 一种基于Qt的可伸缩的全异步C/S架构服务器实现(一) 综述
本文向大家介绍一种基于Qt的伸缩TCP服务实现.该实现针对C/S客户端-服务集群应用需求而搭建.连接监听.数据传输.数据处理均在独立的线程池中进行,根据特定任务不同,可安排负责监听.传输.处理的线程数 ...
- 一种基于Qt的可伸缩的全异步C/S架构server实现(二) 网络传输
二.网络传输模块 模块相应代码命名空间 (namespace ZPNetwork) 模块相应代码存储目录 (\ZoomPipeline_FuncSvr\network) 2.1 模块结构 ...
- 一种基于Qt的可伸缩的全异步C/S架构server实现(五) 单层无中心集群
五.单层无中心集群 对40万用户规模以内的server.使用星形的无中心连接是较为简便的实现方式.分布在各个物理server上的服务进程共同工作.每一个进程承担若干连接.为了实现这个功能,须要解决几个 ...
- 一种基于Qt的可伸缩的全异步C/S架构服务器实现(流浪小狗,六篇,附下载地址)
本文向大家介绍一种基于Qt的伸缩TCP服务实现.该实现针对C/S客户端-服务集群应用需求而搭建.连接监听.数据传输.数据处理均在独立的线程池中进行,根据特定任务不同,可安排负责监听.传输.处理的线程数 ...
- 一种基于C51单片机的非抢占式的操作系统架构
摘 要:从Keil C51的内存空间管理方式入手,着重讨论实时操作系统在任务调度时的重入问题,分析一些解决重入的基本方式与方法:分析实时操作系统任务调度的占先性,提出非占先的任务调度是能更适合于Kei ...
- 利用ZoomPipeline迅速实现基于线程池的全异步TCP点对点代理
在博文<一种基于Qt的可伸缩的全异步C/S架构服务器实现>中提到的高度模块化的类可以进行任意拆解,实现非常灵活的功能.今天,我们来看一看一个公司局域网访问英特网云服务器的点对点代理例子.代 ...
- 【Qt编程】基于Qt的词典开发系列<十四>自动补全功能
最近写了一个查单词的类似有道词典的软件,里面就有一个自动补全功能(即当你输入一个字母时,就会出现几个候选项).这个自动补全功能十分常见,百度搜索关键词时就会出现.不过它们这些补全功能都是与你输入的进行 ...
- 基于Qt有限状态机的一种实现方式和完善的人工智能方法
基于Qt有限状态机的一种实现方式和完善的人工智能方法 人工智能在今年是一个非常火的方向,当然了.不不过今年,它一直火了非常多年,有关人工智能的一些算法层出不穷.人工智能在非常多领域都有应用,就拿我熟悉 ...
- 【Qt编程】基于Qt的词典开发系列--后序
从去年八月份到现在,总算完成了词典的编写以及相关技术文档的编辑工作.从整个过程来说,文档的编写比程序的实现耗费的时间更多.基于Qt的词典开发系列文章,大致包含了在编写词典软件过程中遇到的技术重点与难点 ...
随机推荐
- Qt Chart 5.7.0 傻瓜安装教程
前提 qtchart 里的README文件(注意红色标记处)(本人翻译不行.多多见谅,也可以在评论里纠正( ⊙ o ⊙ )) --------------- Qt Charts 5.7.0 ----- ...
- java 访问 mysql 数据库的字符集设置
mysql是在linux下,java代码通过jdbc访问总是中文乱码.做过如下尝试: 1)修改 mysql的 my.cnf文件,设置 default-character-set等参数 2) 利用alt ...
- Python关键字yield详解以及Iterable 和Iterator区别
迭代器(Iterator) 为了理解yield是什么,首先要明白生成器(generator)是什么,在讲生成器之前先说说迭代器(iterator),当创建一个列表(list)时,你可以逐个的读取每一项 ...
- android Bitmap围绕一个点进行旋转
在项目中需要使用定位功能,也就是一个点围绕一个圆心进行旋转,查看了canvas的函数也就只有一个 canvas.drawBitmap(bitmap, matrix, paint)通过使用Matrix来 ...
- 用Swift完成不同View Controller之间的切换
之前用objective-c开发时,页面之间的切换很容易.其实用swift没有很大的变化,如果你是用storyboard完成的界面,基本上是同样的方式,只不过在代码部分写成swift风格的就行了. 今 ...
- android jsonarray
Json数组是子元素的有序集合,每个子元素都有一个下标,可以根据下标操纵Json数组的子元素.类JsonArray是bantouyan-json库对Json数组的抽象,提供操纵Json数组的各种方法. ...
- 合并k个已排序的链表 分类: leetcode 算法 2015-07-09 17:43 3人阅读 评论(0) 收藏
最先想到的是把两个linked lists 合并成一个. 这样从第一个开始一个一个吞并,直到所有list都被合并. class ListNode:# Definition for singly-lin ...
- arm:启动代码判断是从nand启动还是从norflash启动,拷贝程序到内存的过程
一.nand启动和nor启动:[1] CPU从0x00000000位置开始运行程序. 1.nand启动: 如果将S3C2440配置成从NANDFLASH启动(将开发板的启动开关拔到nand端,此时OM ...
- java io学习记录(路径分隔符)
java路径分隔符(路径表示) path="E:\\xp\\test\\2.jpg"; path="E:/xp/test/2.jpg"; path=" ...
- javascript每日一练(十三)——运动实例
一.图片放大缩小 <!doctype html> <html> <head> <meta charset="utf-8"> < ...