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

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

新規登録して質問してみよう
ただいま回答率
85.48%
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

0回答

353閲覧

laravelで作成したアプリをherokuにあげようとしたらエラーがでました。

ssssbbbb0819

総合スコア3

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クリップ

投稿2022/09/27 16:16

前提

https://www.youtube.com/watch?v=mBERWdb8NpM&t=782
上記の動画を参考にして
”heroku run php artisan migrate”
を実行しました。
かなりの量のエラーが出たのですが何に原因があるのでしょうか。

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

[2022-09-28 00:35:17] production.ERROR: SQLSTATE[HY000] [2002] Connection timed out (SQL: select * from information_schema.tables where table_schema = heroku_216b9b3af0e25af and table_name = migrations and table_type = 'BASE TABLE') {"exception":"[object] (Illuminate\\Database\\QueryException(code: 2002): SQLSTATE[HY000] [2002] Connection timed out (SQL: select * from information_schema.tables where table_schema = heroku_216b9b3af0e25af and table_name = migrations and table_type = 'BASE TABLE') at /app/vendor/laravel/framework/src/Illuminate/Database/Connection.php:712) [stacktrace] #0 /app/vendor/laravel/framework/src/Illuminate/Database/Connection.php(784): Illuminate\\Database\\Connection->runQueryCallback() #1 /app/vendor/laravel/framework/src/Illuminate/Database/Connection.php(764): Illuminate\\Database\\Connection->tryAgainIfCausedByLostConnection() #2 /app/vendor/laravel/framework/src/Illuminate/Database/Connection.php(675): Illuminate\\Database\\Connection->handleQueryException() #3 /app/vendor/laravel/framework/src/Illuminate/Database/Connection.php(376): Illuminate\\Database\\Connection->run() #4 /app/vendor/laravel/framework/src/Illuminate/Database/Schema/MySqlBuilder.php(44): Illuminate\\Database\\Connection->select() #5 /app/vendor/laravel/framework/src/Illuminate/Database/Migrations/DatabaseMigrationRepository.php(169): Illuminate\\Database\\Schema\\MySqlBuilder->hasTable() #6 /app/vendor/laravel/framework/src/Illuminate/Database/Migrations/Migrator.php(673): Illuminate\\Database\\Migrations\\DatabaseMigrationRepository->repositoryExists() #7 /app/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateCommand.php(110): Illuminate\\Database\\Migrations\\Migrator->repositoryExists() #8 /app/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateCommand.php(78): Illuminate\\Database\\Console\\Migrations\\MigrateCommand->prepareDatabase() #9 /app/vendor/laravel/framework/src/Illuminate/Database/Migrations/Migrator.php(606): Illuminate\\Database\\Console\\Migrations\\MigrateCommand->Illuminate\\Database\\Console\\Migrations\\{closure}() #10 /app/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateCommand.php(98): Illuminate\\Database\\Migrations\\Migrator->usingConnection() #11 /app/vendor/laravel/framework/src/Illuminate/Container/BoundMethod.php(36): Illuminate\\Database\\Console\\Migrations\\MigrateCommand->handle()   入り切らないので消してます。#35までありました。 In Connection.php line 712: SQLSTATE[HY000] [2002] Connection timed out (SQL: select * from information_schema.tables where table_schema = heroku_216b9b3af0e25af and table_name = migr ations and table_type = 'BASE TABLE') In Connector.php line 70: SQLSTATE[HY000] [2002] Connection timed out

該当のソースコード

datamase.php

1<?php 2 3use Illuminate\Support\Str; 4 5$db = parse_url(env('DATABASE_URL')); 6 7return [ 8 9 10 11 'default' => env('DB_CONNECTION', 'mysql'), 12 13 14 'connections' => [ 15 16 'sqlite' => [ 17 'driver' => 'sqlite', 18 'url' => env('DATABASE_URL'), 19 'database' => env('DB_DATABASE', database_path('database.sqlite')), 20 'prefix' => '', 21 'foreign_key_constraints' => env('DB_FOREIGN_KEYS', true), 22 ], 23 24 'mysql' => [ 25 'driver' => 'mysql', 26 'url' => env('DATABASE_URL'), 27 'host' => $db['host'], 28 'port' => env('DB_PORT', '8889'), 29 'database' => ltrim($db["path"],'/'), 30 'username' => $db['user'], 31 'password' => $db['pass'], 32 'unix_socket' => env('DB_SOCKET', ''), 33 'charset' => 'utf8mb4', 34 'collation' => 'utf8mb4_unicode_ci', 35 'prefix' => '', 36 'prefix_indexes' => true, 37 'strict' => true, 38 'engine' => null, 39 'options' => extension_loaded('pdo_mysql') ? array_filter([ 40 PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'), 41 ]) : [], 42 ], 43 44 'pgsql' => [ 45 'driver' => 'pgsql', 46 'url' => env('DATABASE_URL'), 47 'host' => env('DB_HOST', '127.0.0.1'), 48 'port' => env('DB_PORT', '5432'), 49 'database' => env('DB_DATABASE', 'forge'), 50 'username' => env('DB_USERNAME', 'forge'), 51 'password' => env('DB_PASSWORD', ''), 52 'charset' => 'utf8', 53 'prefix' => '', 54 'prefix_indexes' => true, 55 'schema' => 'public', 56 'sslmode' => 'prefer', 57 ], 58 59 'sqlsrv' => [ 60 'driver' => 'sqlsrv', 61 'url' => env('DATABASE_URL'), 62 'host' => env('DB_HOST', 'localhost'), 63 'port' => env('DB_PORT', '1433'), 64 'database' => env('DB_DATABASE', 'forge'), 65 'username' => env('DB_USERNAME', 'forge'), 66 'password' => env('DB_PASSWORD', ''), 67 'charset' => 'utf8', 68 'prefix' => '', 69 'prefix_indexes' => true, 70 ], 71 72 ], 73 74 75 'migrations' => 'migrations', 76 77 78 'redis' => [ 79 80 'client' => env('REDIS_CLIENT', 'phpredis'), 81 82 'options' => [ 83 'cluster' => env('REDIS_CLUSTER', 'redis'), 84 'prefix' => env('REDIS_PREFIX', Str::slug(env('APP_NAME', 'laravel'), '_').'_database_'), 85 ], 86 87 'default' => [ 88 'url' => env('REDIS_URL'), 89 'host' => env('REDIS_HOST', '127.0.0.1'), 90 'password' => env('REDIS_PASSWORD', null), 91 'port' => env('REDIS_PORT', '6379'), 92 'database' => env('REDIS_DB', '0'), 93 ], 94 95 'cache' => [ 96 'url' => env('REDIS_URL'), 97 'host' => env('REDIS_HOST', '127.0.0.1'), 98 'password' => env('REDIS_PASSWORD', null), 99 'port' => env('REDIS_PORT', '6379'), 100 'database' => env('REDIS_CACHE_DB', '1'), 101 ], 102 103 ], 104 105]; 106

env

1APP_NAME=Laravel 2APP_ENV=local 3APP_KEY=### 4APP_DEBUG=true 5APP_URL=http://localhost 6 7LOG_CHANNEL=stack 8LOG_DEPRECATIONS_CHANNEL=null 9LOG_LEVEL=debug 10 11DB_CONNECTION=mysql 12DB_HOST=127.0.0.1 13DB_PORT=3306 14DB_DATABASE=laravel 15DB_USERNAME=root 16DB_PASSWORD=root 17DB_SOCKET=/Applications/MAMP/tmp/mysql/mysql.sock 18
### 試したこと なにに原因があるのかわからず何を試せばいいのかわかりません。。。 ### 補足情報(FW/ツールのバージョンなど) laravel PHP 7.3.24 Composer version 2.3.10 heroku/7.63.4 git version 2.30.1

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

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

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

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

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

hoshi-takanori

2022/09/27 16:24

DB_HOST=127.0.0.1 としてますが、heroku ではデータベースは別のマシンのものを利用することになります。 ってか、もうすぐ heroku 有料化ですね…。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問