Qt应用Redis实现消息队列

类似BS模式,客户端发送任务请求给服务端,服务端将处理结果返回给客户端。 redis负责消息的存储和转发。

仿真病人挂号看病,Patient进程进行挂号,Doctor进程进行看病 ,程序代码如下:

Patient 

Patient.h:

#include <QObject>

class QRedis;

class Patient : public QObject
{
	Q_OBJECT

public:
	Patient(QObject *parent = nullptr);
	~Patient();

public slots:
	void pushTask(); //push任务

private:
	void popResult(); //pop结果
	QRedis * m_redis;
};
Patient.cpp

#include "patient.h"
#include "qredis.h"
#include <QTimer>
#include <QEventLoop>
#include <QThread>

static const QString KEYTASK = "MARKTASK";
static const QString KEYRESULT = "MARKRESULT";

Patient::Patient(QObject *parent)
	: QObject(parent)
{
	//初始化通道
	m_redis = new QRedis(this);
	m_redis->connectHost("127.0.0.1", 6379);
	m_redis->auth("1234");

	qDebug() << "client thread id :" << int(QThread::currentThreadId());

	//轮询任务
	QTimer * timer = new QTimer(this);
	connect(timer, &QTimer::timeout, this, &Patient::popResult);
	timer->start(20);

	m_redis->del(KEYRESULT);
	m_redis->del(KEYTASK);
	pushTask();
}

Patient::~Patient()
{
}

void Patient::pushTask()
{
	static int i = 0;
	QString task = QStringLiteral("%1号,姓名:%2,状态:%3").arg(++i).arg(QStringLiteral("病人%1").arg(i)).arg(QStringLiteral("挂号"));
	qDebug() <<"========================================================\n\n"<< task;
	qDebug() << "thread id :" << int(QThread::currentThreadId());
	qint64 ret = m_redis->rpush(KEYTASK, task);
}

void Patient::popResult()
{
	QString state;
	QString taskData = m_redis->lpop(KEYRESULT);
	if (taskData.compare("nil", Qt::CaseInsensitive) == 0 || taskData.isEmpty())
	{
		return;
	}
	QEventLoop loop;
	QTimer::singleShot(5000, &loop, &QEventLoop::quit);
	loop.exec();
	pushTask();
}

main.cpp

#include <QtCore/QCoreApplication>
#include <QDebug>
#include <QThread>
#include "patient.h"

int main(int argc, char *argv[])
{
	QCoreApplication a(argc, argv);

	qDebug() << QString("main thread id = : %1").arg(int(QThread::currentThreadId()));

	QThread patientThread;
	Patient patient;
	patient.moveToThread(&patientThread);
	patientThread.start();
	return a.exec();
}

/Docktor/

Docktor.h

#pragma once

#include <QObject>

class QRedis;

class Docktor : public QObject
{
	Q_OBJECT

public:
	Docktor(QObject *parent = nullptr);
	~Docktor();

public slots:
	void popTask(); //pop任务

private:
	void pushResult(const QString &task); //push结果

	QRedis * m_redis;
};

Docktor.cpp

#include "docktor.h"
#include "qredis.h"
#include <QTimer>
#include <QEventLoop>
#include <QThread>

static const QString KEYTASK = "MARKTASK";
static const QString KEYRESULT = "MARKRESULT";

Docktor::Docktor(QObject *parent)
	: QObject(parent)
{
	//初始化通道
	m_redis = new QRedis(this);
	m_redis->connectHost("127.0.0.1", 6379);
	m_redis->auth("1234");

	QTimer * timer = new QTimer(this);
	connect(timer, &QTimer::timeout, this, &Docktor::popTask);
	timer->start(20);
}

Docktor::~Docktor()
{
}

void Docktor::popTask()
{
	//获取任务
	QString taskData = m_redis->lpop(KEYTASK);
	if (taskData.compare("nil", Qt::CaseInsensitive) == 0 || taskData.isEmpty())
	{
		//qDebug() <<  QString("wait..............................");
		return;
	}
	//处理任务
	pushResult(taskData);
}

void Docktor::pushResult(const QString &task)
{
	QStringList taskDatas = task.split(",");
	QString state = taskDatas.at(2);
	taskDatas.removeLast();
	taskDatas.append(QStringLiteral("状态:看病"));
	//push处理结果
	qDebug() <<"========================================================\n\n" << taskDatas.join(",");
	qDebug() << "thread id :" << int(QThread::currentThreadId());
	qint64 ret = m_redis->rpush(KEYRESULT, taskDatas.join(","));
}

main.cpp

#include <QtCore/QCoreApplication>
#include <QDebug>
#include <QThread>
#include "docktor.h"

int main(int argc, char *argv[])
{
	QCoreApplication a(argc, argv);
	qDebug() << QString("main thread id = : %1").arg(int(QThread::currentThreadId()));

	QThread docktorThread;
	Docktor docktor;
	docktor.moveToThread(&docktorThread);
	docktorThread.start();
	return a.exec();
}

/截图/










  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Spring Boot与Redis结合实现消息队列的方法如下: 1. 首先,确保你的Spring Boot项目中已经引入了Redis的依赖。 2. 创建一个消息发布者类,用于发布消息到Redis消息队列中。可以使用RedisTemplate来实现消息的发布。以下是一个示例代码: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Component; @Component public class MessagePublisher { @Autowired private RedisTemplate<String, Object> redisTemplate; public void publish(String channel, Object message) { redisTemplate.convertAndSend(channel, message); } } ``` 3. 创建一个消息订阅者类,用于监听Redis消息队列并处理接收到的消息。可以使用@RedisListener注解来实现消息的订阅。以下是一个示例代码: ```java import org.springframework.data.redis.connection.Message; import org.springframework.data.redis.connection.MessageListener; import org.springframework.stereotype.Component; @Component public class MessageSubscriber implements MessageListener { @Override public void onMessage(Message message, byte[] pattern) { String channel = new String(message.getChannel()); String body = new String(message.getBody()); // 处理接收到的消息 System.out.println("Received message: " + body + " from channel: " + channel); } } ``` 4. 在需要发布消息的地方,通过调用消息发布者类的publish方法来发布消息。以下是一个示例代码: ```java @Autowired private MessagePublisher messagePublisher; public void sendMessage(String channel, Object message) { messagePublisher.publish(channel, message); } ``` 5. 在需要订阅消息的地方,通过在消息订阅者类的方法上添加@RedisListener注解来监听指定的频道。以下是一个示例代码: ```java @RedisListener(channels = "myChannel") public void handleMessage(String message) { // 处理接收到的消息 System.out.println("Received message: " + message); } ``` 通过以上步骤,你就可以使用Spring Boot与Redis结合实现消息队列了。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值