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
我希望能奏效
我在 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
我希望能奏效