모든 Magento SQL을 기록하는 방법?


23

Magento가 실행 한 모든 쿼리를 기록하는 쉬운 방법이 있습니까?

목표는 페이지로드와 같이 실행 된 모든 SQL을 인쇄하는 것입니다.

답변:


43

모든 SQL이 실제로 기록되도록하려면 타사 소프트웨어를 사용하는 것이 좋습니다.

  • Neon Profile SQL 은 실제로 무료이며 정상적으로 작동합니다
    (Magento를 Neon에 첨부하려면 local.xml을 편집해야합니다 ... 통과하는 모든 종류의 SQL 프록시로 작동합니다)

대안으로 네이티브 마 젠토 / 바리 엔 접근법은 다음과 같습니다.

  1. 편집하다 lib/Varien/Db/Adapter/Pdo/Mysql.php
  2. 다음 속성을 true(line 103)으로 변경하십시오.
  3. 여기에 로그 파일을 만들 것입니다 var/debug/pdo_mysql.log

변경 될 내용 : (설명은 자명하다)

 /**
     * Write SQL debug data to file
     *
     * @var bool
     */
    protected $_debug               = true;

    /**
     * Minimum query duration time to be logged
     *
     * @var float
     */
    protected $_logQueryTime        = 0.05;

    /**
     * Log all queries (ignored minimum query duration time)
     *
     * @var bool
     */
    protected $_logAllQueries       = true;

    /**
     * Add to log call stack data (backtrace)
     *
     * @var bool
     */
    protected $_logCallStack        = true;

생성 된 로그는 다음과 같습니다.

## 2014-06-26 12:18:47
## 10258 ## QUERY
SQL: SELECT `adminnotification_inbox`.* FROM `adminnotification_inbox` WHERE (title = 'Customize your order and invoice numbers to protect your sales using Order Number Customizer by XTENTO.') AND (url = 'http://www.xtento.com/magento-extensions/order-number-customizer.html?utm_source=feed&utm_medium=feed&utm_campaign=order_number_customizer')
AFF: 1
TIME: 0.0008

활성화 한 경우 $_logCallStackTRACE 파트도 있습니다.

TRACE: #1 Varien_Db_Adapter_Pdo_Mysql#00000000644036ff00007f14137095e6#->_debugStat(2, 'SELECT `adminnot...', array(), &Varien_Db_Statement_Pdo_Mysql#000000006440371700007f14137095e6#) called at [lib/Varien/Db/Adapter/Pdo/Mysql.php:424]
#2 Varien_Db_Adapter_Pdo_Mysql#00000000644036ff00007f14137095e6#->query(&Varien_Db_Select#000000006440371800007f14137095e6#, array()) called at [lib/Zend/Db/Adapter/Abstract.php:753]
#3 Varien_Db_Adapter_Pdo_Mysql[Zend_Db_Adapter_Abstract]#00000000644036ff00007f14137095e6#->fetchRow(&Varien_Db_Select#000000006440371800007f14137095e6#) called at [app/code/core/Mage/AdminNotification/Model/Resource/Inbox.php:116]
#4 Mage_AdminNotification_Model_Resource_Inbox#00000000644034c500007f14137095e6#->parse(&Mage_AdminNotification_Model_Inbox#00000000644034e900007f14137095e6#, array(array('severity' => 4, 'date_added' => '2013-10-23 13:00...', 'title' => 'Customizing your...', 'description' => 'Easily add new c...', 'url' => 'http://www.xtent...'), array('severity' => 4, 'date_added' => '2014-04-09 17:00...', 'title' => 'Customize your o...', 'description' => 'Customize your M...', 'url' => 'http://www.xtent...'), array('severity' => 4, 'date_added' => '2014-05-06 17:00...', 'title' => 'Process orders i...', 'description' => 'Process all your...', 'url' => 'http://www.xtent...'))) called at [app/code/core/Mage/AdminNotification/Model/Inbox.php:118]
#5 Mage_AdminNotification_Model_Inbox#00000000644034e900007f14137095e6#->parse(array(array('severity' => 4, 'date_added' => '2013-10-23 13:00...', 'title' => 'Customizing your...', 'description' => 'Easily add new c...', 'url' => 'http://www.xtent...'), array('severity' => 4, 'date_added' => '2014-04-09 17:00...', 'title' => 'Customize your o...', 'description' => 'Customize your M...', 'url' => 'http://www.xtent...'), array('severity' => 4, 'date_added' => '2014-05-06 17:00...', 'title' => 'Process orders i...', 'description' => 'Process all your...', 'url' => 'http://www.xtent...'))) called at [app/code/local/Xtento/XtCore/Model/Feed.php:57]
#6 Xtento_XtCore_Model_Feed#000000006440348500007f14137095e6#->checkUpdate(&Varien_Event_Observer#00000000644034d900007f14137095e6#) called at [app/code/core/Mage/Core/Model/App.php:1338]
#7 Mage_Core_Model_App#00000000644036ef00007f14137095e6#->_callObserverMethod(&Xtento_XtCore_Model_Feed#000000006440348500007f14137095e6#, 'checkUpdate', &Varien_Event_Observer#00000000644034d900007f14137095e6#) called at [app/code/core/Mage/Core/Model/App.php:1317]
#8 Mage_Core_Model_App#00000000644036ef00007f14137095e6#->dispatchEvent('controller_actio...', array('controller_actio...' => &Fishpig_Wordpress_Adminhtml_WordpressController#000000006440364a00007f14137095e6#)) called at [app/Mage.php:451]
#9 Mage::dispatchEvent('controller_actio...', array('controller_actio...' => &Fishpig_Wordpress_Adminhtml_WordpressController#000000006440364a00007f14137095e6#)) called at [app/code/core/Mage/Core/Controller/Varien/Action.php:528]
#10 Fishpig_Wordpress_Adminhtml_WordpressController[Mage_Core_Controller_Varien_Action]#000000006440364a00007f14137095e6#->preDispatch() called at [app/code/core/Mage/Adminhtml/Controller/Action.php:160]
#11 Fishpig_Wordpress_Adminhtml_WordpressController[Mage_Adminhtml_Controller_Action]#000000006440364a00007f14137095e6#->preDispatch() called at [app/code/core/Mage/Core/Controller/Varien/Action.php:408]
#12 Fishpig_Wordpress_Adminhtml_WordpressController[Mage_Core_Controller_Varien_Action]#000000006440364a00007f14137095e6#->dispatch('checkVersion') called at [app/code/core/Mage/Core/Controller/Varien/Router/Standard.php:250]
#13 Mage_Core_Controller_Varien_Router_Admin[Mage_Core_Controller_Varien_Router_Standard]#00000000644036ae00007f14137095e6#->match(&Mage_Core_Controller_Request_Http#000000006440365c00007f14137095e6#) called at [app/code/core/Mage/Core/Controller/Varien/Front.php:176]
#14 Mage_Core_Controller_Varien_Front#000000006440365700007f14137095e6#->dispatch() called at [app/code/core/Mage/Core/Model/App.php:354]
#15 Mage_Core_Model_App#00000000644036ef00007f14137095e6#->run(array('scope_code' => '', 'scope_type' => 'store', 'options' => array())) called at [app/Mage.php:687]
#16 Mage::run('', 'store') called at [index.php:87]

