PHP:执行速度慢

时间:2013-02-13 00:54:35

标签: php performance

我有这个登录系统:

    require_once "conexion.php";


    class login extends conexion {



    public function log_user($user,$pass)
        {
        $conexion = mysql_conexion();
            $login = "SELECT user_name,user_pass,id FROM menssager_user WHERE user_name='$user' AND user_pass='$pass'";
                $e = $conexion->prepare($login);
                    $e->execute();

                $re = $e->fetch(PDO::FETCH_ASSOC);

                    if($user == $re["user_name"] && $pass == $re["user_pass"])
                    {

                    $this->is_online($re["id"]);
                    return $re["id"];
                    }

        $conexion = null;

        }   }

当我执行该代码时,需要1.3秒才能确定该用户是否存在,并且我在数据库中只有2个用户名。 有人能告诉我为什么这么慢? 注意:昨天我升级到5.4.7并重新编写代码(对于该版本的新功能)。

更新

数据库conexion:

class conexion{

        public function mysql_conexion(){

            $conexion_path = "mysql:dbname=menssager;host:127.0.0.1";
                $root = "root";
                $pass = "";

                try{

                    $conectar = new PDO($conexion_path,$root,$pass);
                    $conectar->setAttribute(PDO::ATTR_EMULATE_PREPARES,false);
                    $conectar->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

                }catch(PDOException $error)
                {
                    echo $conectar = $error->getMessage();
                }
                return $conectar;

        }
    }

1 个答案:

答案 0 :(得分:0)

当你还在测量连接与执行时间时,我会猜测答案。我认为你的连接时间是导致延迟的原因。看看前面提到过的类似问题。 https://serverfault.com/questions/408550/connecting-to-mysql-from-php-is-extremely-slow

关闭反向DNS查找可能会对您有所帮助。 添加一个链接,显示如何关闭它:

http://developers.sugarcrm.com/wordpress/2012/01/10/howto-turn-off-mysql-reverse-dns-lookup-to-speed-up-response-times/