推进 - 多连接性能

时间:2013-08-21 12:40:52

标签: php mysql sql-server propel sqlsrv

我是基于两个单独数据库的php项目。一个是MySQL DB,另一个是Microsoft SQL服务器。基本上我已经配置了整个环境,它几乎可以正常工作。

几乎,因为我在尝试访问这两个数据库时发现了一些可怕的性能。

由propel生成的我的数据库配置如下所示:

$conf = array (
  'datasources' => 
  array (
    'db1' => 
    array (
      'adapter' => 'sqlsrv',
      'connection' => 
      array (
        'dsn' => 'sqlsrv:server=SERVER_NAME\\SQLEXPRESS;Database=db1',
        'user' => 'user1',
        'password' => 'password1',
      ),
    ),
    'db2' => 
    array (
      'adapter' => 'mysql',
      'connection' => 
      array (
        'dsn' => 'mysql:host=localhost;dbname=db2',
        'user' => 'user2',
        'password' => 'password2',
        'settings' => 
        array (
          'charset' => 
          array (
            'value' => 'utf8',
          ),
        ),
      ),
    ),
    'default' => 'db1',
  ),
  'log' => 
  array (
    'ident' => 'my_id',
    'type' => 'file',
    'name' => './../application/logs/propel.log',
    'level' => '7',
    'conf' => '',
  ),
  'generator_version' => '1.6.7',
);

我检查了propel.log,但我注意到只有来自db1的查询被记录在那里。所以我使用自己的文本文件日志类来记录响应时间。每当我试图从db2获取数据时,响应时间大约为1秒,这是不可接受的。

之后我尝试单独使用db2,同样的查询大约需要0.07秒!所以我认为在推动连接时推进会导致延迟。

我进行了第二次测试 - 我在推动配置中将db2设置为默认值。当我这样做时,来自db2的查询执行得更快(再次 - 相同的查询0.07s)。

这是正常行为吗?处理多个数据库是否总是会导致性能问题?

无论如何要让它更快?

提前感谢您的帮助。如果需要,我非常乐意提供一些额外的细节。

1 个答案:

答案 0 :(得分:0)

找到解决方案。这是完全不同的原因:http://www.iishacks.com/2013/02/18/mysql-connection-response-slow-on-windows-2008-2012/

抱歉浪费你的时间。