欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Windows Server 2008 R2和2012中PHP连接MySQL过慢的解决方法

程序员文章站 2024-02-23 09:34:10
对比下面两个脚本的速度: windows 7 用 localhost 连接本地 mysql,速度会很慢。 windows 7 用 127.0.0.1 连接本...

对比下面两个脚本的速度:

  • windows 7 用 localhost 连接本地 mysql,速度会很慢。
  • windows 7 用 127.0.0.1 连接本地 mysql,速度则是正常的。

my.ini里配置了

bind-address=127.0.0.1

 用localhost连接本地mysql: 速度慢

<?php
$start = microtime(true);
$mysqli = new mysqli('127.0.0.1', 'root', '', 'mysql'); //连接耗时仅为0.0025秒.
//$mysqli = new mysqli('localhost', 'root', '', 'mysql'); //连接耗时超过1秒,比正常慢了400倍.
echo microtime(true) - $start;

分析:
1.my.ini里配置

bind-address=127.0.0.1

时,win7及其以上版本系统php用localhost连接mysql耗时超过1秒,比用127.0.0.1连接慢了400倍.
2.my.ini里配置

bind-address=::1

时,win7及其以上版本系统php用localhost连接mysql速度是正常的,但用127.0.0.1连接又不正常了.
3.去掉bind-address配置,则用localhost或127.0.0.1连接mysql速度都是正常的.

所以:在配置了

bind-address=127.0.0.1 

的情况下,应该使用 127.0.0.1 连接本地 mysql 数据库 。
安装 wordpress、phpmyadmin 等 php 程序的时候默认使用 localhost 连接本地 mysql 数据库,这时注意把默认的 localhost 改为 127.0.0.1。

另外,windows 2008、2012 跟 windows 7 存在同样的问题。