はじめに
今回は、EC2でサーバーを構築する際に利用できる「User Data」について取り上げます。この高度なオプション設定については、これまで特に意識せずスルーしてきました。
しかし、サーバー構築時の環境セットアップを簡単に自動化できる可能性があると気づき、実際に試してみることにしました。
本記事では、その手順や効果をまとめています。
最近はCloudFormationやTerraformなどを活用してインスタンス起動時にコマンドを投入する方法を使用することが多いですが、今回は手動で作成する場合の挙動も改めて確認していきます。
書こうと思ったきっかけ
User Dataという設定項目の存在は以前から認識していましたが、インスタンス起動後にSSH接続してコマンドを入力しても工数的に大きな違いはないと考えていました。
しかし、「自動化を取り入れることで、どれだけ効率化できるのか?」という疑問が浮かび、今回試してみることにしました。
今後この設定をどれだけ活用するかは分かりませんが、未来の自分への備忘録として、今回の技術検証を体系的にまとめます。
この内容が誰かの技術の支えになれば幸いです!
まず、User Dataとは
Amazon EC2では、User Dataを使用して、インスタンス起動時にコマンドやスクリプトを自動的に実行することができます。
この機能を活用することで、サーバー構築や設定作業を自動化し、効率的に環境をセットアップすることが可能です。
詳しく知りたい方は、以下のブログやAWS公式ドキュメントを参考にしてみてください。
User Dataの特徴
User Dataに実行したいコマンドやスクリプトを入力することで、インスタンス起動時に自動的に設定が行われるため、手動での作業を大幅に削減できます。
-
自動実行:
EC2インスタンスの起動時に、指定したスクリプトやコマンドを自動的に実行します。
通常、初回起動時に1回だけ実行されます(必要に応じて再実行も可能)。 -
セットアップの自動化:
パッケージのインストール
サービスの設定や起動
カスタムスクリプトの実行 -
簡単な構文:
User Dataにはシェルスクリプトやクラウド初期化ツール(Cloud-Init
)を利用できます。
前提条件
ここでは、VPCなどの基本的なAWS構成がすでに構築されていることを前提としています。
まだ構築が終わっていない方は、以下の記事でVPCやサブネットの作成方法をご紹介していますので、ぜひ参考にしてください。
また、セキュリティグループの設定も重要です。特に、インバウンドルールでHTTP(ポート80)を解放する必要があります。
セキュリティグループの設定方法については、以下の記事で詳しく解説していますので、あわせて参照してください。
これらの設定が完了していることを確認してから、次の手順に進むことをおすすめします。
実際に使ってみた
AWSのマネジメントコンソールからEC2のサービス画面に移動し、「インスタンスを起動」をクリックします。
途中の設定手順は省略しますが、ご了承ください。
インスタンス起動時に、EC2管理コンソール内の「Advanced Details」セクションで「User Data」にスクリプトを貼り付けます。
以下のスクリプトは、HTTPサーバーをインストールして起動する設定例です。
#!/bin/bash
sudo yum update -y
sudo yum install -y httpd
sudo systemctl start httpd
sudo systemctl enable httpd
echo "Hello, EC2!" | sudo tee /var/www/html/index.html
少し補足:シェバン(#!/bin/bash)とは?
#!/bin/bash
はシェバン(shebang)と呼ばれる記述で、スクリプトファイルの先頭に記載する特殊な文字列です。
これにより、スクリプトがどのインタプリタ(プログラムを実行するソフトウェア)で実行されるべきかを指定します。
この場合は、Bashシェルを指定しています。
ブラウザからアクセスしてみた
ここでは、EC2にパブリックIPアドレスが付与されていることを前提に、管理画面からIPアドレスを確認します。
私の環境では、以下のURLをブラウザで指定してアクセスしました。
http://52.196.216.234/index.html
このURLで、今回自動作成された index.html
にアクセスします。
想定通り、設定したコマンドが実行されていることを確認できました!!
まとめ
今回、普段あまり使用していなかったUser Dataの設定について検証を行いました。
実際に試してみると、サーバーを構築する台数が多い場合には非常に便利な機能であると感じました。
今後は、この設定項目にCloud-Init
を活用することで、さらに高度な初期化が可能となります。 機会があれば、その活用にも挑戦したいと思います。
基本的な技術検証の内容ではありますが、この情報がどなたかの技術的な支えとなれば幸いです!
参考記事