【问题标题】:PHP Artisan Migrate Error in Lamp EnvironmentLamp 环境中的 PHP Artisan Migrate 错误
【发布时间】:2020-10-26 21:05:49
【问题描述】:

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

在我的 XAMPP 中,我的服务器是:localhost:8080

我有一个错误,上面写着

照亮\数据库\查询异常] SQLSTATE[HY000] [2002] No such file or directory (SQL: select * from information_schema.tables where table_schema = laravel and table_name = migrations)

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

我不确定“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}"

数据库.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'),
            ]) : [],
        ],

【问题讨论】:

  • 你可以试试“composer dump-autoload”来逗我吗
  • 你跑php artisan migrate:install了吗?
  • 与 DB_HOST=127.0.0.1 而不是 localhost 有何不同?
  • 我试过'localhost;也是,但它没有工作。 @JamesClarkDeveloper

标签: php mysql laravel migration database-migration


【解决方案1】:

更新 - XAMPP VM 解决方案

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

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

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

  • CREATE USER 'admin'@'%' IDENTIFIED BY 'admin';
  • 使用 GRANT 选项将 . 上的所有权限授予 'admin'@'%';
  • 刷新特权;

这将允许您使用具有 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

现在迁移应该对你有好处。

参考:

【讨论】:

    【解决方案2】:

    如果你使用的是 mac

    在终端写入

    composer global 需要 "laravel/installer"(回车)

    nano .bash_profile(回车)

    按 i 键,你就可以写了

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

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

    然后打开你的 XAMPP

    点击常规

    点击打开终端

    点击终端

    密码(输入)

    cd 空格 ..(回车)

    cd 选择/

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

    cd htdocs

    cd 你的 laravel 文件夹名称

    php 工匠迁移

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

    希望能成功

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2020-11-27
      • 2016-05-14
      • 2015-12-19
      • 2016-10-14
      • 2020-10-23
      • 2018-08-04
      • 2018-11-18
      • 1970-01-01
      相关资源
      最近更新 更多