質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

1回答

2120閲覧

Laravel 存在するはずのDBに接続できない

Tao-Tao

総合スコア2

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2021/06/15 11:59

編集2021/06/20 00:13

前提・実現したいこと

Laravelでマイグレーションを実行したい

発生している問題・エラーメッセージ

Laravelでマイグレーション実行時にエラーが発生します。
2日ほどこのエラーと戦っていますが、打開策が見えず、お力を貸していただけないでしょうか。
おそらく、どのデータベースにも接続されていないのが原因だと思うのですが、phpmyadmin上ではtestというDBが作成されているにもかかわらず、useできないです。
下記にコードを記載します。
※一部を***で伏せ字にしています。

エラーメッセージ ("SQLSTATE[HY000] [1045] Access denied for user '***'@'localhost' (using password: YES)") ### 該当のソースコード ーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーー [.env] APP_NAME=Laravel APP_ENV=local APP_KEY=*** APP_DEBUG=true APP_URL=http://localhost LOG_CHANNEL=stack DB_CONNECTION=mysql DB_HOST=localhost DB_PORT=8889 DB_DATABASE=test DB_USERNAME=root DB_PASSWORD=root DB_SOCKET=/Applications/MAMP/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_DRIVER=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] <?php use Illuminate\Support\Str; $db = parse_url ('mysql://***:***@***.cleardb.com/heroku_***?reconnect=true'); return [ /* |-------------------------------------------------------------------------- | Default Database Connection Name |-------------------------------------------------------------------------- | | Here you may specify which of the database connections below you wish | to use as your default connection for all database work. Of course | you may use many connections at once using the Database library. | */ 'default' => env('DB_CONNECTION', 'mysql'), /* |-------------------------------------------------------------------------- | Database Connections |-------------------------------------------------------------------------- | | Here are each of the database connections setup for your application. | Of course, examples of configuring each database platform that is | supported by Laravel is shown below to make development simple. | | | All database work in Laravel is done through the PHP PDO facilities | so make sure you have the driver for your particular database of | choice installed on your machine before you begin development. | */ 'connections' => [ 'sqlite' => [ 'driver' => 'sqlite', 'url' => env('DATABASE_URL'), 'database' => env('DB_DATABASE', database_path('database.sqlite')), 'prefix' => '', 'foreign_key_constraints' => env('DB_FOREIGN_KEYS', true), ], 'mysql' => [ 'driver' => 'mysql', 'url' => env('DATABASE_URL'), 'host' => $db['host'], 'port' => env('DB_PORT', '3306'), 'database' => ltrim($db ["path"], '/'), 'username' => $db['user'], 'password' => $db['pass'], 'unix_socket' => env('DB_SOCKET', ''), 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => '', 'prefix_indexes' => true, 'strict' => true, 'engine' => null, 'options' => extension_loaded('pdo_mysql') ? array_filter([ PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'), ]) : [], ], 'pgsql' => [ 'driver' => 'pgsql', 'url' => env('DATABASE_URL'), 'host' => env('DB_HOST', '127.0.0.1'), 'port' => env('DB_PORT', '5432'), 'database' => env('DB_DATABASE', 'forge'), 'username' => env('DB_USERNAME', 'forge'), 'password' => env('DB_PASSWORD', ''), 'charset' => 'utf8', 'prefix' => '', 'prefix_indexes' => true, 'schema' => 'public', 'sslmode' => 'prefer', ], 'sqlsrv' => [ 'driver' => 'sqlsrv', 'url' => env('DATABASE_URL'), 'host' => env('DB_HOST', 'localhost'), 'port' => env('DB_PORT', '1433'), 'database' => env('DB_DATABASE', 'forge'), 'username' => env('DB_USERNAME', 'forge'), 'password' => env('DB_PASSWORD', ''), 'charset' => 'utf8', 'prefix' => '', 'prefix_indexes' => true, ], ], /* |-------------------------------------------------------------------------- | Migration Repository Table |-------------------------------------------------------------------------- | | This table keeps track of all the migrations that have already run for | your application. Using this information, we can determine which of | the migrations on disk haven't actually been run in the database. | */ 'migrations' => 'migrations', /* |-------------------------------------------------------------------------- | Redis Databases |-------------------------------------------------------------------------- | | Redis is an open source, fast, and advanced key-value store that also | provides a richer body of commands than a typical key-value system | such as APC or Memcached. Laravel makes it easy to dig right in. | */ 'redis' => [ 'client' => env('REDIS_CLIENT', 'phpredis'), 'options' => [ 'cluster' => env('REDIS_CLUSTER', 'redis'), 'prefix' => env('REDIS_PREFIX', Str::slug(env('APP_NAME', 'laravel'), '_').'_database_'), ], 'default' => [ 'url' => env('REDIS_URL'), 'host' => env('REDIS_HOST', '127.0.0.1'), 'password' => env('REDIS_PASSWORD', null), 'port' => env('REDIS_PORT', '6379'), 'database' => env('REDIS_DB', '0'), ], 'cache' => [ 'url' => env('REDIS_URL'), 'host' => env('REDIS_HOST', '127.0.0.1'), 'password' => env('REDIS_PASSWORD', null), 'port' => env('REDIS_PORT', '6379'), 'database' => env('REDIS_CACHE_DB', '1'), ], ], ]; ーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーー

