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

标签 php performance sqlite zend-framework soap

昨天我发布了有关 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/

相关文章:

php - "or"的运算符优先级和赋值

php - 在 php 中单击提交时如何验证答案并显示答案

MySQL:如果使用 LIMIT 1 而不是 LIMIT 5,查询执行速度会大大降低

android - SQLite 初学者问题。安卓内容解析器。更新(...)插入(...)

php - 如何在 PHP 中检测相似图像?

php - 从YouTube API JSON响应(PHP)中随机选择一个视频

performance - 为什么我的 Perl 脚本在使用线程时解压缩文件的速度变慢?

java - 为什么/如何将整数设置为 -1 使我的 while 循环工作?

sqlite - 每次更新应用程序时,我都需要创建一个新的SQLite数据库吗?

android - 如何在查询函数中使用 LIKE 子句