PHP RestAPI MySQL数据库多个连接

时间:2018-06-03 16:37:24

标签: php mysql rest api connection

我在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中的其他方法。愿意听取这个问题的解决方案。

1 个答案:

答案 0 :(得分:0)

也许这可以帮助https://www.phpfastcache.com/ 减少数据库/ Web服务调用

您的网站有10,000名在线访问者,您的动态页面必须在每次加载页面时向数据库或Web服务发送10,000次相同的查询。\使用phpFastCache,您的页面只向您的DB / WS发送1个查询,并使用缓存为9,999名其他访问者提供服务。\显然您可以决定符合您需求的TTL。