heartbeat: add basic code.
This commit is contained in:
@@ -1,6 +1,6 @@
|
||||
cmake_minimum_required(VERSION 3.16)
|
||||
|
||||
project(frelay VERSION 0.1.4 LANGUAGES CXX)
|
||||
project(frelay VERSION 0.1.5 LANGUAGES CXX)
|
||||
set(CMAKE_CXX_STANDARD 11)
|
||||
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||
|
||||
|
||||
@@ -209,6 +209,11 @@ bool ClientCore::Send(const char* data, qint64 len)
|
||||
return true;
|
||||
}
|
||||
|
||||
bool ClientCore::IsConnect()
|
||||
{
|
||||
return connected_;
|
||||
}
|
||||
|
||||
void ClientCore::SetRemoteID(const QString& id)
|
||||
{
|
||||
GlobalData::Ins()->SetRemoteID(id);
|
||||
@@ -238,7 +243,62 @@ SocketWorker::~SocketWorker()
|
||||
|
||||
void SocketWorker::run()
|
||||
{
|
||||
// qDebug() << "SocketWorker thread:" << QThread::currentThread();
|
||||
core_->Instance();
|
||||
exec();
|
||||
}
|
||||
|
||||
HeatBeat::HeatBeat(ClientCore* core, QObject* parent) : QThread(parent), core_(core)
|
||||
{
|
||||
}
|
||||
|
||||
HeatBeat::~HeatBeat()
|
||||
{
|
||||
Stop();
|
||||
}
|
||||
|
||||
void HeatBeat::Stop()
|
||||
{
|
||||
isRun_ = false;
|
||||
}
|
||||
|
||||
void HeatBeat::run()
|
||||
{
|
||||
isRun_ = true;
|
||||
InfoMsg info;
|
||||
auto frame = core_->GetBuffer(info, FBT_SER_MSG_HEARTBEAT, "");
|
||||
while (isRun_) {
|
||||
QThread::sleep(1);
|
||||
if (!core_->IsConnect()) {
|
||||
continue;
|
||||
}
|
||||
ClientCore::syncInvoke(core_, frame);
|
||||
}
|
||||
}
|
||||
|
||||
TransBeat::TransBeat(ClientCore* core, QObject* parent) : QThread(parent), core_(core)
|
||||
{
|
||||
}
|
||||
|
||||
TransBeat::~TransBeat()
|
||||
{
|
||||
Stop();
|
||||
}
|
||||
|
||||
void TransBeat::run()
|
||||
{
|
||||
isRun_ = true;
|
||||
InfoMsg info;
|
||||
while (isRun_) {
|
||||
QThread::sleep(1);
|
||||
if (!core_->IsConnect()) {
|
||||
continue;
|
||||
}
|
||||
auto frame = core_->GetBuffer(info, FBT_SER_MSG_JUDGE_OTHER_ALIVE, core_->GetRemoteID());
|
||||
ClientCore::syncInvoke(core_, frame);
|
||||
}
|
||||
}
|
||||
|
||||
void TransBeat::Stop()
|
||||
{
|
||||
isRun_ = false;
|
||||
}
|
||||
|
||||
@@ -34,6 +34,7 @@ public:
|
||||
void Disconnect();
|
||||
bool Send(QSharedPointer<FrameBuffer> frame);
|
||||
bool Send(const char* data, qint64 len);
|
||||
bool IsConnect();
|
||||
template <typename T> bool Send(const T& info, FrameBufferType type, const QString& tid)
|
||||
{
|
||||
auto f = GetBuffer<T>(info, type, tid);
|
||||
@@ -104,6 +105,7 @@ public:
|
||||
LocalFile localFile_;
|
||||
};
|
||||
|
||||
// Socket Worker Thread
|
||||
class SocketWorker : public QThread
|
||||
{
|
||||
Q_OBJECT
|
||||
@@ -119,4 +121,44 @@ private:
|
||||
ClientCore* core_{};
|
||||
};
|
||||
|
||||
// HeatBeat to Server
|
||||
class HeatBeat : public QThread
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
HeatBeat(ClientCore* core, QObject* parent = nullptr);
|
||||
~HeatBeat() override;
|
||||
|
||||
public:
|
||||
void Stop();
|
||||
|
||||
protected:
|
||||
void run() override;
|
||||
|
||||
private:
|
||||
bool isRun_{false};
|
||||
ClientCore* core_{};
|
||||
};
|
||||
|
||||
// judge send client is alive or not when downloading
|
||||
class TransBeat : public QThread
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
TransBeat(ClientCore* core, QObject* parent = nullptr);
|
||||
~TransBeat() override;
|
||||
|
||||
public:
|
||||
void Stop();
|
||||
|
||||
protected:
|
||||
void run() override;
|
||||
|
||||
private:
|
||||
bool isRun_{false};
|
||||
ClientCore* core_{};
|
||||
};
|
||||
|
||||
#endif // CLIENTCORE_H
|
||||
@@ -14,10 +14,13 @@ constexpr quint32 CHUNK_BUF_SIZE = 1 * 1024 * 1024;
|
||||
// Contents beyond 30 are only forwarded.
|
||||
enum FrameBufferType : uint16_t {
|
||||
FBT_NONE = 0,
|
||||
FBT_SER_MSG_HEARTBEAT,
|
||||
FBT_SER_MSG_ASKCLIENTS,
|
||||
FBT_SER_MSG_YOURID,
|
||||
FBT_SER_MSG_RESPONSE,
|
||||
FBT_SER_MSG_FORWARD_FAILED,
|
||||
FBT_SER_MSG_JUDGE_OTHER_ALIVE,
|
||||
FBT_SER_MSG_OFFLINE,
|
||||
FBT_CLI_BIN_FILEDATA = 31,
|
||||
FBT_CLI_MSG_COMMUNICATE,
|
||||
FBT_CLI_ASK_DIRFILE,
|
||||
|
||||
@@ -4,6 +4,7 @@
|
||||
#include <QDebug>
|
||||
|
||||
#include "InfoClient.h"
|
||||
#include "InfoMsg.h"
|
||||
#include "InfoPack.hpp"
|
||||
|
||||
Server::Server(QObject* parent) : QTcpServer(parent)
|
||||
@@ -174,7 +175,36 @@ void Server::replyRequest(QSharedPointer<ClientInfo> client, QSharedPointer<Fram
|
||||
replyFrame->tid = client->id;
|
||||
replyFrame->data = clientList;
|
||||
auto ret = sendData(client->socket, replyFrame);
|
||||
qDebug() << "Reply client list:" << client->id << ret;
|
||||
break;
|
||||
}
|
||||
case FBT_SER_MSG_HEARTBEAT: {
|
||||
QSharedPointer<ClientInfo> cl;
|
||||
{
|
||||
QReadLocker locker(&rwLock_);
|
||||
if (clients_.count(frame->fid)) {
|
||||
cl = clients_.value(frame->fid);
|
||||
}
|
||||
}
|
||||
if (cl) {
|
||||
cl->connectTime = QDateTime::currentDateTime().toMSecsSinceEpoch() / 1000;
|
||||
}
|
||||
break;
|
||||
}
|
||||
case FBT_SER_MSG_JUDGE_OTHER_ALIVE: {
|
||||
QSharedPointer<ClientInfo> cl;
|
||||
{
|
||||
QReadLocker locker(&rwLock_);
|
||||
if (clients_.count(frame->tid)) {
|
||||
cl = clients_.value(frame->tid);
|
||||
}
|
||||
}
|
||||
if (!cl) {
|
||||
auto rf = QSharedPointer<FrameBuffer>::create();
|
||||
rf->type = FBT_SER_MSG_OFFLINE;
|
||||
rf->fid = id_;
|
||||
rf->tid = frame->fid;
|
||||
sendData(client->socket, rf);
|
||||
}
|
||||
break;
|
||||
}
|
||||
default:
|
||||
@@ -199,7 +229,6 @@ bool Server::sendData(QTcpSocket* socket, QSharedPointer<FrameBuffer> frame)
|
||||
|
||||
void Server::monitorClients()
|
||||
{
|
||||
// qint64 now = QDateTime::currentSecsSinceEpoch();
|
||||
qint64 now = QDateTime::currentDateTime().toMSecsSinceEpoch() / 1000;
|
||||
QWriteLocker locker(&rwLock_);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user