15

다음 노드에서 Zend SQL 프로파일 러를 활성화하십시오. app/etc/local.xml

<resources>
 <default_setup>
  <connection>
   <profiler>1</profiler>

그런 다음 코드 어딘가에서 프로파일 러에 액세스하여 실행 된 모든 쿼리에 대한 많은 정보를 검색 할 수 있습니다.

$profiler = Mage::getSingleton('core/resource')->getConnection('core_write')->getProfiler();

모든 쿼리를 간단히 출력하려면 :

print_r($profiler->getQueryProfiles());

index.php각 페이지의 맨 아래에 모든 쿼리를 표시하기 위해이 두 줄을 끝에 추가 할 수 있습니다 . 이로 인해 JSON 응답을 반환하는 AJAX 요청이 중단되므로이 코드를 사용하여 쿼리를 인쇄하는 대신 로깅하는 것을 고려할 수 있습니다 (다시 끝에 추가 index.php).

$profiler = Mage::getSingleton('core/resource')->getConnection('core_write')->getProfiler();
Mage::log(print_r($profiler->getQueryProfiles(), true), null, 'queries.log', true);

그런 다음 모든 검색어를 찾을 수 있습니다. var/log/queries.log

디버깅을 마친 후에는 라인을 다시 제거하는 것을 잊지 마십시오!


2

나는 이것이 모든 쿼리를 잡을 것이라고 100 % 확신하지는 않지만 대부분 쿼리 메소드 Zend_Db_Adapter_Abstract 쿼리 메소드를 통해 실행됩니다.

lib / Zend / Db / Adapter / Abstract.php

이를 염두에두고, 디버깅 문을 임시로 추가 할 수 있습니다 (복사본에 복사하십시오)

앱 / 코드 / 로컬 / 마법사

안전하다)

public function query($sql, $bind = array())
{
    // connect to the database if needed
    $this->_connect();

    // is the $sql a Zend_Db_Select object?
    if ($sql instanceof Zend_Db_Select) {
        if (empty($bind)) {
            $bind = $sql->getBind();
        }

        $sql = $sql->assemble();
    }
    echo '$sql' . "\n<br />\n";
    var_dump($bind);

2
나는 비슷한 접근법을 한 번 사용했다고 생각하지만 방법이 나에게 제안하는 것이 더 좋다는 것을 알았다. :)
Fra

"안전하게 디버깅 문을 임시로 추가하십시오." 이 방법에는 안전한 것이 없습니다.
Kevin Schroeder

2

mysql 서버에 액세스 할 수 있고 쿼리를 실행하는 다른 프로젝트가없는 경우 mysql에서 일반 로그를 추가 할 수 있습니다. /programming/6479107/how-to-enable-mysql-query-log 는 로그 파일이 매우 빠르게 커질 수있는 모든 쿼리를 작성하므로 어떻게 해야하는지 확인하십시오. 다 끝내고 나면 꺼집니다.

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.