1、写在后面
上一篇中咱们简略解说了 衰弱状态
的性能。
实际上,仅仅从效果图上看不足以理解。
所以接下来,咱们筹备好实现一个简略的 衰弱状态场景
,能力了解其弱小。
2、注释开始
首先,衰弱状态
的本质是 状态监控
,这点咱们一点要记住。
因而,咱们首先须要一个有限获取状态的 Linux 守护过程
或 Windows 服务
。
这里先简略称其为 Monitor
。
咱们的 SkeyeARS
须要 Monitor
提供所有的软硬件状态。
因而,Monitor
须要做到以下几点:
- 提供设施的软件资源监控。
而咱们次要实现的是对运行程序的监控,即所谓的 看门狗
。
所以只须要获取监控程序运行状态即可,上面是获取过程数的 Windows
实现。
int MonitorApi::getProcessCount(const QString &processName)
{
// 过程计数
static bool initialized = false;
int count = 0;
QString fileName = QFileInfo(processName).fileName();
QString fullName = QDir::toNativeSeparators(QFileInfo(processName).absoluteFilePath());
#ifdef Q_OS_WIN
if (!initialized) {
// 晋升过程权限
LUID luidTmp;
HANDLE tokenHnadle;
TOKEN_PRIVILEGES tkp;
if (OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &tokenHnadle)) {if(!LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &luidTmp)) {qDebug() << "LookupPrivilegeValue Faile! Error =" << GetLastError();
CloseHandle(tokenHnadle);
}
tkp.PrivilegeCount = 1;
tkp.Privileges[0].Luid = luidTmp;
tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
if(!AdjustTokenPrivileges(tokenHnadle, FALSE, &tkp, sizeof(tkp), NULL, NULL)) {qDebug() << "AdjustTokenPrivileges Faile! Error =" << GetLastError();
CloseHandle(tokenHnadle);
}
CloseHandle(tokenHnadle);
}
initialized = true;
}
PROCESSENTRY32 pe32;
pe32.dwSize = sizeof(PROCESSENTRY32);
// 创立过程快照句柄
HANDLE processSnapshotHandle = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
// 创立句柄失败
if (processSnapshotHandle == INVALID_HANDLE_VALUE)
return -1;
// 找第一个
bool isExist = Process32First(processSnapshotHandle, &pe32);
while(isExist) {auto name = QString::fromWCharArray(pe32.szExeFile);
// 过程名不辨别大小写
if(fileName.compare(name, Qt::CaseInsensitive) == 0) {HMODULE modules[512] = {0};
DWORD needed = 0;
TCHAR mouduleName[MAX_PATH];
BOOL is64Process;
HANDLE processHandle = OpenProcess(PROCESS_ALL_ACCESS, FALSE, pe32.th32ProcessID);
if (processHandle) {IsWow64Process(processHandle, &is64Process); // 判断是 32 位还是 64 位过程
EnumProcessModulesEx(processHandle, modules, sizeof(modules), &needed, is64Process ? LIST_MODULES_32BIT : LIST_MODULES_64BIT);
if (needed > 0) {GetModuleFileNameEx(processHandle, modules[0], mouduleName, MAX_PATH);
if (QString::fromWCharArray(mouduleName) == fullName)
count++;
}
CloseHandle(processHandle);
}
}
// 找下一个
isExist = Process32Next(processSnapshotHandle, &pe32);
}
#endif
return count;
}
- 提供机器的硬件资源监控。
所谓硬件资源,次要分为三种:
1、磁盘应用。
2、CPU 利用率。
3、内存使用率。
4、网络流量。
- 提供状态给所有须要的零碎(例如
SkeyeARS
)。
而如何将状态提供给其余零碎呢,一种想法应用音讯队列。
咱们能够将获取到的软硬件资源,封装后公布进来。
对于感兴趣的零碎,则能够按本人的须要,订阅音讯即可。
在咱们的 Monitor
中,采纳的音讯队列为:ZeroMQ
。
## 对于 SkeyeARS ##
SkeyeARS 全景 AR 加强监视系统,是视开科技开发的一款基于宽场景多路视频无缝拼接、视频实时加强、监督指标加强显示、指标主动跟踪、视频存储回放、近程数据传输和多通道全景视频同步显示等性能的综合视频 AR 加强监视系统,广泛应用于智慧交通、智慧城市、智慧机场等大场景智能监控畛域。
具体阐明:http://www.openskeye.cn/web/product/ars