gpt4 book ai didi

Prestashop 慢后台(initContent : 12000ms)

转载 作者:行者123 更新时间:2023-12-02 14:56:36 24 4
gpt4 key购买 nike

我经营一家 Prestashop 商店已经 2 年多了,因为今天早上后台真的很慢。所以我使用了 Debug模式,我可以看到 initContent 需要 12 秒才能加载...调试日志中似乎没有其他错误。我没有安装新模块或更改任何参数,B-O 昨天晚上工作正常。

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

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

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

BackOffice debug screenshot

最佳答案

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

关于Prestashop 慢后台(initContent : 12000ms),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52591981/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com