PDOException: SQLSTATE [HY000] [2006] MySQL сервер ушел - PullRequest
0 голосов
/ 16 октября 2019

Я новичок в Laravel, поэтому начал создавать API. У меня уже есть база данных MySQL на локальном компьютере, и я пытаюсь подключиться к локальной базе данных, но получаю следующий logtrace

php artisan migrate



PDOException  : SQLSTATE[HY000] [2006] MySQL server has gone away

  at /Users/sandeeparmal/...../vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php:70
    66|         if (class_exists(PDOConnection::class) && ! $this->isPersistentConnection($options)) {
    67|             return new PDOConnection($dsn, $username, $password, $options);
    68|         }
    69| 
  > 70|         return new PDO($dsn, $username, $password, $options);
    71|     }
    72| 
    73|     /**
    74|      * Determine if the connection is persistent.

  Exception trace:

  1   PDO::__construct("mysql:host=127.0.0.1;port=8080;dbname=sample_server", "root", "", [])
      /Users/sandeeparmal/...../vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php:70

  2   Illuminate\Database\Connectors\Connector::createPdoConnection("mysql:host=127.0.0.1;port=8080;dbname=sample_server", "root", "", [])
      /Users/sandeeparmal/...../vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php:100

Вот мой файл .env:

DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=8080
DB_DATABASE=sample_server
DB_USERNAME=root
DB_PASSWORD=      

Вот мой файл database.php:

'default' => env('DB_CONNECTION', 'mysql'),
'connections' => [

    'sqlite' => [
        'driver' => 'sqlite',
        'url' => env('DATABASE_URL'),
        'database' => env('DB_DATABASE', database_path('database.sqlite')),
        'prefix' => '',
        'foreign_key_constraints' => env('DB_FOREIGN_KEYS', true),
    ],

    'mysql' => [
        'driver' => 'mysql',
        'url' => env('DATABASE_URL'),
        'host' => env('DB_HOST', '127.0.0.1'),
        'port' => env('DB_PORT', '8080'),
        'database' => env('DB_DATABASE', 'forcity_server'),
        'username' => env('DB_USERNAME', 'root'),
        'password' => env('DB_PASSWORD', ''),
        'unix_socket' => env('DB_SOCKET', ''),
        'charset' => 'utf8mb4',
        'collation' => 'utf8mb4_unicode_ci',
        'prefix' => '',
        'prefix_indexes' => true,
        'strict' => true,
        'engine' => null,
        'options' => extension_loaded('pdo_mysql') ? array_filter([
            PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'),
        ]) : [],
    ]

Я пытался найти решение и получил решение от здесь но все равно он не работает. Я применил то же самое в локальной базе данных.

1 Ответ

0 голосов
/ 16 октября 2019

Я обновил до laravel 6, поэтому я обновил PHP, потому что laravel 6 использует 7.2+ по умолчанию, там не было php.ini, и когда он был сгенерирован, расширение было отключено, поэтому я тоже попробовал миграцию и обнаружил

Проверьте php.ini, есть одна строка

;extension=pdo_mysql

сделайте это

extension=pdo_mysql

сохраните и перезапустите apache

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...