Enterprise 1.14.1 Зразки, що спричиняють 35 секунд плюс час завантаження на сторінках категорії


23

Ми втілили нову вбудовану функцію Swatch в нашій новій новій збірці сайту. Коли ми вмикаємо зразки на сторінках категорій, час завантаження сторінки переходить від 2 секунд до 38 + секунд.

Мені було цікаво, чи не було у когось іншого цього питання, і якщо так, чи міг би він вказати на можливі рішення?

Ми спробували EE 1.14.1 і CE 1.9.1 з 36 настроюваними продуктами з зразками, застосованими на стандартній темі RWD, і жодних інших модулів не активовано.

Цю проблему неможливо вирішити кешуванням, оскільки кожен раз, коли користувач шукає або фільтрує категорію, сторінка знову перемелюється до зупинки.


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

Ми використовуємо атрибути - кольорові зразки та розміри не більше 8 на предмет, а в більшості випадків - не більше 4. Це запускається на пустій ​​установці magento CE 1.9.1 із завантаженими зразками даних та 10 настроюваних продуктів із спеціальними зразками додано. Це, безумовно, пов'язане з зразками, оскільки чим більше ми додаємо, тим повільніше стає сайт. Зверніть увагу, що кешування вимкнено, щоб перевірити це, оскільки користувачі можуть фільтрувати пошук, і ми не можемо мати шалений час завантаження кожного разу, коли користувач налаштовує їх пошук. Дякуємо за Ваш час :)
Дейв Бевінгтон

Відповіді:


22

Правильно. Я виявляю проблему на функції Mage_ConfigurableSwatches_Helper_Mediafallback :: attachConfigurableProductChildrenAttributeMapping.

Я вношу на цьому деякі зміни. Це збільшує продуктивність.

Спробуйте:

  1. Скопіювати /app/code/core/Mage/ConfigurableSwatches/Helper/Mediafallback.phpв /app/code/local/Mage/ConfigurableSwatches/Helper/Mediafallback.php.

  2. У /app/code/local/Mage/ConfigurableSwatches/Helper/Mediafallback.phpфайлі перемістіть цей код (8.8-91)

     // normalize to all lower case before we start using them
     $optionLabels = array_map(function ($value) {
      return array_map('Mage_ConfigurableSwatches_Helper_Data::normalizeKey', $value);
     }, $optionLabels);

    до foreachциклу.

Це змінений метод:

 /**
 * Set child_attribute_label_mapping on products with attribute label -> product mapping
 * Depends on following product data:
 * - product must have children products attached
 *
 * @param array $parentProducts
 * @param $storeId
 * @return void
 */
public function attachConfigurableProductChildrenAttributeMapping(array $parentProducts, $storeId)
{
    $listSwatchAttr = Mage::helper('configurableswatches/productlist')->getSwatchAttribute();

    $parentProductIds = array();
    /* @var $parentProduct Mage_Catalog_Model_Product */
    foreach ($parentProducts as $parentProduct) {
        $parentProductIds[] = $parentProduct->getId();
    }

    $configAttributes = Mage::getResourceModel('configurableswatches/catalog_product_attribute_super_collection')
        ->addParentProductsFilter($parentProductIds)
        ->attachEavAttributes()
        ->setStoreId($storeId)
    ;

    $optionLabels = array();
    foreach ($configAttributes as $attribute) {
        $optionLabels += $attribute->getOptionLabels();
    }

    // normalize to all lower case before we start using them
    $optionLabels = array_map(function ($value) {
        return array_map('Mage_ConfigurableSwatches_Helper_Data::normalizeKey', $value);
    }, $optionLabels);

    foreach ($parentProducts as $parentProduct) {
        $mapping = array();
        $listSwatchValues = array();

        /* @var $attribute Mage_Catalog_Model_Product_Type_Configurable_Attribute */
        foreach ($configAttributes as $attribute) {
            /* @var $childProduct Mage_Catalog_Model_Product */
            if (!is_array($parentProduct->getChildrenProducts())) {
                continue;
            }

            foreach ($parentProduct->getChildrenProducts() as $childProduct) {

                // product has no value for attribute, we can't process it
                if (!$childProduct->hasData($attribute->getAttributeCode())) {
                    continue;
                }
                $optionId = $childProduct->getData($attribute->getAttributeCode());

                // if we don't have a default label, skip it
                if (!isset($optionLabels[$optionId][0])) {
                    continue;
                }

                // using default value as key unless store-specific label is present
                $optionLabel = $optionLabels[$optionId][0];
                if (isset($optionLabels[$optionId][$storeId])) {
                    $optionLabel = $optionLabels[$optionId][$storeId];
                }

                // initialize arrays if not present
                if (!isset($mapping[$optionLabel])) {
                    $mapping[$optionLabel] = array(
                        'product_ids' => array(),
                    );
                }
                $mapping[$optionLabel]['product_ids'][] = $childProduct->getId();
                $mapping[$optionLabel]['label'] = $optionLabel;
                $mapping[$optionLabel]['default_label'] = $optionLabels[$optionId][0];
                $mapping[$optionLabel]['labels'] = $optionLabels[$optionId];

                if ($attribute->getAttributeId() == $listSwatchAttr->getAttributeId()
                    && !in_array($mapping[$optionLabel]['label'], $listSwatchValues)
                ) {
                    $listSwatchValues[$optionId] = $mapping[$optionLabel]['label'];
                }
            } // end looping child products
        } // end looping attributes


        foreach ($mapping as $key => $value) {
            $mapping[$key]['product_ids'] = array_unique($mapping[$key]['product_ids']);
        }

        $parentProduct->setChildAttributeLabelMapping($mapping)
            ->setListSwatchAttrValues($listSwatchValues);
    } // end looping parent products
}

