项目实战:Qt并发服务器通讯,受同一时刻最大线程数限制(笔者本本同一时刻600多)

简介: 项目实战:Qt并发服务器通讯,受同一时刻最大线程数限制(笔者本本同一时刻600多)

若该文为原创文章,转载请注明原文出处

本文章博客地址:https://blog.csdn.net/qq21497936/article/details/79955907

各位读者,知识无穷而人力有穷,要么改需求,要么找专业人士,要么自己研究

红胖子(红模仿)的博文大全:开发技术集合(包含Qt实用技术、树莓派、三维、OpenCV、OpenGL、ffmpeg、OSG、单片机、软硬结合等等)持续更新中…(点击传送门)

Qt开发专栏:项目实战(点击传送门)

 

需求

       预言项目需要写个qt服务器,终端与qt服务器完成socket通讯,因存在多个设备,单个传输文件大小比较大,所以做多线程并发

 

补充(2021年04月05日)

本文章的初衷,是记录服务器的QTcpServer遇到新的连接之后可以把QTcpSocket分发到不同的线程去处理,使用常规的方式,新QTcpSocket是在QTcpServer的线程里处理的。

 

实现原理

       客户端:固定client的线程数量,单个线程按照设置的间隔不断发送数据给服务器,并接收服务器的线程指针地址。

       服务端:主线程为TcpServer,当有一个新连接的时候,会new一个线程处理该新连接socket,接收数据后发送处理该socket的线程地址。

 

相关博客

实用技巧:阿里云服务器建立公网物联网服务器(解决阿里云服务器端口,公网连接不上的问题)

Qt开发技术:QWebSocket客户端、服务端介绍与开发

Qt开发技术:mqtt介绍、QtMqtt编译和开发环境搭

Mqtt开发笔记:Mqtt服务器搭建

项目实战:Qt并发服务器通讯,受同一时刻最大线程数限制(笔者本本同一时刻600多)

Qt实用技巧:80显示超大显示拼接(十台服务器,每台八路摄像头)方案和Demo

 

Demo测试工具

       CSDN免积分下载地址:https://download.csdn.net/download/qq21497936/10351463

QQ群:1047134658(点击“文件”搜索“tcpClientAndServerTools”,群内与博文同步更新所有可开源的源码模板)

 

受限说明

       1.同一时刻该应用最大限度的线程数,如果超过则仍然会new,然后打印失败,但是仍然会跑new线程的构造函数;

       2.下载源码可以将客户端的时间间隔改下,同时运行线程数增大,IDE的qDebug可以看到停止后,index没有归零,仔细翻阅调试信息,可以找到“错误”,此条,以便读者自己可以使用源码尝试该问题。

       3.写服务器时,应对最大线程数做限制,此Demo只是项目过程中关键功能的记录,未做处理。

 

实现截图

图片.png

 

关键代码

客户端

单个线程socket请求代码 TcpClientThread.h

#ifndef TCPCLIENTTHREAD_H
#define TCPCLIENTTHREAD_H
#include <QThread>
#include <QTcpSocket>
#include <QByteArray>
#include <QHostAddress>
/************************************************************\
 * 类名:TcpClientThread
 * 描述:线程循环使用QTcpClient连接服务器发送数据、接收数据、断开
 * 信号:
 *      recvMsg() - 收到客户端的的数据
 * 函数:
 *      TcpClientThread() - 传入ip,port,间隔时间(ms)
 *      start() - 开启线程
 *      stop() - 停止
 * 作者:红模仿      QQ:21497936
 *      日期          版本号                描述
 * 2018年04月13日     v1.0.0       指定间隔向指定ip和port发送数据、接收数据
\************************************************************/
class TcpClientThread : public QThread
{
    Q_OBJECT
public:
    explicit TcpClientThread(QString ip, quint16 port, int ms=1000, QObject *parent = nullptr);
signals:
    void recvData(QByteArray data);
public slots:
    void stop();
protected:
    void run();
private:
    QTcpSocket *_pTcpSocket;
    QString _ip;
    quint16 _port;
    bool _running;
    int _ms;
};
#endif // TCPCLIENTTHREAD_H

服务器端

newConnection线程处理代码Thread.h

#ifndef THREAD_H
#define THREAD_H
#include <QObject>
#include <QThread>
#include <QTcpSocket>
#include <QDebug>
#include <QMutexLocker>
/************************************************************\
 * 类名:Thread
 * 描述:服务器端,线程处理新连接的socket
 * 信号:
 *      Thread() - 传入socket描述符,注意类型是qintptr,不是int
 *      error() - 错误信息
 *      recvMsg() - 收到客户端的的数据
 * 函数:
 *      TcpClientThread() - 传入ip,port,间隔时间(ms)
 *      start() - 开启线程
 *      stop() - 停止
 * 作者:红模仿      QQ:21497936
 *      日期          版本号                描述
 * 2018年04月13日     v1.0.0          处理收到的信息
\************************************************************/
#define DEBUG qDebug()<<__FILE__<<__LINE__<<__FUNCTION__<<"current thread:"<<QThread::currentThread()
class Thread : public QThread
{
    Q_OBJECT
public:
    explicit Thread(qintptr socketDescriptor, QThread *parent = nullptr);
    ~Thread();
signals:
    void error(QString errorString);
    void recvMsg(QString msg);
protected slots:
    void readyRead();
protected:
    void run();
private:
    qintptr _socketDescriptor;
    QTcpSocket *_pTcpSoscket;
    static int _count;
    static QMutex _mutex;
    int _index;
};
#endif // THREAD_Hsa

 

