我在php上有一个数据库类,它在启动时连接到数据库,用于执行查询并通过RestAPI请求将数据从数据库返回给用户。这里遇到的问题是,每次用户发出HTTP请求时,都会启动新的数据库类,并在用户使用RestAPI完成的每个查询上建立新的连接。
数据库类看起来像这样:
<?php
class DbHandler
{
private $conn;
function __construct()
{
require_once dirname(__FILE__) . '/db_connect.php';
$db = new DbConnect();
$this->conn = $db->connect();
}
public function getSpotlight($user_id) {
$stmt = $this->conn->prepare("SELECT *, (SELECT COUNT(*) FROM followers WHERE following = u.id) as followers, (SELECT COUNT(*) FROM posts WHERE user_id = u.id) as totalPosts from users u WHERE u.id NOT IN (select if(user_id = :var1, user_with, user_id) from friends where user_id = :var1 OR user_with = :var1) AND u.id != :var1 order by followers desc limit 10;");
$stmt->bindParam(":var1", $user_id);
$stmt->execute();
$users = $stmt;
$stmt = null;
return $users;
}
DbConnect看起来像这样:
<?php
class DbConnect
{
private $conn;
function __construct()
{
}
function connect()
{
include_once dirname(__FILE__) . '/config.php';
$host = DB_HOST;
$db_name = DB_NAME;
$user = DB_USERNAME;
$pass = DB_PASSWORD;
$this->conn = new PDO("mysql:host=$host;dbname=$db_name", $user, $pass);
if (mysqli_connect_errno()) {
echo "Failed to connect to MySQL: " . mysqli_connect_error();
}
return $this->conn;
}
}
?>
所以基本上现在当用户调用index.php时,会启动一个新的数据库类,每次查询完成时,每次都会建立一个新的连接,并在请求完成后关闭。
直到我们有超过1000个用户并且每次增加响应时间并且我检查了mysql上的进程列表并且连接正在增加和退出并且新连接即将到来之前,这不是问题。
我不确定该问题的解决方案应该是什么。是否有任何方法使其在此DbHandler文件上持久连接?或者我们可以实现PHP中的其他方法。愿意听取这个问题的解决方案。
答案 0 :(得分:0)
也许这可以帮助https://www.phpfastcache.com/ 减少数据库/ Web服务调用
您的网站有10,000名在线访问者,您的动态页面必须在每次加载页面时向数据库或Web服务发送10,000次相同的查询。\使用phpFastCache,您的页面只向您的DB / WS发送1个查询,并使用缓存为9,999名其他访问者提供服务。\显然您可以决定符合您需求的TTL。