試したこと

$heroku run php artisan migrate を試した
└特にエラーなし

$ sudo mysql -u root

mysql> SELECT database();
+------------+
| database() |
+------------+
| NULL |
+------------+

use test

ERROR 1049 (42000): Unknown database 'test'

補足情報(FW/ツールのバージョンなど)

[フレームワーク]
Laravel6

[ローカル環境]
MAMP

[本番環境]
Heroku

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hentaiman

2021/06/20 11:33

localの話かherokuの話かどちらですか?
Tao-Tao

2021/06/21 13:29

localの話になります。
hentaiman

2021/06/21 15:44

laravelのenvに設定したDB接続情報と全く同じ情報を使ってコマンドラインから接続出来るか確認してください
Tao-Tao

2021/06/22 11:12 編集

hentaiman様 色々な方にご指導いただいたおかけで、ついにエラーは解消されました。 すごく初歩的な内容だと思いますが、database.phpのparse_url関数の後にenvを追加し、.env にDATABASE_URL=mysql://root:root@localhost/test?reconnect=trueを追記したところ、正常に動作しました。 コマンドラインからの接続確認でも、上記の内容で出力されていました。 本当にありがとうございます。
guest

回答1

0

ベストアンサー

ローカル環境の話なのか、本番環境の話なのかよく分かりませんので、ふんわりとした回答にはなります。

  1. Unixドメインソケットで接続するかTCP/IPで接続するかの設定が間違っている(localhostなのか127.0.0.1なのか。環境によって変わるので、ちゃんと調べる)
  2. 接続するアカウントがちゃんと存在するか('root'@'localhost'とか'root'@'127.0.0.1'とか)。select user,host from mysql.userを叩いて調べてみる。当然だが、1.の接続方法によって必要なアカウントが変わるので、それがない場合はアカウントを追加するか、1.の接続方法を変える。
  3. 接続するポートが間違っている(MAMPのデフォルトは8889だが、他の環境はそれでいいのか? 実は3306ではないか?)

投稿2021/06/16 14:26

編集2021/06/16 14:57
AbeTakashi

総合スコア4853

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Tao-Tao

2021/06/17 10:04

Abe Takashi様 ご回答いただき誠にありがとうございます。 Heroku上でのマイグレートではエラーにならないので、ローカル環境の問題だと思っています。 まずは、ご回答いただいた三点の内容を一つずつ確認して、結果を展開いたします。
Tao-Tao

2021/06/19 13:37

Abe Takashi様 まだ、問題の解決に至っていませんが、一旦調査途中の結果を展開します。 1. Unixドメインソケットで接続するかTCP/IPで接続するかの設定が間違っている(localhostなのか127.0.0.1なのか。環境によって変わるので、ちゃんと調べる) →localhostを使っているので、Unixドメインソケットでの接続だと思います。 2. 接続するアカウントがちゃんと存在するか('root'@'localhost'とか'root'@'127.0.0.1'とか)。select user,host from mysql.userを叩いて調べてみる。当然だが、1.の接続方法によって必要なアカウントが変わるので、それがない場合はアカウントを追加するか、1.の接続方法を変える。 →上記のコマンドの実行結果は、下記です。 +------------------+-----------+ | user | host | +------------------+-----------+ | mysql.infoschema | localhost | | mysql.session | localhost | | mysql.sys | localhost | | root | localhost | +------------------+-----------+ '***'@'localhost'が上記の実行結果の中に入っていないので、それが原因と思われますが、'***'@'localhost'の***の部分はHerokuで生成されたユーザー名なので、ローカル環境でのマイグレーションのエラー結果に***が出てくること自体が間違っている気がします。 3. 接続するポートが間違っている(MAMPのデフォルトは8889だが、他の環境はそれでいいのか? 実は3306ではないか?) →Heroku上でのマイグレーションではエラーが出ないのですが、ポートが原因の可能性はありますか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問