昨天我发布了有关 SQLite 性能问题的问题 (Terrible performance in Zend Db PDO_sqlite insert and update queries)。经过多次测试似乎只有在通过 SoapServer 调用方法时才会出现问题(尝试了 native PHP SoapServer 和 Zend_Soap_Server 类)。
测试用例 - 调用 10 个使用 SQLite 数据库插入和更新数据库操作的方法。
以下是其工作原理的几个案例:
1.通过 Controller - 不使用 Soap 服务器。本地主机:~0.3s,远程服务器:~0.3s
2.通过Soap服务器。第一个电话。本地主机:~1-2s,远程服务器:~7s!
3.通过Soap服务器。几个电话。本地主机:~1-10s,远程服务器:~7s
第三种情况我不太关心,可能是本地服务器性能问题。重要的是它在远程服务器上稳定运行。
另一方面,对于简单的 10 个方法调用来说,7 秒的时间长得令人难以置信。显然 - 这 7 秒的一部分是客户端-服务器通信,因为案例 1 忽略了这一点,但我认为它不应该那么慢!
为了调试,我记录了所有内容,似乎发生的是在案例 1 中调用的相同 SQLite 方法,需要 0.00x-0.02 秒,这里持续约 0.15-0.45 秒。
可能是什么问题?使用 SOAP 时它如此剧烈地减慢是正常的吗? (这是我的第一个 soap 服务器项目)。
编辑:我发现的另一个重要日志事实:
资讯-2012-04-26 13:08:07.782679 类:SoapController。方法:SoapController::hadleWSDL。第 18 行。
Information-2012-04-26 13:08:08.318641 * 系统启动 *
所以这基本上是调用 2 个方法之间的时间。对于少量数据的客户端-服务器通信,超过 0.5 秒对我来说似乎很多。下面是 handleWSDL 操作的代码:
$options = array(
'encoding' => 'UTF-8',
'cache_wsdl' => WSDL_CACHE_BOTH,
'uri' =>$this->_WSDL_URI
);
$soap = new Zend_Soap_Server(null, $options);
$soap->setClass('SoapServerFunction');
$soap->setObject(new SoapServerFunction());
$soap->handle();
应用非常简单——SOAP方法接受1个参数,基于它创建1个缓存对象,处理数据,部分数据以XML格式返回。
预先感谢您提出任何建议,我可以做些什么来加快速度或如何跟踪速度变慢的真正原因。
最好的问候!
最佳答案
您是否使用 FQDN 作为服务器地址?在那种情况下,它实际上可能与 DNS 相关。您可能还想在真实系统而不是虚拟主机上尝试所有操作,因为您对物理系统的实际操作没有太多控制权。
其次,我建议安装 xdebug 并使用 kcachegrind或 wincachegrind ,这将使您更详细地了解您的系统正在做什么。
第三,您可以使用 PostgreSQL 记录慢速查询 pg_stat_statements() .
关于php - Soap 服务器 - 性能问题(可能与 SQLite 相关),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10347745/