Amazon Linux 2でサーバ作成 (Apache2.4+PHP7.2+MariaDB)


概要

EC2インスタンスを起動して、Apache2.4とPHP7.2とMariaDBをインストールしてみたのでメモしておく。

インスタンス起動

学習用の起動なので、スタンドアロンで起動してすべてインストールするので、インスタンスを1つ起動。

EC2 -> インスタンス -> インスタンスの作成

※ Amazon Linux 2 AMIを選択
※ セキュリティグループは、80ポートと22ポートを解放する。
(22ポートは不要だが学習用なので簡略化のため設定)

サーバへ接続する

ターミナルを使って起動したEC2インスタンスに接続する。
※ IAMユーザーにてssh接続。
※ アカウントは、多要素認証 (MFA) を設定し、利用しない。

ターミナル
$ ssh aws

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

https://aws.amazon.com/amazon-linux-2/
Run "sudo yum update" to apply all updates.

とりあえず、yumを更新しておく。

ターミナル
$ sudo yum update -y

Amazon Linux Extras リポジトリ

そのままインストールするとPHP5.x系のため、「amazon-linux-extras」を使うことにします。
「amazon-linux-extras」でインストールできる内容を確認する。

ターミナル
$ amazon-linux-extras list
 ...
 15  php7.2                   available    \
        [ =7.2.0  =7.2.4  =7.2.5  =7.2.8  =7.2.11 ]
 ...
 17  lamp-mariadb10.2-php7.2  available    \
        [ =10.2.10_7.2.0  =10.2.10_7.2.4  =10.2.10_7.2.5
          =10.2.10_7.2.8  =10.2.10_7.2.11 ]
 ...

インストールされる内容を確認してみる。

ターミナル
# PHP7
$ amazon-linux-extras info php7.2
php7.2 recommends php-cli                      # yum install php-cli
php7.2 recommends php-pdo                      # yum install php-pdo
php7.2 recommends php-fpm                      # yum install php-fpm
php7.2 recommends php-json                     # yum install php-json
php7.2 recommends php-mysqlnd                  # yum install php-mysqlnd

# PHP拡張モジュール(mariadb)
$ amazon-linux-extras info lamp-mariadb10.2-php7.2
lamp-mariadb10.2-php7.2 recommends php-cli     # yum install php-cli
lamp-mariadb10.2-php7.2 recommends php-pdo     # yum install php-pdo
lamp-mariadb10.2-php7.2 recommends php-fpm     # yum install php-fpm
lamp-mariadb10.2-php7.2 recommends php-json    # yum install php-json
lamp-mariadb10.2-php7.2 recommends php-mysqlnd # yum install php-mysqlnd
lamp-mariadb10.2-php7.2 recommends mariadb     # yum install mariadb

PHP7.2.0 + 拡張モジュール

PHPをインストールしてみる。

ターミナル
$ sudo amazon-linux-extras install -y \
  lamp-mariadb10.2-php7.2=10.2.10_7.2.0 \
  php7.2=7.2.0

インストール状況を確認。

ターミナル
# PHP7
$ php -v
PHP 7.2.0 (cli) (built: Dec 13 2017 00:38:30) ( NTS )

# 拡張モジュール(mariadb)
$ yum list installed mariadb* | grep amzn2extra-lamp-mariadb10.2-php7.2
mariadb.x86_64        3:10.2.10-2.amzn2.0.1  @amzn2extra-lamp-mariadb10.2-php7.2
mariadb-common.x86_64 3:10.2.10-2.amzn2.0.1  @amzn2extra-lamp-mariadb10.2-php7.2
mariadb-config.x86_64 3:10.2.10-2.amzn2.0.1  @amzn2extra-lamp-mariadb10.2-php7.2
mariadb-libs.x86_64   3:10.2.10-2.amzn2.0.1  @amzn2extra-lamp-mariadb10.2-php7.2

MariaDB (10.2.10)

yumコマンドでインストールする。

ターミナル
# インストール
$ sudo yum install -y mariadb-server

# 起動
$ sudo systemctl start mariadb

# 有効化
$ sudo systemctl enable mariadb
$ sudo systemctl is-enabled mariadb

# セキュリティ設定
$ sudo mysql_secure_installation
Set root password? [Y/n]
Remove anonymous users? [Y/n]
Disallow root login remotely? [Y/n]
Remove test database and access to it? [Y/n] n
Reload privilege tables now? [Y/n]
 ...
Thanks for using MariaDB!

# バージョン確認
$ mysql -u root -e 'status' -p
mysql  Ver 15.1 Distrib 10.2.10-MariaDB, for Linux (x86_64) using ...

Apache 2.4

yumコマンドでインストールする。

ターミナル
# インストール
$ sudo yum install -y httpd

# 環境設定
$ sudo vi /etc/httpd/conf/httpd.conf
--------------------------------------------------------
-「Forbidden」ページからOS,IP,Apacheなどの情報を非表示にする
ServerTokens Prod
ServerSignature Off

<Directory "/var/www/html">
  - ディレクトリ構造を表示しない
  Options -Indexes FollowSymLinks

  - htaccessを有効にする
  AllowOverride All
</Directory>
--------------------------------------------------------

# 環境設定ファイルのチェック
$ sudo httpd -t

# 起動
$ sudo systemctl start httpd

# 有効化
$ sudo systemctl enable httpd
$ sudo systemctl is-enabled httpd
enabled

# バージョン確認
$ httpd -v
Server version: Apache/2.4.34

ec2-userにapacheグループを追加する。

ターミナル
# グループ追加
$ sudo usermod -a -G apache ec2-user

# ssh再接続して、所属グループを確認
$ exit
$ ssh aws
$ groups
ec2-user adm wheel apache systemd-journal

所有権の変更。

ターミナル
$ sudo chown -R ec2-user:apache /var/www
$ sudo chmod 2775 /var/www
$ ls -la /var/
drwxrwsr-x  4 ec2-user apache   33 12月 12 13:46 www

パーミッションの変更。

ターミナル
$ find /var/www -type d -exec sudo chmod 2775 {} \;
$ find /var/www -type f -exec sudo chmod 0664 {} \;
$ ls -la /var/www
drwxrwsr-x  2 ec2-user apache   6  9月  1 05:32 cgi-bin
drwxrwsr-x  2 ec2-user apache   6  9月  1 05:32 html

index.phpファイルを配置

/var/www/html/index.php
<html>
<body>
Hello World.<br>
<?php echo 'hoge'; ?>
</body>
</html>

テスト

起動したインスタンスの「パブリック DNS (IPv4)」に記載されているIPアドレスにアクセスしてみる。
※ 今回のIPアドレス: IPv4 パブリック IP 54.92.29.7

AMI作成

再利用できるようAMI(Amazon Machine Image)を作成しておく。

対象のインスタンスを停止しておき、アクション->イメージ->イメージの作成を実行。

イメージ名と説明を入力して「イメージの作成」ボタンを押し、AMIを作成する。

AMIからEC2インスタンス作成

EC2 -> インスタンス -> インスタンスの作成 -> マイ AMI から今回作成した「AmazonLinux2-httpd2.4-php7.2-mariadb10.2」を選択してインスタンスを作成する。

以上です。

参考サイト