Prestashop медленный бэк-офис (initContent: 12000ms) - PullRequest
0 голосов
/ 01 октября 2018

Я работаю в магазине Prestashop уже более 2 лет, так как сегодня утром бэк-офис работает очень медленно.Таким образом, я использовал режим отладки, и я вижу, что initContent требует 12 секунд для загрузки ... Ничто другое не кажется неправильным в журнале отладки.Я не установил новый модуль и не изменил никаких параметров, вчера вечером BO работал нормально.

Я немного искал и нашел некоторые «исправления», которые мне не подходят:

  • Отключение модулей статистики (уже отключено).
  • Изменение разрешений для папки config / xml и удаление файлов в ней.

Я читал еще кое-что о подключении кPrestashop серверы.Ребята, у вас есть какая-нибудь информация об этом?

BackOffice debug screenshot

Ответы [ 2 ]

0 голосов
/ 02 октября 2018

Prestashop проверяет список модулей, связанных с вкладками бэк-офиса.Вы можете увидеть кнопку «Рекомендуемые модули» на панелях инструментов заголовка страниц бэк-офиса.

Чтобы отключить эту опцию, создайте файл /override/classes/controller/AdminController.php со следующим содержимым:

class AdminController extends AdminControllerCore
{
    protected function initTabModuleList()
    {
        return;
    }
}

Обратите внимание, что вы не будетепотерял другие функции, связанные с аддонами.

0 голосов
/ 01 октября 2018

В некоторых моих проектах я могу подтвердить, что за эту задержку отвечает проверка дополнений Prestashop.

Это можно быстро исправить, отключив все подключения к серверам Prestashop класса Tools.

Создайте файл /override/classes/Tools.php со следующим содержимым:

<?php

class Tools extends ToolsCore {
    public static function addonsRequest($request, $params = array())
    {
        return false;
    }
}

Затем удалите файл /cache/class_index.php.


Ограничение вышеприведенного решения состоит в том, что вы потеряете все дополнениясопутствующие функции (обновления модулей, темы и предложения модулей ...).Я в порядке, но это может быть не так.

Поэтому вместо полного отключения подключений аддонов вы можете сократить время ожидания запроса (с 5 до 2 секунд):

Создатьфайл /override/classes/Tools.php со следующим содержанием:

<?php

class Tools extends ToolsCore {
    public static function addonsRequest($request, $params = array())
    {
        if (!self::$is_addons_up) {
            return false;
        }

        $post_data = http_build_query(array(
            'version' => isset($params['version']) ? $params['version'] : _PS_VERSION_,
            'iso_lang' => Tools::strtolower(isset($params['iso_lang']) ? $params['iso_lang'] : Context::getContext()->language->iso_code),
            'iso_code' => Tools::strtolower(isset($params['iso_country']) ? $params['iso_country'] : Country::getIsoById(Configuration::get('PS_COUNTRY_DEFAULT'))),
            'shop_url' => isset($params['shop_url']) ? $params['shop_url'] : Tools::getShopDomain(),
            'mail' => isset($params['email']) ? $params['email'] : Configuration::get('PS_SHOP_EMAIL')
        ));

        $protocols = array('https');
        $end_point = 'api.addons.prestashop.com';

        switch ($request) {
            case 'native':
                $protocols[] = 'http';
                $post_data .= '&method=listing&action=native';
                break;
            case 'native_all':
                $protocols[] = 'http';
                $post_data .= '&method=listing&action=native&iso_code=all';
                break;
            case 'must-have':
                $protocols[] = 'http';
                $post_data .= '&method=listing&action=must-have';
                break;
            case 'must-have-themes':
                $protocols[] = 'http';
                $post_data .= '&method=listing&action=must-have-themes';
                break;
            case 'customer':
                $post_data .= '&method=listing&action=customer&username='.urlencode(trim(Context::getContext()->cookie->username_addons))
                    .'&password='.urlencode(trim(Context::getContext()->cookie->password_addons));
                break;
            case 'customer_themes':
                $post_data .= '&method=listing&action=customer-themes&username='.urlencode(trim(Context::getContext()->cookie->username_addons))
                    .'&password='.urlencode(trim(Context::getContext()->cookie->password_addons));
                break;
            case 'check_customer':
                $post_data .= '&method=check_customer&username='.urlencode($params['username_addons']).'&password='.urlencode($params['password_addons']);
                break;
            case 'check_module':
                $post_data .= '&method=check&module_name='.urlencode($params['module_name']).'&module_key='.urlencode($params['module_key']);
                break;
            case 'module':
                $post_data .= '&method=module&id_module='.urlencode($params['id_module']);
                if (isset($params['username_addons']) && isset($params['password_addons'])) {
                    $post_data .= '&username='.urlencode($params['username_addons']).'&password='.urlencode($params['password_addons']);
                } else {
                    $protocols[] = 'http';
                }
                break;
            case 'hosted_module':
                $post_data .= '&method=module&id_module='.urlencode((int)$params['id_module']).'&username='.urlencode($params['hosted_email'])
                    .'&password='.urlencode($params['password_addons'])
                    .'&shop_url='.urlencode(isset($params['shop_url']) ? $params['shop_url'] : Tools::getShopDomain())
                    .'&mail='.urlencode(isset($params['email']) ? $params['email'] : Configuration::get('PS_SHOP_EMAIL'));
                $protocols[] = 'https';
                break;
            case 'install-modules':
                $protocols[] = 'http';
                $post_data .= '&method=listing&action=install-modules';
                $post_data .= defined('_PS_HOST_MODE_') ? '-od' : '';
                break;
            default:
                return false;
        }

        $context = stream_context_create(array(
            'http' => array(
                'method'  => 'POST',
                'content' => $post_data,
                'header'  => 'Content-type: application/x-www-form-urlencoded',
                'timeout' => 2,
            )
        ));

        foreach ($protocols as $protocol) {
            if ($content = Tools::file_get_contents($protocol.'://'.$end_point, false, $context)) {
                return $content;
            }
        }

        self::$is_addons_up = false;
        return false;
    }
}

Затем удалите файл /cache/class_index.php.

...