【PHP】通过PHP实时监控Apache、MySQL服务运行状态

一、前言

有些时候我们需要监控一些服务的运行状态,比如说Apach或MySQL的运行状态,最近工作中也开发了这方面的功能,记录下来怎样使用PHP语言来实时监控Apache、MySQL服务的运行状态。

如果想一键开启Apache或MySQL等其他服务可以看这篇文章

【PHP】通过PHP开启/暂停Apache、MySQL或其他服务-CSDN博客

二、代码

首先要知道要监控服务的所在地址,下面代码中的地址根据实际情况修改。

返回值是'active'运行状态和'stop'停止状态,前端可以轮询请求这个方法,以实时监控服务运行状态。

php 复制代码
public function getServer()
{
	$info = [];

	// 要监控的服务
	$server['apache'] = "E:\phpstudy_pro\Extensions\Apache2.4.39\bin\httpd.exe";
	$server['mysql'] = "E:\phpstudy_pro\Extensions\MySQL5.7.26\bin\mysqld.exe";

	if (!empty($server)) {

		// apache
		$apache = $this->getProcessNameByName($server['apache']);
		if (!empty($apache)) {  
			if ($apache[0] == $server['apache']) {
				$info['apache'] = 'active';		//运行状态
			}else{
				$info['apache'] = 'stop';		//停止状态
			}
		} else {  
			$info['apache'] = 'stop';	//停止状态
		}  

		// mysql
		$mysql = $this->getProcessNameByName($server['mysql']);
		if (!empty($mysql)) {  
			if ($mysql[0] == $server['mysql']) {
				$info['mysql'] = 'active';	//运行状态
			}else{
				$info['mysql'] = 'stop';	//停止状态
			}
		} else {  
			$info['mysql'] = 'stop';	//停止状态
		}  
	}

	return apiResponse('200','success',$info);

}
相关推荐
焦虑的说说1 小时前
mysql为什么回表会慢
mysql·面试
峥无1 小时前
MySQL 数据库 & 数据表基础操作总结
数据库·mysql
Amnesia0_01 小时前
MYSQL索引
数据库·mysql
Tipriest_1 小时前
没有nvidia的卡上装sogou拼音的特殊处理
运维·服务器·mysql
zimoyin1 小时前
Webman 的 PHP 打包构建脚本:编译二进制、归档备份、生成校验包(附完整源码+解析)
php
bjzhang7513 小时前
CentOS下安装MySQL详解
linux·mysql·centos
十五年专注C++开发15 小时前
MySql中各种功能用sql语句实现总结
数据库·sql·mysql
ULIi096kr17 小时前
MySQL解决Too many connections报错:连接数爆满排查、优化与永久解决方案
数据库·mysql·adb
李白的天不白18 小时前
服务器上数据库的创建
mysql
ha_lydms18 小时前
AnalyticDB基本概念
mysql·adb·analyticdb