LoginSignup
22
26

More than 1 year has passed since last update.

Laravel Docker AWS EC2デプロイ①

Last updated at Posted at 2021-12-02

この記事では、laravelで開発したポートフォリオのAWS EC2へのデプロイについて紹介していきます!
記事が長くなりそうなので、細かい説明とは省いてなるべく実行手順のみ記載していくようにします!

ポートフォリオ使用技術

フロントエンド:HTML5、CSS、bootstrap4.5.0、Tailwindcss2.2.15
バックエンド:PHP7.4.15、Laravel8.34.0、Jetstream1.0、Livewire
インフラ:Docker20.10.2、nginx1.18、MySQL8.0.23/phpMyAdmin、Apache2.4.38、AWS S3

デプロイ環境

デプロイ先:AWS EC2
サーバー:nginx(Apacheの場合も記載しました。)

1.AWS EC2 インスタンス作成

1.AWSからログインしてEC2画面にアクセス。
2.画面右上のリージョンを「東京」に。
3.「インスタンスを起動」をクリック。
スクリーンショット 2021-12-02 21.52.52.png

4.「AWS Linux2」を選択。
スクリーンショット 2021-12-02 21.56.04.png
5.無料枠の「t2.micro」を選択。→次のステップでステップ5まで移動。
※ステップ3、4はデフォルトのまま。
スクリーンショット 2021-12-02 21.58.06.png
6.「タグを追加」→「キー」と「値」を入力。
スクリーンショット 2021-12-02 22.02.58.png
7.「ルールの追加」→「HTTP」と「HTTPS」を追加→「確認と作成」
スクリーンショット 2021-12-02 23.07.26.png

8.「起動」
スクリーンショット 2021-12-02 22.07.28.png
9.「新しいキーペアの作成」→「キーペア名」入力→「キーペアのダウンロード」でローカルに保存→「インスタンスを作成」
スクリーンショット 2021-12-02 22.09.46.png
10.作成されたインスタンスにチェック→接続
スクリーンショット 2021-12-02 22.14.29.png

スクリーンショット 2021-12-02 22.13.10.png

11.10の接続情報を元にターミナルからリモート接続を実施。

$ cd #ターミナルをスタート地点へ

$ mkdir ~/.ssh   #.sshディレクトリを作成

$ mv Downloads/sample-key.pem .ssh/ #mvコマンドで、「キー.pem」を.sshディレクトリに移動

$ cd .ssh/ #.sshにディレクトリ移動

.ssh $ ls #pemファイルが存在するか確認。「sample-key.pem」が存在すればOK

.ssh $ chmod 400 sample-key.pem #キーファイル(○○○.pem)のパーミッションを変更

.ssh $ ssh -i "sample-key.pem" ec2-user@ec2-??-??-???-???.ap-northeast-1.compute.amazonaws.com #ログイン(AWS 接続画面記載のコードをコピペ)

Last login: Thu Dec  2 06:14:35 2021 from p3014131-ipoe.ipoe.ocn.ne.jp

       __|  __|_  )
       _|  (     /   Amazon Linux 2 AMI
      ___|\___|___|

https://aws.amazon.com/amazon-linux-2/

nginxをセットアップ

今回はnginxをセットアップしますが、Apache2を使用したい方はApache2のインストールを参考にしてください。

Apache2の場合

[ec2-user@ip-172-31-45-44 ~]$ sudo yum update #パッケージアップデート
読み込んだプラグイン:extras_suggestions, langpacks, priorities, update-motd
amzn2-core                                                                                      | 3.7 kB  00:00:00     
No packages marked for update
#「No packages marked for update」は、アップデートするパッケージがないということなのでこのままでOK。

$ sudo yum install apache2

※初めに選択したAMIがAWS Linux2の場合、aptコマンドが使用できない為、apt→yumに変更してコマンド実行。

nginxの場合

#EC2インスタンスは、nginxのyum intstallが有効になっていない為、有効化。
[ec2-user@ip-172-31-45-44 ~]$ sudo amazon-linux-extras enable nginx1

[ec2-user@ip-172-31-45-44 ~]$ sudo yum -y install nginx #インストール

[ec2-user@ip-172-31-45-44 ~]$ nginx -v #バージョン確認

[ec2-user@ip-172-31-45-44 ~]$ sudo systemctl enable nginx #nginx自動起動化

[ec2-user@ip-172-31-45-44 ~]$ sudo systemctl start nginx.service #起動

[ec2-user@ip-172-31-45-44 ~]$ sudo systemctl status nginx.service #起動確認

続く

AWSインスタンス一覧画面→作成したインスタンスにチェック→画面下のインスタンス情報内のパブリックIPv4アドレスからアクセス→サーバーの初期画面が表示されればインスタンスの作成とサーバーのセットアップが完了です!
スクリーンショット 2021-12-02 22.57.00.png

とりあえずここまでお疲れ様でした!
まだ初めの段階ですが、エラーに引っかかってしまうとこれだけの作業でも時間が過ぎてしまいますよね。。
記事が長くなってしまう為、続きはパート2で紹介していきます!

参考記事

22
26
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
22
26