Новости Joomla

Совет по Joomla: $db->getQuery(true) стал устаревшим

Совет по Joomla: $db->getQuery(true) стал устаревшим

👩‍💻 Совет по Joomla: $db->getQuery(true) стал устаревшим.Раньше при создании запросов в базу данных мы всегда получали объект запроса с помощью метода

getQuery(). Если передавался параметр
$new =
true, то получали новый запрос. Если без - последний.

use Joomla\CMS\Factory;$db = Factory::getContainer()->get('DatabaseDriver');$query = $db->getQuery(new: true);// и строим запрос
Под капот Joomla 4 вошёл Joomla Framework (PHP фреймворк а-ля Laravel, Yii и т.д.), а для Joomla 5 он обновился - версия 3.4.1 вышла 6 октября 2023г. В методе фреймворка есть примечание о том, что параметр
$new, который передавался в метод
getQuery() помечен как устаревший и будет удалён в версии фреймворка 4.0.
The parameter $new is deprecated and will be removed in 4.0, use %s::createQuery() instead.В Joomla 4 версия Joomla Framework была 2.x., в Joomla 5 - 3.x. Поэтому есть предположение, что с выходом Joomla 6 обновится и версия фреймворка - станет 4.0. Поэтому для получения объекта для новых запросов следует использовать метод
createQuery(). Он уже представлен в ядре и широко используется. При этом метод
getQuery() останется, но, скорее всего, будет выполнять функцию только геттера - получения текущего запроса.
@joomlafeed#joomla #php #разработка

0 Пользователей и 1 Гость просматривают эту тему.
  • 6 Ответов
  • 12323 Просмотров
*

capricorn

  • Завсегдатай
  • 1949
  • 118 / 3
Установил php 7.1.11 (из исходников). Joomla 3.8.1. Получаю ошибки:

Warning: session_start(): Failed to read session data: user (path: /tmp) in /var/www/html/zend-test.techtranslate247/htdocs/libraries/joomla/session/handler/native.php on line 260
Error displaying the error page: Application Instantiation Error: Failed to start the session

http://www.zend-test.techtranslate247.ru/

после обновления страницы пару раз появляется:

Error displaying the error page: Application Instantiation Error: Could not connect to MySQL.

Данные БД в configuration.php правильные. Обработчик сессий БД.

public $dbtype = 'mysqli';
public $session_handler = 'database';

Сессии без Joomla пишутся. http://www.zend-test.techtranslate247.ru/session.php

Код: php
<?php
session_start();
if (!isset($_SESSION['counter'])) $_SESSION['counter'] = 0;
echo "Вы обновили эту страницу " . $_SESSION['counter']++ . " раз. ";
echo "<br><a href=" . $_SERVER['PHP_SELF'] . ">обновить";
?>

Инфо http://www.zend-test.techtranslate247.ru/info.php

php.ini

https://yadi.sk/i/uOa6CgFJ3PMKZC

На этом же сервере этот сайт работал на php 5.6.28. И другие работают.

Нашел https://github.com/joomla/joomla-cms/issues/10855 Особой разницы в конфигурациях php не заметил.

Что может быть?
« Последнее редактирование: 04.11.2017, 05:41:47 от capricorn »
*

capricorn

  • Завсегдатай
  • 1949
  • 118 / 3
Re: Failed to read session data Joomla 3.8.1 php 7.1.11
« Ответ #1 : 02.11.2017, 19:48:15 »
Обе версии php работают в режиме FastCGI - с mod_fastcgi. Каталог сессий /tmp drwxrwxrwxt.

UPD. Пересобрал php. Как-то получилось. Кажется неправильно задал сначала путь к сокету mysql. Точно не могу сказать. В любом случае, научился устанавливать несколько версий php на CentOS.
« Последнее редактирование: 04.11.2017, 06:12:13 от capricorn »
*

dm-krv

  • Завсегдатай
  • 1028
  • 28 / 0
Обе версии php работают в режиме FastCGI - с mod_fastcgi. Каталог сессий /tmp drwxrwxrwxt.

UPD. Пересобрал php. Как-то получилось. Кажется неправильно задал сначала путь к сокету MySQL. Точно не могу сказать. В любом случае, научился устанавливать несколько версий php на CentOS.

Как ты решил эту проблему? У меня сайты на CentOS периодически ложатся с такой ошибкой. Может это какие-то лимиты к MySQL таким образом дают о себе знать? Потому что параллельно еще такая ошибка бывает на других сайтах в это же время:
Код
Error: Failed to start application: Could not connect to MySQL server.
И перегрузка сервера не помогает. Зато проблема сама рассасывается через некоторое время, т. е. явно нечто по программной части, а не из-за того, что сервер перегружен.  Не могу никак понять в чем дело.
« Последнее редактирование: 19.04.2019, 13:09:31 от dm-krv »
*

wishlight

  • Гуру
  • 5053
  • 314 / 1
  • От 300 руб быстрый хостинг. Сервера.
*

dm-krv

  • Завсегдатай
  • 1028
  • 28 / 0
mysqltuner если проверить?

Попробую в ПН. Сегодня опять словил эту ошибку, полез проверять и вижу, что MySQL банально выключен. Запустить повторно не смог и только через пол часа вдруг внезапно понял, что он запускается от отдельного пользователя) Собственно при повторении ошибки, попробую по логам проверить, что ему не так, а там уже будет видно.

Команды:
Код
systemctl status mysqld.service
Код
nano /var/log/mysqld.log
Код
journalctl -xe
Это уже для себя, чтобы не искать долго для копипаста.
*

Olegator

  • Новичок
  • 7
  • 0 / 0
В поиске выдалась эта страница, поэтому напишу будущим поколениям (а может и сам забуду в следующий раз и найду свой ответ). Такая же ошибка была, как у топикстартера. Считаю, что сообщение об ошибке неадекватное абсолютно! Не разбирался, как так, но проблема оказалась вовсе не в сессиях. Оказалось, просто не были установлены некоторые пакеты PHP. У меня параллельно несколько версий. Joomla запускал на 7.3 (в Ubuntu 18.04), а в этой версии у меня не было чего-то из этого (задал список всего, что было нужно на мой взгляд и что-то доустановилось):
Код
sudo apt-get install php7.3-cli php7.3-common php7.3-curl php7.3-gd php7.3-json php7.3-mbstring php7.3-mysql php7.3-opcache php7.3-xml php7.3-zip
*

d1KdaT

  • Новичок
  • 1
  • 0 / 0
Также одна из причин появления данной ошибки - отсутствие стандартного метода подключения для пользователя MySQL (native / socket). Решается указанием метода подключения или изменением пароля пользователя, в случае использования виртуального хостинга.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Нужна проф помощь в обновлении Joomla на лок.сервере osp. Можно платно

Автор Fati

Ответов: 0
Просмотров: 272
Последний ответ 16.06.2025, 16:40:04
от Fati
Помогите с БАГом в панели администратора Joomla 3

Автор akteon25

Ответов: 2
Просмотров: 1255
Последний ответ 26.02.2025, 16:41:56
от akteon25
Версии РНР и Joomla 3

Автор Ebelous

Ответов: 8
Просмотров: 3004
Последний ответ 27.01.2025, 20:38:45
от pavelrer
Trouble Upgrading from Joomla 3.8 to 3.9

Автор melissa00

Ответов: 0
Просмотров: 1831
Последний ответ 26.07.2024, 10:03:51
от melissa00
SP polls в Joomla 3.8.2

Автор wawont

Ответов: 2
Просмотров: 3489
Последний ответ 22.02.2024, 21:03:15
от Zegeberg