Как исправить ошибку mysql_connect() в wp cli

Проблема:

Я пытаюсь использовать wp cli, чтобы делать что-то. В качестве примера обновить wordpress:

wp core update

Fatal error: Uncaught Error: Call to undefined function mysql_connect() in 
path\to\wp-includes\wp-db.php:1564
Stack trace:
#0 path\to\wp-includes\wp-db.php(592): wpdb->db_connect()
#1 path\to\wp-includes\load.php(404): 
wpdb->__construct(details)
#2 path\to\public\wp-settings.php(106): require_wp_db()
#3 phar://path/to/wp-cli.phar/php/WP_CLI/Runner.php(1182): require('C:\\path\\to\\...')
#4 phar://path/to/wp-cli.phar/php/WP_CLI/Runner.php(1107): WP_CLI\Runner->load_wordpress()
#5 phar://path/to/wp-cli.phar/php/WP_CLI/Bootstrap/LaunchRunner.php(23): WP_CLI\Runner->start()
#6 phar://path/to/wp-cli.phar/php/bootstrap.php(75): WP_CLI\Bootstrap\LaunchRunner->process(Object(WP_CLI\Bootstrap\BootstrapState))
#7 phar://path/to/wp-cli.phar/php/wp-cli.php(23): WP_CLI\bootstrap()
#8 phar://C:/ in path/to\wp-includes\wp-db.php on line 1564

Насколько я вижу, ошибка в mysql_connect().

Я прочитал следующие ответы:

  • Неопределенная функция mysql_connect(). Похоже, это предлагало загрузить некоторые пакеты. Я не хочу этого делать, потому что я не понимаю, что они делают (и в настоящее время я запускаю php с использованием MAMP, поэтому я не уверен, что это вызовет у меня больше проблем), но это действительно подсказало мне, что проблема была с php .ini, который сообщает о попытке решения ниже.
  • Неустранимая ошибка: вызов неопределенной функции mysql_connect() - I не думаю, что в моих данных для входа есть ошибка (сам сайт работает), так что похоже проблема не в этом

Попытка решения - php.ini

Когда я проверяю, какой php.ini wp cli использует через

wp--info

команда. Он печатает следующее:

OS:     Windows NT 10.0 build 17134 (Windows 10) i586
Shell:  C:\Program Files\Git\usr\bin\bash.exe
PHP binary:     C:\MAMP\bin\php\php7.2.1\php.exe
PHP version:    7.2.1
php.ini used:
WP-CLI root dir:        phar://wp-cli.phar
WP-CLI vendor dir:      phar://wp-cli.phar/vendor
WP_CLI phar path:       C:\path\to\public
WP-CLI packages dir:
WP-CLI global config:
WP-CLI project config:
WP-CLI version: 1.5.1

Так что, похоже, здесь не использовался php.ini. Поэтому я думаю, что мне нужно это исправить. Для этого я нашел $WP_CLI_PHP_ARGS, который я Я пытаюсь вставить. Теперь я не суперзвезда кодирования, но, похоже, мне нужно создать сценарий bash, который будет действовать как оболочка, потому что они не работают в версии .phar, поэтому я объединил две оболочки, которые я нашел в Интернете, чтобы создать это:

#!/usr/bin/env sh

dir=$(d=${0%[/\\]*}; cd "$d"; pwd)