У мене була така ж проблема з включеними зразками на сторінках списку, і це допомогло значно прискорити роботу, тому дякую!
Marlon Creative

Я знайшов ту саму проблему. Вирішивши це, завантаження сторінки зайняло від 2,5 хвилин до 7 секунд.
Ендрю Кетт

Ці зразки дійсно сповільнюють категорії, особливо коли у вас багато конфігураційних продуктів. Рішення Андрея М. скоротити завантаження з 10 до 3 секунд для категорії, наповненої налаштованими продуктами! Дякую!
користувач1895954

+1! Дякуємо, що поділилися цим. Ми використовуємо багато конфігуруються з декількома варіантами один і просто не могли використовувати зразки кольору більше ...
Marc

+1! Абсолютно геніальна відповідь, час завантаження змінився з 28 секунд на 3 секунди! Дякую!!
KI

4

Додатковий спосіб покращити ефекти, які можна настроювати, коли у вас є багато варіантів атрибутів.

Наприклад, якщо у вас є 2000 варіантів і в списку каталогів відображається 36 товарів, у цьому випадку метод Mage_ConfigurableSwatches_Model_Resource_Catalog_Product_Attribute_Super_Collection::_loadOptionLabels()приєднається до кожної мітки опцій super_attributes, і ви отримаєте 2000 * 36 = 72000 рядків.

Я переписав цей метод, і він завантажує лише 2000 рядків замість 72000

<?php
/**
 * Load attribute option labels for current store and default (fallback)
 *
 * @return $this
 */
protected function _loadOptionLabels()
{
    if ($this->count()) {
        $labels = $this->_getOptionLabels();
        foreach ($this->getItems() as $item) {
            $item->setOptionLabels($labels);
        }
    }
    return $this;
}

/**
 * Get Option Labels
 *
 * @return array
 */
protected function _getOptionLabels()
{
    $attributeIds = $this->_getAttributeIds();

    $select = $this->getConnection()->select();
    $select->from(array('options' => $this->getTable('eav/attribute_option')))
        ->join(
            array('labels' => $this->getTable('eav/attribute_option_value')),
            'labels.option_id = options.option_id',
            array(
                'label' => 'labels.value',
                'store_id' => 'labels.store_id',
            )
        )
        ->where('options.attribute_id IN (?)', $attributeIds)
        ->where(
            'labels.store_id IN (?)',
            array(Mage_Catalog_Model_Abstract::DEFAULT_STORE_ID, $this->getStoreId())
        );

    $resultSet = $this->getConnection()->query($select);
    $labels = array();
    while ($option = $resultSet->fetch()) {
        $labels[$option['option_id']][$option['store_id']] = $option['label'];
    }
    return $labels;
}

/**
 * Get Attribute IDs
 *
 * @return array
 */
protected function _getAttributeIds()
{
    $attributeIds = array();
    foreach ($this->getItems() as $item) {
        $attributeIds[] = $item->getAttributeId();
    }
    $attributeIds = array_unique($attributeIds);

    return $attributeIds;
}
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.