Prestashop缓慢的后台办公(initContent:12000ms)

时间:2018-10-01 13:13:36

标签: prestashop prestashop-1.6 add-on

我经营Prestashop商店已有2年多了,因为今天早晨,后台的运行速度非常慢。 因此,我使用了调试模式,可以看到initContent花费了12秒的时间...调试日志中似乎没有其他问题。我没有安装新模块或更改任何参数,B-O昨天晚上工作正常。

我搜索了一下,发现一些对我不起作用的“修复程序”:

  • 禁用统计模块(已禁用)。
  • 更改config / xml文件夹的权限并删除其中的文件。

我已经阅读了有关与Prestashop服务器连接的其他信息。你们有什么信息吗?

BackOffice debug screenshot

2 个答案:

答案 0 :(得分:2)

我可以在我的某些项目中确认Prestashop Addons检查是造成此延迟的原因。

您可以通过禁用与​​Tools类中的Prestashop服务器的所有连接来快速解决此问题。

创建具有以下内容的文件/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

答案 1 :(得分:2)

Prestashop检查与后台标签相关的模块列表。您可以在后台页面的标题工具栏中看到“推荐模块”按钮。

要禁用此选项,请创建一个包含以下内容的文件/override/classes/controller/AdminController.php

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

请注意,您不会丢失其他与插件相关的功能。