在 PHP 中,你可以使用以下方法来监控 MySQL 的运行状态:
mysqli
或 PDO
扩展:通过执行 SQL 查询,你可以获取到 MySQL 服务器的状态信息。以下是使用 mysqli
和 PDO
的示例。
使用 mysqli:
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "dbname";
// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);
// 检查连接
if ($conn->connect_error) {
die("连接失败: " . $conn->connect_error);
}
// 获取 MySQL 服务器状态
$sql = "SHOW STATUS";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
while($row = $result->fetch_assoc()) {
echo "变量名: " . $row["Variable_name"]. " - 值: " . $row["Value"] . "<br>";
}
} else {
echo "0 结果";
}
$conn->close();
?>
使用 PDO:
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "dbname";
try {
$conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$sql = "SHOW STATUS";
$result = $conn->query($sql);
if ($result->rowCount() > 0) {
foreach($result as $row) {
echo "变量名: " . $row["Variable_name"]. " - 值: " . $row["Value"] . "<br>";
}
} else {
echo "0 结果";
}
} catch(PDOException $e) {
echo "连接失败: " . $e->getMessage();
}
$conn = null;
?>
mysqladmin
:你还可以使用 mysqladmin
工具,通过 PHP 的 shell_exec()
或 exec()
函数执行命令行操作。
<?php
$servername = "localhost";
$username = "username";
$password = "password";
// 创建连接
$conn = new mysqli($servername, $username, $password);
// 检查连接
if ($conn->connect_error) {
die("连接失败: " . $conn->connect_error);
}
// 获取 MySQL 服务器状态
$sql = "SELECT VERSION(), STATUS;";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
while($row = $result->fetch_assoc()) {
echo "版本: " . $row["VERSION()"]. "<br>";
echo "状态: " . $row["STATUS"]."<br>";
}
} else {
echo "0 结果";
}
$conn->close();
?>
注意:在使用 exec()
或 shell_exec()
时,请确保你的服务器允许执行这些函数。出于安全原因,某些服务器配置可能会限制它们的使用。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。