PHP Lamp 环境中的 Artisan 迁移错误

PHP Artisan Migrate Error in Lamp Environment

我在 MAC,我的 XAMPP 是 XAMPP-VM,并用 lampp 创建了一个文件夹。

在我的XAMPP,我的服务器is:localhost:8080

我有一个错误,上面写着

Illuminate\Database\QueryException] SQLSTATE[HY000] [2002] No such file or directory (SQL: select * from information_schema.tables where table_schema = laravel and table_name = migrations)

我尝试了很多解决方案,但 none 对我有用。

我不确定 'DB_SOCKET' 是什么以及文件路径在 XAMPP 中的位置。

.env

    APP_NAME=Laravel
    APP_ENV=local
    APP_KEY=base64:zS3EUWDenTnhNu0CpN1TQdVSM0ArEgtFI1zpIwes1qQ=
    APP_DEBUG=true
    APP_URL=http://localhost

    LOG_CHANNEL=stack

    DB_CONNECTION=mysql
    DB_HOST=localhost
    DB_PORT=3306
    DB_DATABASE=demo
    DB_USERNAME=root
    DB_PASSWORD=
    DB_SOCKET=/Applications/lampp/tmp/mysql/mysql.sock

    BROADCAST_DRIVER=log
    CACHE_DRIVER=file
    QUEUE_CONNECTION=sync
    SESSION_DRIVER=file
    SESSION_LIFETIME=120
    REDIS_HOST=127.0.0.1
    REDIS_PASSWORD=null
    REDIS_PORT=6379

    MAIL_MAILER=smtp
    MAIL_HOST=smtp.mailtrap.io
    MAIL_PORT=2525
    MAIL_USERNAME=null
    MAIL_PASSWORD=null
    MAIL_ENCRYPTION=null
    MAIL_FROM_ADDRESS=null
    MAIL_FROM_NAME="${APP_NAME}"

    AWS_ACCESS_KEY_ID=
    AWS_SECRET_ACCESS_KEY=
    AWS_DEFAULT_REGION=us-east-1
    AWS_BUCKET=

    PUSHER_APP_ID=
    PUSHER_APP_KEY=
    PUSHER_APP_SECRET=
    PUSHER_APP_CLUSTER=mt1

    MIX_PUSHER_APP_KEY="${PUSHER_APP_KEY}"
    MIX_PUSHER_APP_CLUSTER="${PUSHER_APP_CLUSTER}"

database.php

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

更新 - XAMPP VM 解决方案

我以前描述的糟糕解决方案在不同的 XAMPP 安装中对我有用。由于您使用的是 XAMPP-VM,它实际上创建了一个 Debian VM,对 MySQL 具有不同的默认设置(可能是开箱即用的 VM 附带的 MariaDB)。因此,将禁止从您的本地计算机进行访问,默认情况下对于 PhpMyAdmin 也应进行限制,并且必须进行配置才能从 VM 外部进行访问。

当 XAMPP VM 启动时,它会为 VM 分配一个 IP(如下图所示):

这是应该在 .env 数据库配置中使用的 IP(我的情况 DB_HOST=192.168.64.2)。但是为了能够连接到 VM 中的 MariaDB,需要从 XAMPPs VM window 打开终端。进入后,输入mysql进入MariaDB,输入以下内容:

  • 创建用户 'admin'@'%' 由 'admin' 识别;
  • . 上的所有权限授予 'admin'@'%' WITH GRANT OPTION;
  • 刷新权限;

这将允许您使用具有 VM 外部所有权限的管理员用户从 Laravel 的应用程序访问 MySQL。 .env 文件应如下所示:

DB_CONNECTION=mysql
DB_HOST=192.168.64.2
DB_PORT=3306
DB_DATABASE=demo // this schema would have to be created first
DB_USERNAME=admin
DB_PASSWORD=admin

现在应该适合您迁移了。

参考:

如果您正在使用 mac

在终端写入

composer 全局要求“laravel/installer”(输入)

纳米 .bash_profile(输入)

按 i 按钮,这样你就可以写

export PATH="$PATH:$HOME/.composer/vender/bin"

按 alt+command 并输入按 x 按钮退出

那就开你XAMPP

点击常规

点击打开终端

点击终端

密码(输入)

cd space ..(输入)

cd 选择/

cd lampp(即使你使用的是xampp)

cd htdocs

cd ur laravel 文件夹名称

php artisan 迁移

https://www.youtube.com/watch?v=BUFyKk-GrvI&t=18s

我希望能奏效