【问题标题】:WSL windows laravel SQLSTATE[HY000] [2002]WSL windows laravel SQLSTATE[HY000] [2002]
【发布时间】:2021-12-20 08:25:50
【问题描述】:

我最近使用 WSL (Ubuntu 20.4) 和 docker 在我的 windows 机器上启动了一个 laravel(8) 项目。从数据库读取数据时,DB_HOST=localhost 出现错误“SQLSTATE[HY000] [2002]No such file or directory”或DB_HOST=127.0.0.1 出现“SQLSTATE[HY000] [2002] Connection denied”。但是,这个问题只有在我使用./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 

我也失败了

【问题讨论】:

    标签: php mysql laravel eloquent laravel-8


    【解决方案1】:

    如果您使用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

    【讨论】:

    • 对于 'localhost' 或 '127.0.0.1' 以外的任何内容,即使是 php artisan migrate 命令也不适用于我。我将docker-compose.yml 文件的内容附加到网址pastebin.com/URUAGr2g
    • 仍然,您必须使用DB_HOST=mysql。如果您执行php artisan server,它将与localhost 一起使用,因为您不在docker 容器内...当您运行phpunit 时,您必须在容器内:docker-compose exec laravel.test bash 然后执行./vendor/bin/phpunit。跨度>
    猜你喜欢
    • 2019-04-13
    • 1970-01-01
    • 2017-05-04
    • 2021-12-13
    • 1970-01-01
    • 1970-01-01
    • 2017-09-20
    • 2020-03-26
    • 2020-12-04
    相关资源
    最近更新 更多