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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Q&A

解決済

2回答

567閲覧

AWSのEC2でLaravelとmysqlを連携させたい。

donut4

総合スコア148

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

0グッド

0クリップ

投稿2019/08/11 15:53

AWS内に2つのサブネットを構築し、ホストAにはLaravelを、ホストBにはMysqlをインストールしました。
Laravel側からMysqlの接続を実現するためDATABASE.phpを以下のように修正し、、、

'connections' => [ 'mysql' => [ 'driver' => 'mysql', 'host' => '10.0.xx.xx',  ←ホストBとは疎通確認できている。 'database' => 'wordpress', 'username' => 'wordpress', 'password' => 'wordpresspassword', 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', 'strict' => false, ],

一発でつながらないだろうな...と思いながらブラウザでphpinfo()を表示させてみましたが、、、

PDOやpdo_mysqlに値が入ってました。
イメージ説明

これを接続できているとみても大丈夫なんでしょうか?

phpにクエリ書いて確認すれば?と思うかもしれませんが
どこかが間違っていたらと思い心配になったので何か間違っている箇所があれば教えていただきたいと思います。

よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

自己解決

/config/database.phpと.envを以下のように設定したらひとまずは解決しました。
(ほかにもバージョンの違いによるエラー等ありましたが現在では無事にCRUD機能をコーディングできます。)

・database.php 'default' => env('DB_CONNECTION', 'mysql'), 'connections' => [ 'mysql' => [ 'driver' => 'mysql', 'host' => env('DB_HOST','10.0.x.x'), →DBのあるサーバーのIPアドレス 'port' => env('DB_PORT', '3306'), →mysqlは3306を固定で設定する 'database' => env( 'DB_DATABASE', 'hoge' ), →DB構築で設定した値 'username' => env('DB_USERNAME', 'hoge'), →DB構築で設定した値 'password' => env('DB_PASSWORD', 'hogepass'), →DB構築で設定した値 'unix_socket' => env('DB_SOCKET', ''), 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => '', 'prefix_indexes' => true, 'strict' => true, 'engine' => null, ],
・.env(抜粋) DB_CONNECTION=mysql DB_HOST=10.0.x.x DB_PORT=3306 DB_DATABASE=hoge DB_USERNAME=hoge DB_PASSWORD=hogepass

投稿2019/08/12 11:24

donut4

総合スコア148

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

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

0

大丈夫じゃないと思います。
phhpinfo()で表示されることを依拠して「接続できている」と仰るのであれば、
DATABASE.php(大文字じゃなかったような気がしますが…)のパスワードを1文字変えて再度読み込みをしてみては?
PHP側でMySQL系のライブラリが有効になっていることは、データベースに接続ができていることの証明にはならないと思いますよ。

投稿2019/08/11 18:14

takepan1973

総合スコア821

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

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

donut4

2019/08/12 02:32

パスワード変えてもphpinfo()の結果は変わってなかったです、、、
takepan1973

2019/08/12 02:39

うん、だから、それだから関係ないという話です。 接続できているかは、実際に接続するためのプログラムを書かないと分かりません。 「phpにクエリ書いて確認すれば?」 です。現在の時点では間違ってはいないと思います。でも、それと接続できているということはイコールじゃありません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問