Soap Server - 性能问题(可能与 SQLite 相关)


Soap Server - performance issue (might be SQLite related)

昨天我发布了有关SQLite性能问题的问题(Zend Db中的糟糕性能PDO_sqlite插入和更新查询(。经过几次测试,似乎只有当通过 SoapServer 调用方法时才会出现问题(尝试过本机 PHP SoapServer 和 Zend_Soap_Server 类(。

测试用例 - 调用 10 个使用 SQLite DB INSERT 和 UPDATE DB 操作的方法。

以下是其工作原理的几种情况:

1.通过控制器 - 不使用 SOAP 服务器。 本地主机:~0.3秒,远程服务器:~0.3秒

2.通过肥皂服务器。 第一次调用。 本地主机:~1-2秒,远程服务器:~7秒!

3.通过 SOAP 服务器。几个电话。本地主机:~1-10秒,远程服务器:~7秒

第三种情况与我无关,可能是本地服务器性能问题。重要的是它在远程服务器上工作稳定。

另一方面,简单的 10 个方法调用的 7 秒非常长。显然 - 这 7 秒的一部分是客户端-服务器通信,因为案例 1 省略了这一点,但我认为它不应该那么慢!

为了调试,我正在记录所有内容,似乎发生的事情是,在案例 1 中调用的相同 SQLite 方法需要 0.00x-0.02 秒,这里持续 ~0.15-0.45 秒。

可能是什么问题?使用 SOAP 时它会如此急剧地减慢速度是正常的事情吗?(这是我的第一个肥皂服务器项目(。

编辑:我发现的另一个重要的日志事实:

信息 -2012-04-26 13:08:07.782679 类:肥皂控制器。方法:SoapController::hadleWSDL。行: 18.

信息-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,这将为您提供更详细的系统正在做什么的视图。

第三,你可以通过使用PostgreSQLs pg_stat_statements((来记录慢查询。