- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在一个使用 Zend Framework 的网站上工作,其中一个页面在生产服务器上的加载速度比在开发服务器上慢得多。经过一些挖掘和分析(使用 xdebug)后,我发现 PDOStatement->execute 调用在生产服务器上运行需要 11134 毫秒,在开发服务器上需要 780 毫秒。
两台服务器上的数据库相同,两台服务器上的 MySQL 版本相同 (5.5.32),两台服务器上的 MySQL 配置也相同(一直到 my.cnf 中的行)。两台服务器都运行 Ubuntu 12.04.2 LTS,尽管与生产服务器相比,开发服务器确实有额外的软件。我能想到的唯一区别是,开发服务器在 SSD 上运行,而生产服务器在 RAID 0 中运行两个常规 SATA 驱动器。然而,在 phpMyAdmin 中运行查询会产生大约相同的时间(0.0003-0.0005 秒,尽管我不相信 phpMyAdmin 的执行时间报告)。
这是我运行的查询:
$query = "SET @rank = 0";
$statement = $db->query($query);
$query = "SET @previous_result = -1";
$statement = $db->query($query);
$query = "
SELECT
@group_id := IFNULL(g.id, -1)
FROM
`branch_statistics` bs
JOIN
branch_to_wave btw ON bs.branch_to_wave_id = btw.id
JOIN
branch_to_group btg ON bs.branch_id = btg.branch_id
JOIN
`group` g ON btg.group_id = g.id
WHERE
btw.wave_id = $wave_id AND bs.branch_id = $branch_id";
$statement = $db->query($query);
$query = "DROP TABLE IF EXISTS group_members";
$statement = $db->query($query);
$query = "CREATE TEMPORARY TABLE group_members (id INT PRIMARY KEY)";
$statement = $db->query($query);
$query = "DROP TABLE IF EXISTS group_members2";
$statement = $db->query($query);
$query = "CREATE TEMPORARY TABLE group_members2 (id INT PRIMARY KEY)";
$statement = $db->query($query);
$query = "
INSERT INTO
group_members
SELECT
btw.id
FROM
branch_to_wave btw
JOIN
branch_to_group btg ON btw.branch_id = btg.branch_id
WHERE
btw.wave_id = $wave_id AND
btg.group_id = @group_id
GROUP BY
btw.id";
$statement = $db->query($query);
$query = "INSERT INTO group_members2 SELECT id FROM group_members";
$statement = $db->query($query);
$query = "
SELECT @number_of_results :=
COUNT(result)
FROM
(
SELECT
ROUND(points / maximum_points, 4) as result
FROM
`branch_statistics` bs
JOIN
group_members2 gm2 ON gm2.id = bs.branch_to_wave_id
GROUP BY
result
) results
";
$statement = $db->query($query);
$query = "
EXPLAIN SELECT
*,
@number_of_results as number_of_results
FROM
(
SELECT
*,
IF(@previous_result != result, @rank := @rank + 1, @rank) as rank,
@previous_result := result
FROM
(
SELECT
bs.branch_id,
ROUND(points / maximum_points, 4) as result,
(
SELECT
AVG(ROUND(points / maximum_points, 4)) as average
FROM
`branch_statistics` bs
JOIN
group_members2 gm2 ON gm2.id = bs.branch_to_wave_id
) as average
FROM
`branch_statistics` bs
JOIN
group_members gm ON gm.id = bs.branch_to_wave_id
GROUP BY
bs.branch_id
ORDER BY
result DESC
) complete
) results
WHERE branch_id = $branch_id
";
$statement = $db->query($query);
$statement->setFetchMode(Zend_Db::FETCH_NUM);
$results = $statement->fetchAll();
我不知道服务器规范是否相关,但无论如何它们在这里:
生产服务器:
Intel(R) Core(TM)2 Duo CPU E7500 @ 2.93GHz 带 3.4Gb RAM
开发服务器(在以下硬件上运行的虚拟机,以及 5-6 个其他虚拟机):
AMD FX(tm)-8120 八核处理器,3Gb RAM
所以我的问题是:我怎样才能查明造成这种差异的原因?
编辑 #1 (2013-08-16 @ 11:23):对于那些不熟悉 Zend Framework 的人,这里是导致 PDOStatement->execute 的调用堆栈:
编辑#2 (2013-08-16 @ 13:09):这是两台机器上的分析结果。
Status Duration DEV Duration PROD
starting 0.000032 0.000010
Waiting for query cache lock 0.000010 0.000006
checking query cache for query 0.000183 0.000074
checking permissions 0.000010 0.000007
checking permissions 0.000009 0.000006
checking permissions 0.000009 0.000006
checking permissions 0.000011 0.000007
Opening tables 0.000030 0.000017
System lock 0.000140 0.000063
optimizing 0.000016 0.000010
statistics 0.000035 0.000016
preparing 0.000020 0.000011
Creating tmp table 0.000028 0.000015
executing 0.000009 0.000006
Copying to tmp table 0.000424 0.000133
Sorting result 0.000039 0.000017
Sending data 0.000015 0.000008
optimizing 0.000014 0.000009
statistics 0.000022 0.000012
preparing 0.000019 0.000010
executing 0.000011 0.000007
Sending data 0.000171 0.000110
optimizing 0.000006 0.000007
statistics 0.000006 0.000008
preparing 0.000006 0.000007
executing 0.000004 0.000006
Sending data 0.000042 0.000035
removing tmp table 0.000007 0.000009
Sending data 0.000006 0.000008
init 0.000011 0.000013
optimizing 0.000005 0.000008
statistics 0.000006 0.000008
preparing 0.000006 0.000009
executing 0.000004 0.000006
Sending data 0.000016 0.000019
end 0.000005 0.000007
query end 0.000005 0.000007
closing tables 0.000004 0.000006
removing tmp table 0.000005 0.000007
closing tables 0.000004 0.000006
removing tmp table 0.000006 0.000007
closing tables 0.000006 0.000008
freeing items 0.000013 0.000275
logging slow query 0.000004 0.000007
cleaning up 0.000006 0.000007
我还测试了 mysqlslap 并发现了一些非常有趣的结果,如下所示(时间是平均查询时间)。您可以看到,虽然同时进行更多查询确实会增加平均查询时间,但与开发服务器相比,生产服务器上的相同查询仍然慢 24 倍。
我真的不明白为什么在 phpMyAdmin 中运行查询需要 0.0005 秒,而使用 mysqlslap 的相同查询需要 0.299 秒,但我怀疑这是我问题的核心。
Mysqlslap settings Dev Prod
iterations = 10, concurrency = 50 1.253 14.129
iterations = 10, concurrency = 25 0.513 7.153
iterations = 10, concurrency = 10 0.141 3.133
iterations = 10, concurrency = 1 0.014 0.299
最佳答案
今天终于明白了!问题是临时表不是在生产服务器的内存中创建的。我不知道为什么,因为配置文件明确指出它应该,但我通过将 ENGINE = MEMORY
添加到所有 CREATE TEMPORARY TABLE
调用解决了这个问题。
例如:
CREATE TEMPORARY TABLE group_members (id INT PRIMARY KEY) ENGINE = MEMORY
关于php - PDOStatement->在生产服务器上执行比在开发服务器上慢 14 倍,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18276556/
我需要一些说明。我可以直接写入 /dev/port 以直接访问并行端口并且它工作正常(我可以打开插入端口连接器的 LED)。但是,我想我可以用 /dev/mem 做同样的事情? (http://tld
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我使用 Visual C++ 和 Win32 API 学习了 Windows 编程。如今,似乎大多数应用程序都是使用 C# 在 .NET 中开发的。我知道大多数时候 native 代码和托管代码之间没
请耐心等待。我正在制作一个 java 控制台,类似于此处找到的 DragonConsole https://code.google.com/p/dragonconsole/ 。一切都按计划进行,但我想
关闭。这个问题需要更多 focused .它目前不接受答案。 想要改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭5年前。 Improve this que
Django 的开发服务器表现得很奇怪。访问它的浏览器在加载时卡住,任何退出它的尝试都不起作用。当我点击 control c看似相当,但实际上仍在运行。让它退出的唯一方法是重新启动我的电脑,这很令人沮
我正在使用 Flash Develop,并且创建了一个 ActionScript 3.0 项目。它启动并读取一个 xml 文件,其中包含图像的 url。我已将 url 保留在与 swf 相同的文件夹中
是否可以根据其 website 上提供的规范开发 AUTOSAR BSW 堆栈(例如用于 CAN 通信)?不购买任何昂贵的供应商工具?可以遵循哪些步骤?我被要求探索这种可能性。 最佳答案 是和否。工具
有人知道如何用音频文件的内容覆盖 iPhone 麦克风吗? 想象一个场景,您正在通话,并且想要播放一些简短的音频让其他人听到。 因此,有必要将麦克风(硬件)置于保持状态,并使用委托(delegate)
我遇到了这个问题,我的应用程序出现 EXC_BAD_ACCESS 错误并卡住/停止。我使用模拟器的“向左旋转”和“向右旋转”选项来模拟方向变化行为。导致此错误的可能原因有哪些?由于我没有获得有关错误的
我有超过 1 台 Mac,我想在所有这些 Mac 上进行开发。我知道我需要在每台机器上同步我的手机,但这是我遇到的最小的问题。看起来我无法在手机上运行应用程序,除了在其中之一上开发的应用程序。 是否有
在手机上测试时,我的应用程序在特定点崩溃。控制台显示此消息 Tue Jan 27 15:47:14 unknown SpringBoard[22] : Application com.myprof.
我有一个案例,我从服务器获取信息。我的应用程序有一个选项卡栏和导航按钮。我希望应用程序显示进度指示器并禁用所有其他控件,以便用户在从服务器提取数据时无法跳转。我怎样才能实现这个目标? 我想到的一种方法
有时,当我尝试“构建”/编译下载的源代码时,我会收到以下警告: ld: warning: directory '/Volumes/Skiiing2/CD/ViewBased/Unknown Path/
我无法在 Apple 文档中找到关于开发和分发配置之间差异的明确解释。我目前正在使用开发配置在我的 iPhone 上进行开发和测试。我打算将该应用程序分发到我的 Beta 测试中,我想知道: 我需要使
我在使用 SharePoint 时遇到的最大挑战之一是它不能很好地适应典型的项目环境,其中至少包含开发和生产环境。我遇到的最多的问题是内容和列表是如此紧密地耦合在一起,以至于如果不在生产环境中执行内容
我失败了fist step让 Eclipse(对我来说是全新的)为 ARM 开发做好准备。 我在 Windows 10 中安装了 Eclipse。我想我应该安装 xpm,但我不知道在哪里输入此命令:
首先,我告诉你-我是编码新手 我正在使用vs代码来学习c++,它不会产生像dev c++或codeblocks这样的调试器。我看了一些视频,其中我们必须编辑json文件,这对于初学者来说非常复杂。有人
我失败了fist step让 Eclipse(对我来说是全新的)为 ARM 开发做好准备。 我在 Windows 10 中安装了 Eclipse。我想我应该安装 xpm,但我不知道在哪里输入此命令:
我开发了一个 Ionic 应用程序(iOS 和 Android 的混合)。我有 Xcode 8.3.3 并购买了一年的 Apple Developer Program 订阅。 我不想测试我的应用并将其
我是一名优秀的程序员,十分优秀!