Prestashop缓慢后台(initContent:12000ms)

问题描述 投票:2回答:2

我现在经营Prestashop商店超过2年,因为今天早上后台非常慢。所以我使用了调试模式,我可以看到initContent正在加载12秒......在调试日志中没有其他任何错误。我没有安装新模块或更改任何参数,B-O昨天晚上工作正常。

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

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

我已经阅读了关于连接到Prestashop服务器的其他一些事情。你们有这方面的任何信息吗?

BackOffice debug screenshot

prestashop prestashop-1.6 add-on
2个回答
3
投票

我可以在我的一些项目中确认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


2
投票

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

要禁用此选项,请使用以下内容创建文件/override/classes/controller/AdminController.php

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

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

© www.soinside.com 2019 - 2024. All rights reserved.