Ключ реєстру маг "_singleton / weee / спостерігач" вже існує


13

Коли я намагаюся додати або відредагувати продукт, я отримую таку помилку:

Mage registry key "_singleton/weee/observer" already exists
Trace:
#0 app/Mage.php(222): Mage::throwException('Mage registry k...')
#1 app/Mage.php(476): Mage::register('_singleton/weee...', false)
#2 app/code/core/Mage/Core/Model/App.php(1316): Mage::getSingleton('weee/observer')
#3 app/Mage.php(447): Mage_Core_Model_App->dispatchEvent('adminhtml_catal...', Array)
#4 app/code/core/Mage/Adminhtml/Block/Catalog/Product/Edit/Tab/Attributes.php(143): Mage::dispatchEvent('adminhtml_catal...', Array)
#5 app/code/core/Mage/Adminhtml/Block/Widget/Form.php(144): Mage_Adminhtml_Block_Catalog_Product_Edit_Tab_Attributes->_prepareForm()
#6 app/code/core/Mage/Core/Block/Abstract.php(862): Mage_Adminhtml_Block_Widget_Form->_beforeToHtml()
#7 app/code/core/Mage/Adminhtml/Block/Catalog/Product/Edit/Tabs.php(79): Mage_Core_Block_Abstract->toHtml()
#8 app/code/core/Mage/Core/Block/Abstract.php(238): Mage_Adminhtml_Block_Catalog_Product_Edit_Tabs->_prepareLayout()
#9 app/code/core/Mage/Core/Model/Layout.php(456): Mage_Core_Block_Abstract->setLayout(Object(Mage_Core_Model_Layout))
#10 app/code/core/Mage/Core/Model/Layout.php(472): Mage_Core_Model_Layout->createBlock('adminhtml/catal...', 'product_tabs')
#11 app/code/core/Mage/Core/Model/Layout.php(239): Mage_Core_Model_Layout->addBlock('adminhtml/catal...', 'product_tabs')
#12 app/code/core/Mage/Core/Model/Layout.php(205): Mage_Core_Model_Layout->_generateBlock(Object(Mage_Core_Model_Layout_Element), Object(Mage_Core_Model_Layout_Element))
#13 app/code/core/Mage/Core/Model/Layout.php(210): Mage_Core_Model_Layout->generateBlocks(Object(Mage_Core_Model_Layout_Element))
#14 app/code/core/Mage/Core/Controller/Varien/Action.php(344): Mage_Core_Model_Layout->generateBlocks()
#15 app/code/core/Mage/Core/Controller/Varien/Action.php(269): Mage_Core_Controller_Varien_Action->generateLayoutBlocks()
#16 app/code/core/Mage/Adminhtml/Controller/Action.php(275): Mage_Core_Controller_Varien_Action->loadLayout(Array, true, true)
#17 app/code/core/Mage/Adminhtml/controllers/Catalog/ProductController.php(207): Mage_Adminhtml_Controller_Action->loadLayout(Array)
#18 app/code/core/Mage/Core/Controller/Varien/Action.php(419): Mage_Adminhtml_Catalog_ProductController->newAction()
#19 app/code/core/Mage/Core/Controller/Varien/Router/Standard.php(250): Mage_Core_Controller_Varien_Action->dispatch('new')
#20 app/code/core/Mage/Core/Controller/Varien/Front.php(176): Mage_Core_Controller_Varien_Router_Standard->match(Object(Mage_Core_Controller_Request_Http))
#21 app/code/core/Mage/Core/Model/App.php(354): Mage_Core_Controller_Varien_Front->dispatch()
#22 app/Mage.php(683): Mage_Core_Model_App->run(Array)
#23 index.php(124): Mage::run('catalog', 'website')
#24 {main}

Magento ver. 1.7.0.0 Компілятор вимкнено очищений кеш, відбудований індекс не було оновлень або нових розширень, він просто перестав працювати

Будь-яка допомога буде вдячна!


1
З мого розуміння це викликано кешем, ви впевнені, що це очищено? Як ви це зрозуміли?
Пітер О'Каллаган

Я використовував кеш-керування в System - Flush Magento Cache та Flush Cache Storage. Чи є спосіб перевірити, чи кеш був промитий?
littleredsunshine

Припустимо, що ви використовуєте кеш на основі файлів, перевірте, чи є щось всередині var/cacheкаталогу, якщо є, видаліть усе в папці.
Пітер О'Каллаган

Спробував це, все ж отримуючи помилки. У самій верхній частині екрана також є посилання на ім’я сайту 3.8.0-41-generic # 60 ~ точно1-Ubuntu SMP Пт 16 травня 00:18:00 UTC 2014 x86_64 Дякую за швидкі відповіді та вашу допомогу!
littleredsunshine

Відповіді:


16

Ця помилка надходить через порожні значення в реєстрі.

щоб запобігти цьому, вам потрібно відключити режим "компіляції", і якщо ви хочете його використовувати, запустіть його.

php -f shell/compiler.php disable
php -f shell/compiler.php clear
php -f shell/compiler.php compile

Спробував очистити та відключити компілятор і все-таки отримати помилку. Будь-які інші ідеї будуть вдячні.
littleredsunshine

Запустити компіляцію працює !!!
MageDev

Абхішек ти мій герой! Ця публікація вирішила проблему, на яку я витратив години з аналогічною помилкою, ніж вище. Компіляція з панелі адміністратора викликає помилки. Але біг із командного рядка спрацював нормально :)
MagentoMac

4

Перевірте, чи правильно у вашому модулі XML-код спостерігача за подіями config.xml.

Це має бути приблизно так:

<events>
    <event_name_that_you_are_working_on>
        <observers>
            <some_unique_identifier>
                <type>singleton</type>
                <class>YourNamespace_YourModule_Model_Observer</class>
                <method>functionNameInYourObserver</method>
            </some_unique_identifier>
        </observers>
    </event_name_that_you_are_working_on>
</events>

Одного разу я отримав подібну помилку, оскільки використовував modulename/observerвсередині вузла класу. Використання повної назви класу ( YourNamespace_YourModule_Model_Observer) вирішило для мене помилку.

У xml-коді спостерігача за подіями вашого модуля ви можете використовувати, classяк нижче:

<class>yourmodule/observer</class>

Спробуйте використовувати це замість цього (як це зроблено у наведеному вище коді xml-коду спостерігача подій):

<class>YourNamespace_YourModule_Model_Observer</class>

1
  1. Вимкніть розширення з app\etc\moduelsкаталогу.
  2. Очистити кеш і
  3. Виконати компіляцію.

Тепер це буде добре працювати.


0

Перше відключення компіляції та кешу.

І очистити весь кеш-пам'ять насильно.

Потім встановіть Extension.

Після цього запустіть процес компіляції.

Вище процес працював на мене.


0

Щоб відключити компіляцію в Magento, редагування включає / config.php. Приблизно у рядку 28 коментуйте перший рядок та прокоментуйте другий:

#define('COMPILER_INCLUDE_PATH', dirname(__FILE__).DIRECTORY_SEPARATOR.'src');
define('COMPILER_COLLECT_PATH', dirname(__FILE__).DIRECTORY_SEPARATOR.'stat');
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.