若该文为原创文章,转载请注明原文出处

本文章博客地址:https://blog.csdn.net/qq21497936/article/details/79955907


相关实践学习
消息队列RocketMQ版:基础消息收发功能体验
本实验场景介绍消息队列RocketMQ版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
2月前
|
并行计算 Java 数据处理
SpringBoot高级并发实践:自定义线程池与@Async异步调用深度解析
SpringBoot高级并发实践:自定义线程池与@Async异步调用深度解析
235 0
|
1月前
|
安全
List并发线程安全问题
【10月更文挑战第21天】`List` 并发线程安全问题是多线程编程中一个非常重要的问题,需要我们认真对待和处理。只有通过不断地学习和实践,我们才能更好地掌握多线程编程的技巧和方法,提高程序的性能和稳定性。
198 59
|
1月前
|
安全 Java
线程安全的艺术:确保并发程序的正确性
在多线程环境中,确保线程安全是编程中的一个核心挑战。线程安全问题可能导致数据不一致、程序崩溃甚至安全漏洞。本文将分享如何确保线程安全,探讨不同的技术策略和最佳实践。
41 6
|
1月前
|
安全 Java 开发者
Java 多线程并发控制:深入理解与实战应用
《Java多线程并发控制:深入理解与实战应用》一书详细解析了Java多线程编程的核心概念、并发控制技术及其实战技巧,适合Java开发者深入学习和实践参考。
58 6
|
1月前
|
存储 安全 Java
Java多线程编程中的并发容器:深入解析与实战应用####
在本文中,我们将探讨Java多线程编程中的一个核心话题——并发容器。不同于传统单一线程环境下的数据结构,并发容器专为多线程场景设计,确保数据访问的线程安全性和高效性。我们将从基础概念出发,逐步深入到`java.util.concurrent`包下的核心并发容器实现,如`ConcurrentHashMap`、`CopyOnWriteArrayList`以及`BlockingQueue`等,通过实例代码演示其使用方法,并分析它们背后的设计原理与适用场景。无论你是Java并发编程的初学者还是希望深化理解的开发者,本文都将为你提供有价值的见解与实践指导。 --- ####
|
1月前
|
存储 设计模式 分布式计算
Java中的多线程编程:并发与并行的深度解析####
在当今软件开发领域,多线程编程已成为提升应用性能、响应速度及资源利用率的关键手段之一。本文将深入探讨Java平台上的多线程机制,从基础概念到高级应用,全面解析并发与并行编程的核心理念、实现方式及其在实际项目中的应用策略。不同于常规摘要的简洁概述,本文旨在通过详尽的技术剖析,为读者构建一个系统化的多线程知识框架,辅以生动实例,让抽象概念具体化,复杂问题简单化。 ####
|
2月前
|
Java
【编程进阶知识】揭秘Java多线程:并发与顺序编程的奥秘
本文介绍了Java多线程编程的基础,通过对比顺序执行和并发执行的方式,展示了如何使用`run`方法和`start`方法来控制线程的执行模式。文章通过具体示例详细解析了两者的异同及应用场景,帮助读者更好地理解和运用多线程技术。
36 1
|
3月前
|
网络协议 C语言
C语言 网络编程(十四)并发的TCP服务端-以线程完成功能
这段代码实现了一个基于TCP协议的多线程服务器和客户端程序,服务器端通过为每个客户端创建独立的线程来处理并发请求,解决了粘包问题并支持不定长数据传输。服务器监听在IP地址`172.17.140.183`的`8080`端口上,接收客户端发来的数据,并将接收到的消息添加“-回传”后返回给客户端。客户端则可以循环输入并发送数据,同时接收服务器回传的信息。当输入“exit”时,客户端会结束与服务器的通信并关闭连接。
|
3月前
|
数据采集 消息中间件 并行计算
进程、线程与协程:并发执行的三种重要概念与应用
进程、线程与协程:并发执行的三种重要概念与应用
77 0
|
3月前
|
C语言
C语言 网络编程(九)并发的UDP服务端 以线程完成功能
这是一个基于UDP协议的客户端和服务端程序,其中服务端采用多线程并发处理客户端请求。客户端通过UDP向服务端发送登录请求,并根据登录结果与服务端的新子线程进行后续交互。服务端在主线程中接收客户端请求并创建新线程处理登录验证及后续通信,子线程创建新的套接字并与客户端进行数据交换。该程序展示了如何利用线程和UDP实现简单的并发服务器架构。