当前位置: 首页 > 知识库问答 >
问题:

SQLSTATE[HY000][2002]在Laravel homestead内拒绝连接

邢嘉祯
2023-03-14

使用Mac OS X和2.2.1与Laravel 5.2.

在终端中(在我的项目文件夹中的homestead中),我可以使用php artisan查看所有可用的命令。当我尝试运行php artisan migrate时,我收到一个连接错误:
SQLSTATE[HY000][2002]连接被拒绝

我已经设置了一个Laravel项目与这些. env设置

DB_HOST=127.0.0.1
DB_DATABASE=tcv
DB_USERNAME=homestead
DB_PASSWORD=secret

我还尝试了localhost作为DB\u主机,root作为DB\u用户名和DB\u密码。把所有可能的变化放在一起!

在Sequel Pro(数据库管理应用程序)中,我可以连接这些设置

Host       127.0.0.1
Username   homestead
Password   secret
Database   tcv
Port       33060

但这个数据库显然是空的,因为我不能从终端迁移到它。。。

据我所知,这是一个配置问题,因为我可以用续集专业版连接到它。但老实说,我完全不知道是什么设置出错了。

谢谢你的帮助!!

编辑
由于某种原因,当我将项目移动到MAMP并运行php artisan migrate时,我收到了相同的SQLSTATE[HY000][2002]连接被拒绝错误。
现在我完全迷路了。。。

共有3个答案

施茂
2023-03-14

如果您在mac操作系统上使用MAMP,请在mysql数据库配置文件中添加以下行

'unix_socket' => env('DB_SOCKET', ''),

在您的. env文件中添加

DB_SOCKET=/Applications/MAMP/tmp/mysql/mysql.sock
宗啸
2023-03-14

问题

在Laravel中,您有配置/database.php,连接的所有设置都位于其中。在项目的根目录中还有一个. env文件(每个人都使用它来节省时间)。其中包含可用于整个项目的变量。

在一个标准的L5项目中,配置/database.php的MySql部分如下所示:

    'mysql' => [
        'driver'    => 'mysql',
        'host'      => env('DB_HOST', 'localhost'),
        'database'  => env('DB_DATABASE', 'forge'),
        'username'  => env('DB_USERNAME', 'forge'),
        'password'  => env('DB_PASSWORD', ''),
        'charset'   => 'utf8',
        'collation' => 'utf8_unicode_ci',
        'prefix'    => '',
        'strict'    => false,
        'engine'    => null,
    ],

请注意,没有端口集!

虽然在我的.env文件中,我设置了DB_PORT=33060。但是,这个值(3306)从未被读入config/database.php
所以不要像我这样愚蠢,忘记检查database.php文件。

冯枫涟
2023-03-14

我刚刚遇到了这个问题,发现将. env文件中的这个从127.0.0.1更改为localhost修复了它。

DB_HOST=localhost
 类似资料:
  • 所以我想部署我现有的laravel porject到我的digitalOcean vps我用户这个啧啧,我上传我的网站成功 我的环境文件也是 但问题是 我使用mysql创建并运行了,得到了这些错误,问题出在哪里 [Illumb\Database\QueryException]SQLSTATE[HY000][2002]连接被拒绝(SQL:select*from information\s chema

  • 问题内容: 我正在尝试使用PHP连接来连接phpmyadmin上的MySQL数据库。只是尝试查看连接是否成功,对连接没有什么幻想。我正在使用MAMP托管数据库,我尝试使用的连接是这样的: 我一直在使用邮递员进行测试,以查看连接是否正常工作,但是我一直收到以下错误消息: 连接失败:SQLSTATE [HY000] [2002]连接被拒绝 在收到以下错误消息之前: 连接失败:SQLSTATE [HY0

  • 我对Laravel还是个新手,但过去曾使用过几个框架。我正在使用一个Linux开发主机,并根据文档创建了一个docker容器,使用: 在此之后,我使用以下方法对其进行了改进: 我已经使用迁移创建了一个post表,它工作得很好,并使用tinker添加了一些示例条目。而且,这没有任何问题。但是当我试图使用该模型读取控制器中的所有表条目时,我得到一个MySQL连接拒绝错误。 经过相当多的研究,我一直没能

  • 问题内容: 我正在使用PHP 5.5和MAMP(从此处下载): 我有一个像这样的基本脚本: 当我运行此脚本时,出现以下错误: 我需要在MAMP或PHP中设置一些配置问题吗? 问题答案: 万一其他人遇到此问题,则MAMP上mysql的默认端口是,但php希望用于mysql的端口是。因此,您需要打开MAMP,转到首选项,并将MAMP的mysql端口更改为,然后 重新启动mysql服务器 。现在,使用h

  • 我已经创建了laravel应用程序,其数据库在本地主机上运行,所以我决定在GCP appengine上部署,但当我单击deploy时,这个发生在SQLSTATE[HY000][2002]连接超时,我连接到下面的GCP sql实例就是我的应用程序。亚马尔 首先,我使用使用sql_代理的本地主机,它不显示任何文件目录,然后我删除DB_套接字,然后出现此错误,SQLSTATE[HY000][2002]连

  • 运行时出错: PHP工匠迁移:重置 在my Laravel网站的根目录中: 当我运行-v时,我得到了以下信息: 我想我知道发生了什么。我不得不在PHPStorm中将数据库连接更改为192.168.10.10才能连接到MySQL,因为MySQL位于homestead VM(虚拟机)上,而我无法在本地连接到它,因为从技术上讲,它位于“不同的机器”上。然后我去寻找在哪里更改数据库信息。到目前为止,我的查