13

我在这里问这个是因为我认为它不仅仅适用于 EasyPHP 本身。

我目前使用 EasyPHP 作为我的 WAMP 开发服务器,因此我可以创建 Web 应用程序。问题是,当我让 mysqli 对象连接到数据库时,它需要 1 秒。在共享主机上运行相同的查询会导致速度提高 200 倍以上。这应该是我应该担心的事情吗?就可扩展性或将我的应用程序移动到另一台服务器而言,花点时间看看问题所在是否明智?我只是假设 EasyPHP 可能很慢。不是专业,只是让我觉得很有趣。

4

3 回答 3

56

如果您遇到此问题并使用 Windows 7 之前的 Windows 版本,这可能不是您问题的答案。

为什么会这样?

此问题的原因是 IPv4 与 IPv6。

当您使用主机名而不是 IP 地址时,MySQL 客户端首先运行AAAA(IPv6) 主机查找名称,如果成功将名称解析为 IPv6 地址,则首先尝试此地址。如果任一步骤失败(名称解析或连接),它将回退到 IPv4,运行A查找并尝试此主机。

这在实践中意味着如果 IPv6localhost查找成功但 MySQL 未绑定到 IPv6 环回,您将需要等待一个连接超时周期(显然在 OP 的机器上这是 1 秒),然后 IPv4 回退发生并且连接成功。

这在 Windows 7 之前不是问题,因为localhost解决方案是通过 hosts 文件完成的,并且它仅预配置了127.0.0.1- 它没有与它的 IPv6 对应项一起提供::1

然而,由于 Windows 7,解析内置于 DNS 解析器中localhost,原因如下 所述这意味着 IPv6 查找现在将成功 - 但 MySQL 未绑定到该 IPv6 地址,因此连接将失败,您将看到此问题中概述的延迟。

那很好。告诉我如何解决它!

你有几个选择。环顾互联网,一般的“解决方案”似乎是明确使用 IP 地址而不是名称,但有几个理由不这样做,两者都与可移植性相关,都可以说都不重要:

  • 如果您将脚本移动到另一台支持 IPv6 的机器上,您的脚本将不再工作。

  • 如果您将脚本移动到基于 *nix 的托管环境,则魔术字符串localhost将意味着 MySQL 客户端如果配置了一个 Unix 套接字,则更愿意使用它,这比基于 IP 环回的连接更有效

它们听起来很重要吗?

他们不是。您应该设计您的应用程序,以便在配置文件中定义此类事情。如果您将脚本移动到另一个环境,则可能还需要配置其他内容。

总之,使用 IP 地址不是最好的解决方案,但它很可能是可以接受的。

那么最好的解决方案是什么?

最好的方法是更改​​ MySQL 服务器使用的绑定地址。然而,这并不像人们想象的那么简单。与 Apache、Nginx 和几乎所有其他健全的网络服务应用程序不同,MySQL 仅支持单个绑定地址,因此不仅仅是添加另一个绑定地址的情况。不过幸运的是,操作系统在这里确实支持了一些魔法,所以我们可以让 MySQL 同时使用 IPv4 和 IPv6。

您需要运行 MySQL 5.5.3 或更高版本,并且需要使用--bind-address=命令行参数启动 MySQL(或在 my.ini 中设置相应的选项)。您有 4 个选项docs,具体取决于您要执行的操作:

  • 您可能熟悉的,并且您最有可能(有效)使用的,0.0.0.0. 这将绑定到机器上所有可用的 IPv4 地址。即使您不关心 IPv6,这实际上也可能不是最好的做法,因为它与::.

  • 显式 IPv4 或 IPv6 地址(例如127.0.0.1::1用于环回)。这会将服务器绑定到该地址并且绑定到该地址。

  • 魔线::。这将在 IPv4 和 IPv6 模式下将 MySQL 绑定到机器上的每个地址,包括环回和物理接口地址。这存在潜在的安全风险,仅当您需要 MySQL 接受来自远程主机的连接时才这样做。

  • 使用IPv4 映射的 IPv6 地址。这是 IPv6 中内置的一种特殊机制,用于在 4 -> 6 转换期间向后兼容,它允许您绑定到特定的 IPv4 地址,它与 IPv6 等效。除了“双环回”地址之外,这不太可能对您有用::ffff:127.0.0.1。对于大多数人来说,这很可能是最好的解决方案,只绑定到环回但允许 IPv4 和 IPv6 连接。

我需要修改hosts文件吗?

没有。不要修改主机文件。DNS 解析器知道如何处理localhost,重新定义它充其量是没有效果的,最坏的情况是把解析器弄得一团糟。

怎么样--skip-name-resolve

由于相关但略有不同的原因,这也可能解决问题/需要解决问题。

如果没有此配置选项,MySQL 将尝试通过PTRDNS 查询将所有客户端连接 IP 地址解析为主机名。如果您的 MySQL 服务器已经启用 IPv6,但连接仍然需要很长时间,可能是因为反向 DNS ( PTR) 记录配置不正确。

禁用名称解析将解决此问题,但它确实有其他后果,特别是配置为在条件下使用 DNS 名称的任何访问权限Host现在都将失败。

如果您要这样做,您需要将所有授权配置为使用 IP 地址而不是名称。

于 2013-03-15T15:39:53.837 回答
26

当我使用localhostMySQL 服务器地址时,我有一些延迟。改变它来127.0.0.1帮助。

于 2012-07-03T12:19:52.440 回答
0

不管服务器如何,只要有可能就使用持久连接会很好。毕竟,在旧连接也可以完成工作时,一直打开新连接是不明智的。查看 mysqli 的手册

于 2012-07-03T12:15:45.913 回答