# See if we are running in Cygwin by checking for cygpath program
if command -v 'cygpath' >/dev/null 2>&1; then
   # Cygwin paths start with /cygdrive/ which will break windows PHP,
   # so we need to translate the dir path to windows format. However
   # we could be using cygwin PHP which does not require this, so we
   # test if the path to PHP starts with /cygdrive/ rather than /usr/bin
   if [[ $(which php) == /cygdrive/* ]]; then
       dir=$(cygpath -m $dir);
   fi
fi

dir=$(echo $dir | sed 's/ /\ /g')
"${WP_CLI_PHP}" $WP_CLI_PHP_ARGS "${dir}/wp-cli.phar" "$@"

Когда я запускаю это, он по-разному жалуется. Я полагаю, что сделал какую-то основную ошибку. (Я также добавил «экспорт WP_CLI_PHP_ARGS=/C/MAMP/bin/php/php7.2.1/php.ini-production» в свой .bash_profile).


person NYoung    schedule 13.06.2018    source источник


Ответы (3)


mysql_connect() устарел, начиная с PHP 5.5, и удален в PHP 7 , PHP 5.5 не является поддерживаемой версией PHP, поэтому автору следует обновить свой код.

Вместо этого используйте mysqli_connect().

person Thomas Edwards    schedule 13.06.2018
comment
да я это видел. Спасибо. Как мне сделать это в реальности для wp cli? Я пытался изменить файл php.ini, похоже ли это на правильный подход? - person NYoung; 13.06.2018
comment
Нет, если вам нужно отредактировать php.ini что-то не так. Какую версию WordPress вы используете? - person Thomas Edwards; 13.06.2018
comment
Вордпресс 4.9.6 - person NYoung; 13.06.2018
comment
Спасибо за ваше время. Затем я получаю это: Ошибка: не удалось получить URL-адрес 'api.github.com/repos/wp-cli/wp-cli/releases?per_page=100': Рабочие транспорты не найдены. - person NYoung; 13.06.2018
comment
Моя версия 1.5.1, так что я думаю, что она актуальна. - person NYoung; 13.06.2018

Хорошо, хорошо.

Таким образом, проблема была отмечена wp-db, и казалось, что mysql не работает, но это была mysqli. В конце концов у меня заработал файл php.ini, но я решил опубликовать все различные решения, которые могут помочь другим. Номер 4 - это то, что сработало для меня.

1) Отключите mysql_connect, чтобы WordPress использовал mysqli_connect. Перейдите в wp-config.php и добавьте строку

define('WP_USE_EXT_MYSQL', false);

2) Убедитесь, что файл php.ini присутствует в поле команды configure --with-mysqli=shared?

3) Обновите файл mysqli. Я не делал этого, но, следуя этому, совет, похоже, состоит в том, чтобы запустить это в твоей оболочке.

sudo apt-get install mysql-server mysql-common php7.0 php7.0-mysql

Я запускаю git-bash в Windows, так что у меня появляется куча чепухи. Если вы используете Linux, это может сработать.

4) Как и выше, я заметил, что php.ini не был указан в wp --info. Я нашел нужный файл с помощью (просто создайте файл с этим и зайдите на него с вашего сервера). Это оказалось в другом месте, чем я ожидал. Затем я возился с оболочкой bash выше и в конце концов получил это, из-за чего ошибка исчезла:

#!/usr/bin/env sh

dir=$(d=${0%[/\\]*}; cd "$d"; pwd)

# See if we are running in Cygwin by checking for cygpath program
if command -v 'cygpath' >/dev/null 2>&1; then
   # Cygwin paths start with /cygdrive/ which will break windows PHP,
   # so we need to translate the dir path to windows format. However
   # we could be using cygwin PHP which does not require this, so we
   # test if the path to PHP starts with /cygdrive/ rather than /usr/bin
   if [[ $(which php) == /cygdrive/* ]]; then
       dir=$(cygpath -m $dir);
   fi
fi

dir=$(echo $dir | sed 's/ /\ /g')
php -c $WP_CLI_PHP_ARGS "${dir}/wp-cli.phar" "$@"

Если я сделал что-то глупое, дайте мне знать, спасибо за ваше время. Не стесняйтесь обращаться за разъяснениями.

person NYoung    schedule 14.06.2018

Похоже, ваша установка WordPress пытается использовать mysql_connect в wp-db.php. Wordpress по умолчанию использует mysql_connect, если не может найти установленный mysqli ИЛИ переопределяется.

mysqli устанавливается с php 7 (и вы используете php 7).

Итак, проверьте wp-config.php и убедитесь, что WP_USE_EXT_MYSQL определяется как false

person mani    schedule 13.06.2018
comment
Я добавил это, но, насколько я могу судить, это ничего не изменило. - person NYoung; 13.06.2018