gpt4 book ai didi

php - Soap 服务器 - 性能问题(可能与 SQLite 相关)

转载 作者:搜寻专家 更新时间:2023-10-31 22:13:05 26 4
gpt4 key购买 nike

昨天我发布了有关 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 并使用 kcachegrindwincachegrind ,这将使您更详细地了解您的系统正在做什么。

第三,您可以使用 PostgreSQL 记录慢速查询 pg_stat_statements() .

关于php - Soap 服务器 - 性能问题(可能与 SQLite 相关),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10347745/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com