手順
1.AWSアカウントを作成。
参照:AWS アカウント作成の流れ
2.EC2というAmazonのクラウド上の仮想サーバーを構築。
参照:AWS EC2でWebサーバーを構築してみる
3.LAMP環境を構築。
参照:チュートリアル: Amazon Linux 2 に LAMP ウェブサーバーをインストールする
4.Laravelをインストール。
参照:AWSのEC2を立ち上げてLaravelのログイン機能を動かすまで
AWSでLaravelを立ち上げた
1.AWSアカウントを作成
AWS は Amazon Web Services の略で、Amazon のクラウドサーバーを使用できるサービスです。
一年間無料でいろんな機能を試せます。
アカウントの登録は参照(AWS アカウント作成の流れ)に沿って行えばすぐできます。
2.EC2構築
AWSにログインすると最初はこの画面が表示されると思います。
右上の地域はリージョンといい、自分の所在地に合わせて選択します。これは利用するデータセンターの場所を意味します。理論上近いほどレスポンスタイムが短いので、近いところを選びましょう。自分の場合は「東京」です。
そしたら、左上のサービスからEC2を選択。
左のメニューの「インスタンス」 → 「インスタンス作成」を選択
一番目のAmazon Linux2 AMIを選択。
無料利用枠のt2.microにチェックを入れ、
他の設定は特にいじらずセキュリティグループの設定まで飛ばします。「新しいセキュリティグループを作成する」を選択し、「セキュリティグループ名と「説明」を好きなように入力し、画像のように五つのタイプを追加します。「ソース」のところでIP指定ができます。「任意の場所」を選択するとどこでもアクセスすることができ、「マイIP」を選択すると自分が現在使用しているネットワーク環境のIPでしかアクセスできなくなります。趣味程度の個人利用でしたら任意の場所で問題ありません。
右下の「確認と作成」 → 「起動」を押してから、このように表示されます。「新しいキーペアの作成」でキーペア名を入力。重要ですが、キーペアのダウンロードは必ずしてください。サーバーにアクセスするために必要となります。
「インスタンスの作成」 → 「インスタンスの表示」を順番に進めると、インスタントの画面に戻ります。
インスタンスの状態が running になっていれば作成成功です。
プラスα(オプション)
今作ったインスタンスに固定IPを割り当てることができます。左のメニューから「Elastic IP
」 → 「新しいアドレスの割り当て」 → 「割り当て」 → 「閉じる」で固定IPを一つゲットします。リストからIPを右クリック → 「アドレスの関連付け」で作成したインスタンスを選択し結びつけれます。
3.LAMP環境の構築
①インスタンスに接続
サーバーに接続するため、ssh接続できるターミナルTeraTermをダウンロードします。インスタンス画面下の説明から固定IPとっていれば「IPv4 パブリック IP」、とっていなければ「パブリック DNS (IPv4)」をTeraTermのホストに入力して「OK」します。
次にユーザー名に「ec2-user」、秘密鍵に先ほどインスタンスを作るときにダウンロードしたキーペアファイルをセットして「OK」。
サーバーに接続できました。
直接とは関係ないですがコマンドでsudoを打つかどうかについて「root権限で`sudo`を付けた場合と付けない場合の違いに`su`は何の略?」を読めばわかると思います。
###②EC2のタイムゾーン設定
「Amazon EC2のタイムゾーンを日本時間に変更する方法」でわかりやすく書かれていますが、いくつか補足があります。
/etc/sysconfig/clock
にはこのように変更すると書いてありますが、
# ZONE="UTC"
ZONE="Japan"
UTC=true
true
のところをfalse
にしないと再起動するときにタイムゾーンがUTCに戻ることがあります。
# ZONE="UTC"
ZONE="Japan"
UTC=flase
ここでルート権限を持たないため、vim
で保存するときにきっとこのようなエラーが出ると思います。
E45: 'readonly' option is set (add ! to override)
この解決法として自分がrootになるか、「[vim]read only のファイルをsudoで強制的に保存する」を参照してください。
オプションとして、「AWSの初期設定でrootパスワードを設定する」。一行目のssh
なんちゃらはすでにTeraTermログイン時にできてますので無視。
ln
のオプションの意味は【 ln 】コマンド――ファイルのハードリンクとシンボリックリンクを作るに書いてあります。
###③LAMP環境構築
AWSの公式チュートリアル「チュートリアル: Amazon Linux 2 に LAMP ウェブサーバーをインストールする」の順序を追えばできます。自分はSQLに慣れているため、オプションの phpMyAdmin のインストールはしていません。phpMyAdmin はデータベースをGUIで管理できるツールです。
#4.Laravelのインストール
###①Composerをダウンロード
Composerについては「PHP開発でComposerを使わないなんてありえない!基礎編」。
以下ダウンロードコマンドです。
$ curl -sS https://getcomposer.org/installer | sudo php
$ sudo mv composer.phar /usr/local/bin/composer
これでcomposer.phar
というファイルが/usr/local/bin/composer/
の下に置かれます。
このcomposer.phar
ファイルをcomposer
というコマンドで実行できたら便利なので、composer
というコマンドを作ります。
alias composer='php /usr/local/bin/composer/composer.phar'
ただし、これだけだと再起動するとリセットされてcomposer
が効かなくなりますので、常に成立するようにルートに存在する.bashrc
というファイルに書き込みます。
$ cd ~ # ルートに移動
$ ls -la # .bashrcがあるかどうかを確認
$ vi .bashrc # 「alias composer='php /usr/local/bin/composer/composer.phar'」を書き込む
そしたらターミナルが起動すると読み込まれる.bash_profile
に.bashrc
を参照するようにします。
$ vi .bash_profile # 「source ~/.bashrc」を一番下に書き込む
###②拡張ライブラリをダウンロード
Laravelをダウンロードするのに必要なライブラリーは3つあります。mbstring
、mysqlnd
とxml
です。
$ sudo yum install -y php-mbstring php-mysqlnd php-xml
###③Laravelをインストール
Laravel をインストールするディレクトリに移動します。自分の場合は/var/www/
の下にしました。
$ cd /var/www
$ composer create-project --prefer-dist laravel/laravel
自分の場合ここで「proc_open(): fork failed errors」というエラーが出ました。「[PHP]Composer使用時に「proc_open(): fork failed errors」エラーが出た時の対処法」を見て解決できたので共有します。
-prefer-dist
って何ぞやと知りたい方には「composer の–prefer-distってよく使うけど何してる?」へ。
###④Apacheのドキュメントルートの設定と.htaccessの有効化
$ sudo vi /etc/httpd/conf.d/custom.conf
に
# ドキュメントルート
DocumentRoot "/var/www/laravel/public"
# .htaccess 有効化
<Directory /var/www/laravel/public>
AllowOverride All
</Directory>
を加えます。
そしたらApacheを再起動してください。
$ sudo service httpd restart
###⑤パーミッションを変更
自分はパーミッションについてまだちんぷんかんぷんで、どの権限をどうすればいいか自分ではわかっていないので、他の方のブログを見たほうがいいかもしれません。基本的にパーミッションが合ってないとシステムにこのファイルに書き込めないよと怒られます。どうやらLaravelの場合はstorage
とbootstrap
の権限を変更する必要があるらしい。
$ cd ~
$ sudo groupadd www
$ sudo usermod -a -G www ec2-user
$ exit
一度ログアウトして再度入り直して、
$ cd /var/www
$ sudo chmod -R 777 laravel/storage
$ sudo chmod -R 775 laravel/bootstrap/cache
$ sudo chown -R root:www /var/www
これでLaravelが使えるようになったはず。