Prestashop 缓慢的后台(initContent:12000ms)
Prestashop slow back-office (initContent : 12000ms)
我 运行 在 Prestashop 商店工作了 2 年多了,因为今天早上后台真的很慢。
所以我使用了调试模式,我可以看到 initContent
需要 12 秒才能加载...调试日志中似乎没有其他错误。我没有安装新模块或更改任何参数,B-O 昨天晚上工作正常。
我搜索了一下,发现一些 "fixes" 对我不起作用:
- 禁用统计模块(已经禁用)。
- 更改 config/xml 文件夹的权限并删除其中的文件。
我已经阅读了一些关于连接到 Prestashop 服务器的其他内容。你们有这方面的信息吗?
我可以在我的一些项目中确认 Prestashop Addons 检查是导致此延迟的原因。
您可以通过在 Tools
class.
中禁用与 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 检查与后台选项卡相关的模块列表。您可以在后台页面的 header 工具栏中看到推荐模块按钮。
要禁用此选项,请创建一个包含以下内容的文件 /override/classes/controller/AdminController.php
:
class AdminController extends AdminControllerCore
{
protected function initTabModuleList()
{
return;
}
}
请注意,您不会丢失其他与插件相关的功能。
我 运行 在 Prestashop 商店工作了 2 年多了,因为今天早上后台真的很慢。
所以我使用了调试模式,我可以看到 initContent
需要 12 秒才能加载...调试日志中似乎没有其他错误。我没有安装新模块或更改任何参数,B-O 昨天晚上工作正常。
我搜索了一下,发现一些 "fixes" 对我不起作用:
- 禁用统计模块(已经禁用)。
- 更改 config/xml 文件夹的权限并删除其中的文件。
我已经阅读了一些关于连接到 Prestashop 服务器的其他内容。你们有这方面的信息吗?
我可以在我的一些项目中确认 Prestashop Addons 检查是导致此延迟的原因。
您可以通过在 Tools
class.
创建一个包含以下内容的文件/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 检查与后台选项卡相关的模块列表。您可以在后台页面的 header 工具栏中看到推荐模块按钮。
要禁用此选项,请创建一个包含以下内容的文件 /override/classes/controller/AdminController.php
:
class AdminController extends AdminControllerCore
{
protected function initTabModuleList()
{
return;
}
}
请注意,您不会丢失其他与插件相关的功能。