gpt4 book ai didi

php - 使用 PHP 检查是否可以在短时间内从本地应用程序访问 MySql 在线服务器

转载 作者:行者123 更新时间:2023-11-28 23:21:42 25 4
gpt4 key购买 nike

我有一个基于 PHP本地 Web 应用程序,它使用了一个在线 Mysql 服务器。

我需要知道什么时候可以访问该服务器(我什么时候有互联网连接,或者服务器什么时候关闭)。

我试过了

$conn = new mysqli('hostname','username','password','db');

if($conn->connect_error){
//offline action
}
else{
//online action
}

哪个有效,但它会持续大约一分钟以确定服务器是否可访问。

我想知道是否有任何其他持续时间少于 3 或 4 秒的解决方案。

最佳答案

检查服务器是否首先返回响应,您可以使用fsockopen(),但也可以使用其他方法,例如使用operating system shell。这样你就可以ping了。

function is_connectable(string $host, int $port=80, int $timeout=3){
if($fp = @fsockopen($host, $port, $errno, $errstr, $timeout)){
return fclose($fp) || true;
}

return false;
}

$host = "mysql.someserver.com";
$port = 3306;
$user = "username";
$pass = "mypassword";
$mydb = "mydatabase";

if(is_connectable($host, $port)){
try{
$pdo = new PDO("mysql:host=$host;port=$port;dbname=$mydb", $user, $pass);
} catch(Exception $e){
die($e->getMessage());
}
} else {
die("mysql server '$host' is down");
}

还有直接使用数据库驱动的超时:

关于php - 使用 PHP 检查是否可以在短时间内从本地应用程序访问 MySql 在线服务器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41302145/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com