WSL windows laravel SQLSTATE[HY000] [2002]
WSL windows laravel SQLSTATE[HY000] [2002]
我最近在我的 windows 机器上使用 WSL (Ubuntu 20.4) 和 docker 开始了一个 laravel(8) 项目。从数据库中读取数据时,我收到 DB_HOST=localhost
的错误 'SQLSTATE[HY000] [2002]No such file or directory' 或 DB_HOST=127.0.0.1
的 'SQLSTATE[HY000] [2002] Connection refused'。但是,只有当我使用 ./vendor/bin/sail up
启动整个项目时才会出现此问题,当我使用 php artisan serve
启动同一项目时,任何 DB_HOST
配置都不会出现错误。
显示数据库中内容的索引函数
public function index()
{
dd(Customer::all());
}
客户对象
class Customer extends Model
{
use HasFactory;
protected $table = 'customers';
protected $primaryKey = 'id';
}
.env 文件
APP_NAME=Laravel
APP_ENV=local
APP_KEY=base64:WtHehq3ZteXPe6xEIij2TBblW7Qo3VUd5obTao3Kg4U=
APP_DEBUG=true
APP_URL=http://thc.test
LOG_CHANNEL=stack
LOG_DEPRECATIONS_CHANNEL=null
LOG_LEVEL=debug
DB_CONNECTION=mysql
DB_HOST=localhost
DB_PORT=3306
DB_DATABASE=thc
DB_USERNAME=root
DB_PASSWORD=
BROADCAST_DRIVER=log
CACHE_DRIVER=file
FILESYSTEM_DRIVER=local
QUEUE_CONNECTION=sync
SESSION_DRIVER=file
SESSION_LIFETIME=120
MEMCACHED_HOST=memcached
REDIS_HOST=redis
REDIS_PASSWORD=null
REDIS_PORT=6379
MAIL_MAILER=smtp
MAIL_HOST=mailhog
MAIL_PORT=1025
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=
AWS_USE_PATH_STYLE_ENDPOINT=false
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}"
SCOUT_DRIVER=meilisearch
MEILISEARCH_HOST=http://meilisearch:7700
我已经尝试过将 unix_socket
设置为 '/Applications/MAMP/tmp/mysql/mysql.sock' 以及 'socket' 条目的 show variables like '%sock%';
结果的解决方案。我尝试在“.env”文件和 'database.php'.
中设置此值
命令
php artisan key:generate
php artisan cache:clear
php artisan route:clear
php artisan config:clear
php artisan view:clear
也让我失望
如果您使用 docker
,则不必使用任何主机作为 localhost
,而是使用服务名称作为主机,例如,如果您 docker-compose.yaml
是这样的:
version: '3.9'
services:
superNiceDb:
image: mysql:8.0
command: --default-authentication-plugin=mysql_native_password
environment:
MYSQL_DATABASE: 'laravel'
MYSQL_ROOT_PASSWORD: '123'
volumes:
- ./docker/mysql_data:/var/lib/mysql
- ./docker/mysql:/docker-entrypoint-initdb.d
ports:
- ${DB_PORT:-3306}:3306
您必须在 .env
中或您从中读取该值的任何地方使用 DB_HOST=superNiceDb
。
这适用于任何系统,如果您正在使用 docker,这是引用服务的唯一方式,切勿使用 localhost
。
我最近在我的 windows 机器上使用 WSL (Ubuntu 20.4) 和 docker 开始了一个 laravel(8) 项目。从数据库中读取数据时,我收到 DB_HOST=localhost
的错误 'SQLSTATE[HY000] [2002]No such file or directory' 或 DB_HOST=127.0.0.1
的 'SQLSTATE[HY000] [2002] Connection refused'。但是,只有当我使用 ./vendor/bin/sail up
启动整个项目时才会出现此问题,当我使用 php artisan serve
启动同一项目时,任何 DB_HOST
配置都不会出现错误。
显示数据库中内容的索引函数
public function index()
{
dd(Customer::all());
}
客户对象
class Customer extends Model
{
use HasFactory;
protected $table = 'customers';
protected $primaryKey = 'id';
}
.env 文件
APP_NAME=Laravel
APP_ENV=local
APP_KEY=base64:WtHehq3ZteXPe6xEIij2TBblW7Qo3VUd5obTao3Kg4U=
APP_DEBUG=true
APP_URL=http://thc.test
LOG_CHANNEL=stack
LOG_DEPRECATIONS_CHANNEL=null
LOG_LEVEL=debug
DB_CONNECTION=mysql
DB_HOST=localhost
DB_PORT=3306
DB_DATABASE=thc
DB_USERNAME=root
DB_PASSWORD=
BROADCAST_DRIVER=log
CACHE_DRIVER=file
FILESYSTEM_DRIVER=local
QUEUE_CONNECTION=sync
SESSION_DRIVER=file
SESSION_LIFETIME=120
MEMCACHED_HOST=memcached
REDIS_HOST=redis
REDIS_PASSWORD=null
REDIS_PORT=6379
MAIL_MAILER=smtp
MAIL_HOST=mailhog
MAIL_PORT=1025
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=
AWS_USE_PATH_STYLE_ENDPOINT=false
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}"
SCOUT_DRIVER=meilisearch
MEILISEARCH_HOST=http://meilisearch:7700
我已经尝试过将 unix_socket
设置为 '/Applications/MAMP/tmp/mysql/mysql.sock' 以及 'socket' 条目的 show variables like '%sock%';
结果的解决方案。我尝试在“.env”文件和 'database.php'.
命令
php artisan key:generate
php artisan cache:clear
php artisan route:clear
php artisan config:clear
php artisan view:clear
也让我失望
如果您使用 docker
,则不必使用任何主机作为 localhost
,而是使用服务名称作为主机,例如,如果您 docker-compose.yaml
是这样的:
version: '3.9'
services:
superNiceDb:
image: mysql:8.0
command: --default-authentication-plugin=mysql_native_password
environment:
MYSQL_DATABASE: 'laravel'
MYSQL_ROOT_PASSWORD: '123'
volumes:
- ./docker/mysql_data:/var/lib/mysql
- ./docker/mysql:/docker-entrypoint-initdb.d
ports:
- ${DB_PORT:-3306}:3306
您必须在 .env
中或您从中读取该值的任何地方使用 DB_HOST=superNiceDb
。
这适用于任何系统,如果您正在使用 docker,这是引用服务的唯一方式,切勿使用 localhost
。