<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Java - CayTech Lab</title>
	<atom:link href="https://caymezon.com/tag/java/feed/" rel="self" type="application/rss+xml" />
	<link>https://caymezon.com</link>
	<description></description>
	<lastBuildDate>Sun, 29 Mar 2026 04:44:53 +0000</lastBuildDate>
	<language>ja</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=7.0</generator>

<image>
	<url>https://caymezon.com/wp-content/uploads/2026/01/cropped-CayTechLab-32x32.jpg</url>
	<title>Java - CayTech Lab</title>
	<link>https://caymezon.com</link>
	<width>32</width>
	<height>32</height>
</image> 
	<atom:link rel='hub' href='https://caymezon.com/?pushpress=hub'/>
	<item>
		<title>EC2サーバ構築ハンズオン：AWSコンソールでTomcatを構築する手順【EC2 Tomcat / CloudFormation版との比較付き】</title>
		<link>https://caymezon.com/aws-handson-console-ec2-tomcat/</link>
					<comments>https://caymezon.com/aws-handson-console-ec2-tomcat/#respond</comments>
		
		<dc:creator><![CDATA[caymezon]]></dc:creator>
		<pubDate>Sun, 29 Mar 2026 04:44:53 +0000</pubDate>
				<category><![CDATA[AWS Basic]]></category>
		<category><![CDATA[Cloud & Infra]]></category>
		<category><![CDATA[APサーバー]]></category>
		<category><![CDATA[AWS]]></category>
		<category><![CDATA[AWSコンソール]]></category>
		<category><![CDATA[EC2]]></category>
		<category><![CDATA[ec2サーバ構築]]></category>
		<category><![CDATA[IAM]]></category>
		<category><![CDATA[Java]]></category>
		<category><![CDATA[Tomcat]]></category>
		<category><![CDATA[UserData]]></category>
		<category><![CDATA[セキュリティグループ]]></category>
		<category><![CDATA[ハンズオン]]></category>
		<category><![CDATA[初心者]]></category>
		<guid isPermaLink="false">https://caymezon.com/?p=20313</guid>

					<description><![CDATA[<p>目次 はじめにキーワード解説Apache（Webサーバー）と Tomcat（APサーバー）の違い使用するAWSサービス構築するリソース全体の作業順序【重要】⓪ 自分のIPアドレスを確認する方法A: ルーター管理画面で確認 [&#8230;]</p>
<p>The post <a href="https://caymezon.com/aws-handson-console-ec2-tomcat/">EC2サーバ構築ハンズオン：AWSコンソールでTomcatを構築する手順【EC2 Tomcat / CloudFormation版との比較付き】</a> first appeared on <a href="https://caymezon.com">CayTech Lab</a>.</p>]]></description>
										<content:encoded><![CDATA[<div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-2" checked><label class="toc-title" for="toc-checkbox-2">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">はじめに</a></li><li><a href="#toc2" tabindex="0">キーワード解説</a></li><li><a href="#toc3" tabindex="0">Apache（Webサーバー）と Tomcat（APサーバー）の違い</a></li><li><a href="#toc4" tabindex="0">使用するAWSサービス</a></li><li><a href="#toc5" tabindex="0">構築するリソース</a></li><li><a href="#toc6" tabindex="0">全体の作業順序</a></li><li><a href="#toc7" tabindex="0">【重要】⓪ 自分のIPアドレスを確認する</a><ol><li><a href="#toc8" tabindex="0">方法A: ルーター管理画面で確認（推奨）</a></li><li><a href="#toc9" tabindex="0">方法B: コマンドで確認</a></li></ol></li><li><a href="#toc10" tabindex="0">① キーペアの作成</a><ol><li><a href="#toc11" tabindex="0">ダウンロードしたキーペアを保存する</a></li></ol></li><li><a href="#toc12" tabindex="0">② IAMロールの作成</a><ol><li><a href="#toc13" tabindex="0">ステップ1: エンティティタイプとユースケースの選択</a></li><li><a href="#toc14" tabindex="0">ステップ2: 許可ポリシーのアタッチ</a></li><li><a href="#toc15" tabindex="0">ステップ3: ロール名の設定</a></li></ol></li><li><a href="#toc16" tabindex="0">③ EC2インスタンスの起動</a><ol><li><a href="#toc17" tabindex="0">3-1. 基本設定</a></li><li><a href="#toc18" tabindex="0">3-2. セキュリティグループの設定</a></li><li><a href="#toc19" tabindex="0">3-3. IAMロールの設定</a></li><li><a href="#toc20" tabindex="0">3-4. UserDataの設定（Java + Tomcatの自動インストール）</a></li><li><a href="#toc21" tabindex="0">3-5. インスタンスを起動する</a></li></ol></li><li><a href="#toc22" tabindex="0">④ 動作確認</a><ol><li><a href="#toc23" tabindex="0">ブラウザで確認</a></li><li><a href="#toc24" tabindex="0">SSHで接続して確認</a></li><li><a href="#toc25" tabindex="0">UserDataのインストール状況を確認する方法</a></li><li><a href="#toc26" tabindex="0">【接続できない場合】IPアドレスが異なる可能性</a></li></ol></li><li><a href="#toc27" tabindex="0">⑤ リソースの削除</a><ol><li><a href="#toc28" tabindex="0">1. EC2インスタンスを終了する</a></li><li><a href="#toc29" tabindex="0">2. セキュリティグループを削除する</a></li><li><a href="#toc30" tabindex="0">3. IAMロールを削除する</a></li><li><a href="#toc31" tabindex="0">4. キーペアを削除する（任意）</a></li></ol></li><li><a href="#toc32" tabindex="0">CloudFormation版との比較</a></li><li><a href="#toc33" tabindex="0">トラブルシューティング</a></li><li><a href="#toc34" tabindex="0">まとめ</a></li><li><a href="#toc35" tabindex="0">関連記事</a></li></ol>
    </div>
  </div>

<h2><span id="toc1">はじめに</span></h2>
<p>「EC2サーバ上でJavaアプリを動かしたい」——ApacheでHTMLを返せるようになったら、次はJavaが実行できるAPサーバー（Tomcat）に挑戦しましょう。</p>
<p>この記事では、<strong>AWSコンソール（GUI）のみ</strong>を使って、Tomcat APサーバーが動作するEC2インスタンスをゼロから手動で構築するハンズオンを紹介します。</p>
<pre><code class="language-plaintext">インターネット
  ↓ TCP 8080（Tomcat HTTP）← ブラウザでアクセス
  ↓ TCP 22（SSH）          ← ターミナルで接続
セキュリティグループ（ファイアウォール）
  ↓ 自分のIPのみ通過させる
EC2インスタンス（t2.micro / Amazon Linux 2023）
  ├── Java 17（Amazon Corretto）← Tomcatの実行基盤
  ├── Tomcat 10.1（APサーバー）← UserDataで自動インストール
  │     └── /opt/tomcat/latest/webapps/ROOT/index.jsp を返す
  └── IAMロール（Session Manager接続用）</code></pre>
<p><strong>このハンズオンで体験できること：</strong></p>
<ul>
<li>EC2サーバーへのJava 17（Amazon Corretto）とTomcat 10のインストール</li>
<li>セキュリティグループによるポートアクセス制御（SSH:22 / Tomcat:8080）</li>
<li>UserDataを使ったJava + Tomcatの初回起動時自動インストール</li>
<li>JSPが実行されていることをブラウザで確認（Apacheの静的HTMLとの違い）</li>
</ul>
<p><strong>このハンズオンの特徴：</strong></p>
<ul>
<li>Apache版（Phase 1-1）の次のステップとして、APサーバーとWebサーバーの違いを体験できる</li>
<li>手動操作を通じて、各リソースの役割と依存関係を視覚的に理解できる</li>
</ul>
<hr>
<blockquote>
<p><strong>この記事は <a href="https://caymezon.com/aws-handson-cloudformation-ec2-tomcat/">CloudFormation版ハンズオン</a> の比較記事です。</strong><br />コンソール操作でEC2 Tomcatサーバー構築の全体像を学び、CloudFormationとの違いを比較したい方向けです。</p>
</blockquote>
<hr>
<p><!-- ![ハンズオン完成後のTomcat動作確認画面](images/ec2-tomcat-top.jpg) --></p>
<p><!-- <a rel="nofollow" href="//af.moshimo.com/af/c/click?a_id=1384942&p_id=170&pc_id=185&pl_id=4062&url=https%3A%2F%2Fwww.amazon.co.jp%2Fs%3Fk%3D%25E6%259C%25AC%2BAWS%2B%25E9%2596%258B%25E7%2599%25BA%26__mk_ja_JP%3D%25E3%2582%25AB%25E3%2582%25BF%25E3%2582%25AB%25E3%2583%258A%26crid%3D1DE63UBHFOR4K%26sprefix%3D%25E6%259C%25AC%2Baws%2B%25E9%2596%258B%25E7%2599%25BA%252Caps%252C167%26ref%3Dnb_sb_noss" referrerpolicy="no-referrer-when-downgrade" attributionsrc>Amazon検索[本 AWS 開発]</a><img decoding="async" src="//i.moshimo.com/af/i/impression?a_id=1384942&p_id=170&pc_id=185&pl_id=4062" width="1" height="1" style="border:none;" alt="" loading="lazy"> --></p>
<p><!-- <!-- START MoshimoAffiliateEasyLink --><script type="text/javascript">(function(b,c,f,g,a,d,e){b.MoshimoAffiliateObject=a;b[a]=b[a]||function(){arguments.currentScript=c.currentScript||c.scripts[c.scripts.length-2];(b[a].q=b[a].q||[]).push(arguments)};c.getElementById(a)||(d=c.createElement(f),d.src=g,d.id=a,e=c.getElementsByTagName("body")[0],e.appendChild(d))})(window,document,"script","//dn.msmstatic.com/site/cardlink/bundle.js?20220329","msmaflink");msmaflink({"n":"AWSの基本・仕組み・重要用語が全部わかる教科書 (見るだけ図解)","b":"SBクリエイティブ","t":"","d":"https:\/\/m.media-amazon.com","c_p":"\/images\/I","p":["\/51DEDQXj6oL._SL500_.jpg","\/41F589smNwL._SL500_.jpg","\/41R6f9yyCWL._SL500_.jpg","\/41HqWQ9BvmL._SL500_.jpg","\/41p8p0ZU79L._SL500_.jpg","\/41qLC-fndBL._SL500_.jpg","\/41fcLv9VT5L._SL500_.jpg","\/51lRvCsvHqL._SL500_.jpg"],"u":{"u":"https:\/\/www.amazon.co.jp\/dp\/4815607850","t":"amazon","r_v":""},"v":"2.1","b_l":[{"id":1,"u_tx":"Amazonで見る","u_bc":"#f79256","u_url":"https:\/\/www.amazon.co.jp\/dp\/4815607850","a_id":1384942,"p_id":170,"pl_id":27060,"pc_id":185,"s_n":"amazon","u_so":1},{"id":2,"u_tx":"楽天市場で見る","u_bc":"#f76956","u_url":"https:\/\/search.rakuten.co.jp\/search\/mall\/AWS%E3%81%AE%E5%9F%BA%E6%9C%AC%E3%83%BB%E4%BB%95%E7%B5%84%E3%81%BF%E3%83%BB%E9%87%8D%E8%A6%81%E7%94%A8%E8%AA%9E%E3%81%8C%E5%85%A8%E9%83%A8%E3%82%8F%E3%81%8B%E3%82%8B%E6%95%99%E7%A7%91%E6%9B%B8%20(%E8%A6%8B%E3%82%8B%E3%81%A0%E3%81%91%E5%9B%B3%E8%A7%A3)\/","a_id":1384917,"p_id":54,"pl_id":27059,"pc_id":54,"s_n":"rakuten","u_so":2},{"id":3,"u_tx":"Yahoo!ショッピングで見る","u_bc":"#66a7ff","u_url":"https:\/\/shopping.yahoo.co.jp\/search?first=1\u0026p=AWS%E3%81%AE%E5%9F%BA%E6%9C%AC%E3%83%BB%E4%BB%95%E7%B5%84%E3%81%BF%E3%83%BB%E9%87%8D%E8%A6%81%E7%94%A8%E8%AA%9E%E3%81%8C%E5%85%A8%E9%83%A8%E3%82%8F%E3%81%8B%E3%82%8B%E6%95%99%E7%A7%91%E6%9B%B8%20(%E8%A6%8B%E3%82%8B%E3%81%A0%E3%81%91%E5%9B%B3%E8%A7%A3)","a_id":1466950,"p_id":1225,"pl_id":27061,"pc_id":1925,"s_n":"yahoo","u_so":3}],"eid":"eaCUB","s":"s"});</script></p>
<div id="msmaflink-eaCUB">リンク</div>
<p><!-- MoshimoAffiliateEasyLink END --> --></p>
<h2><span id="toc2">キーワード解説</span></h2>
<table>
<thead>
<tr>
<th>用語</th>
<th>意味</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>EC2（Elastic Compute Cloud）</strong></td>
<td>AWSの仮想サーバーサービス。今回はここにJava + Tomcatをインストールする</td>
</tr>
<tr>
<td><strong>Tomcat</strong></td>
<td>JavaのWebアプリケーション（JSP/Servlet）を実行するAPサーバー。Apacheとは異なりJavaコードを動かすことができる</td>
</tr>
<tr>
<td><strong>Amazon Corretto</strong></td>
<td>AWSが提供するOpenJDKのディストリビューション。無償・本番利用可能なJava実行環境</td>
</tr>
<tr>
<td><strong>JSP（JavaServer Pages）</strong></td>
<td>HTMLにJavaコードを埋め込んで動的なページを生成する技術。Tomcatがサーバー側で実行してHTMLを返す</td>
</tr>
<tr>
<td><strong>セキュリティグループ</strong></td>
<td>EC2への通信を制御するファイアウォール。今回はポート22（SSH）と8080（Tomcat）を開ける</td>
</tr>
<tr>
<td><strong>UserData</strong></td>
<td>EC2の初回起動時のみ自動実行されるシェルスクリプト。今回はJava + Tomcatのインストールに使う</td>
</tr>
<tr>
<td><strong>IAMロール</strong></td>
<td>EC2にAWSサービスを利用する権限を付与する仕組み。今回はSession Manager接続に使う</td>
</tr>
<tr>
<td><strong>キーペア</strong></td>
<td>SSHでEC2に接続するための鍵ペア（公開鍵＋秘密鍵）</td>
</tr>
</tbody>
</table>
<hr>
<h2><span id="toc3">Apache（Webサーバー）と Tomcat（APサーバー）の違い</span></h2>
<table>
<thead>
<tr>
<th>比較項目</th>
<th>Apache（前回）</th>
<th>Tomcat（今回）</th>
</tr>
</thead>
<tbody>
<tr>
<td>種類</td>
<td>Webサーバー</td>
<td>APサーバー（Application Server）</td>
</tr>
<tr>
<td>得意なこと</td>
<td>静的ファイル（HTML/CSS/画像）の配信</td>
<td>Java（JSP/Servlet）の実行</td>
</tr>
<tr>
<td>デフォルトポート</td>
<td>80</td>
<td><strong>8080</strong></td>
</tr>
<tr>
<td>コンテンツの置き場</td>
<td><code>/var/www/html/</code></td>
<td><code>/opt/tomcat/latest/webapps/ROOT/</code></td>
</tr>
<tr>
<td>インストール方法</td>
<td><code>yum install httpd</code>（1コマンド）</td>
<td>Java + Tomcatを手動インストール（複数ステップ）</td>
</tr>
</tbody>
</table>
<hr>
<h2><span id="toc4">使用するAWSサービス</span></h2>
<table>
<thead>
<tr>
<th>サービス</th>
<th>役割</th>
<th>料金</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>EC2</strong></td>
<td>Java + Tomcatが動作するAPサーバー本体（t2.micro）</td>
<td>月750時間まで無料枠あり</td>
</tr>
<tr>
<td><strong>セキュリティグループ</strong></td>
<td>SSH/Tomcatのアクセス制御</td>
<td>無料</td>
</tr>
<tr>
<td><strong>IAM</strong></td>
<td>EC2へのSession Manager接続権限</td>
<td>無料</td>
</tr>
<tr>
<td><strong>EBS</strong></td>
<td>EC2にアタッチされるストレージ（デフォルト8GB）</td>
<td>月30GBまで無料枠あり</td>
</tr>
</tbody>
</table>
<blockquote>
<p><strong>注意</strong>: 無料枠はAWSアカウント開設から12ヶ月間です。期間終了後はEC2インスタンス稼働時間に課金されます。ハンズオン後は必ずリソースを削除してください。</p>
</blockquote>
<hr>
<h2><span id="toc5">構築するリソース</span></h2>
<table>
<thead>
<tr>
<th>リソース</th>
<th>役割</th>
</tr>
</thead>
<tbody>
<tr>
<td>キーペア</td>
<td>SSHでEC2に接続するための認証鍵</td>
</tr>
<tr>
<td>IAMロール</td>
<td>EC2にSession Manager接続の権限を付与</td>
</tr>
<tr>
<td>セキュリティグループ</td>
<td>SSH(22)・Tomcat(8080)のアクセス制御</td>
</tr>
<tr>
<td>EC2インスタンス</td>
<td>Java + Tomcatが動作するAPサーバー本体</td>
</tr>
</tbody>
</table>
<hr>
<h2><span id="toc6">全体の作業順序</span></h2>
<p>依存関係があるため、必ずこの順番で作成します。</p>
<pre><code class="language-plaintext">⓪ 自分のIPアドレスを確認する（重要）
      ↓
① キーペアを作成する
      ↓
② IAMロールを作成する
      ↓
③ EC2インスタンスを起動する
  （セキュリティグループ・UserDataも同時に設定）
      ↓
④ 動作確認（ブラウザ・SSH）
      ↓
⑤ リソースを削除する</code></pre>
<hr>
<h2><span id="toc7">【重要】⓪ 自分のIPアドレスを確認する</span></h2>
<p>セキュリティグループで自分のIPだけを許可するために、<strong>正確なIPアドレス</strong>を事前に確認します。</p>
<blockquote>
<p><strong>注意</strong>: <code>curl https://checkip.amazonaws.com</code> で表示されるIPと、EC2への実際の接続元IPが<strong>一致しない場合</strong>があります（ISPやプロキシの経路の違いによる）。最も確実な方法はルーター管理画面での確認です。</p>
</blockquote>
<h3><span id="toc8">方法A: ルーター管理画面で確認（推奨）</span></h3>
<ol>
<li>ブラウザで以下のURLにアクセスします（ルーターによって異なります）
<pre><code class="language-plaintext">http://192.168.0.1  または  http://192.168.1.1</code></pre>
</li>
<li>「ネットワークマップ」または「インターネット」項目を開く</li>
<li>**「インターネットIPアドレス」または「WAN IPアドレス」**の値を控えます</li>
</ol>
<h3><span id="toc9">方法B: コマンドで確認</span></h3>
<pre><code class="language-cmd">curl https://checkip.amazonaws.com</code></pre>
<p><strong>控えておく情報</strong>: 自分のIPアドレス（例: <code>203.0.113.1</code>）</p>
<hr>
<h2><span id="toc10">① キーペアの作成</span></h2>
<p>キーペアはSSHでEC2に接続するための鍵です。EC2起動時に指定する必要があるため、最初に作成します。</p>
<p><strong>AWSコンソール → EC2 → ネットワーク＆セキュリティ → キーペア → 「キーペアを作成」</strong></p>
<table>
<thead>
<tr>
<th>設定項目</th>
<th>値</th>
</tr>
</thead>
<tbody>
<tr>
<td>名前</td>
<td><code>my-ec2-tomcat-key</code></td>
</tr>
<tr>
<td>キーペアのタイプ</td>
<td><strong>RSA</strong></td>
</tr>
<tr>
<td>プライベートキーファイル形式</td>
<td><strong>.pem</strong></td>
</tr>
</tbody>
</table>
<p>「キーペアを作成」をクリックすると、自動的に <code>my-ec2-tomcat-key.pem</code> がダウンロードされます。</p>
<h3><span id="toc11">ダウンロードしたキーペアを保存する</span></h3>
<p>ダウンロードされた <code>my-ec2-tomcat-key.pem</code> を以下の場所に移動します。</p>
<pre><code class="language-plaintext">C:\Users\ユーザー名\.ssh\my-ec2-tomcat-key.pem</code></pre>
<blockquote>
<p><strong>注意</strong>: <code>.pem</code> ファイルは<strong>再ダウンロードできません</strong>。紛失した場合は新しいキーペアを作成する必要があります。</p>
</blockquote>
<blockquote>
<p><strong>前回のキーペアの流用について</strong>: EC2 + Apacheハンズオンで作成した <code>my-ec2-apache-key</code> を流用しても動作します。その場合この手順はスキップします。</p>
</blockquote>
<p><!-- ![キーペア作成画面](images/keypair-create.jpg) --></p>
<hr>
<h2><span id="toc12">② IAMロールの作成</span></h2>
<p>Session Manager（ブラウザからEC2に接続できるAWS機能）を使えるようにするためのIAMロールを作成します。</p>
<blockquote>
<p><strong>なぜIAMロールが必要か</strong>: EC2がAWSのサービス（Session Manager）を利用するには、そのEC2自身に「このサービスを使う権限」を付与する必要があります。この権限の設定がIAMロールです。</p>
</blockquote>
<p><strong>AWSコンソール → IAM → ロール → 「ロールを作成」</strong></p>
<h3><span id="toc13">ステップ1: エンティティタイプとユースケースの選択</span></h3>
<table>
<thead>
<tr>
<th>設定項目</th>
<th>値</th>
</tr>
</thead>
<tbody>
<tr>
<td>信頼されたエンティティタイプ</td>
<td><strong>AWSのサービス</strong></td>
</tr>
<tr>
<td>ユースケース</td>
<td><strong>EC2</strong></td>
</tr>
</tbody>
</table>
<p>「次へ」をクリック。</p>
<h3><span id="toc14">ステップ2: 許可ポリシーのアタッチ</span></h3>
<p>検索ボックスに <code>AmazonSSMManagedInstanceCore</code> と入力してチェックを入れます。</p>
<p>「次へ」をクリック。</p>
<h3><span id="toc15">ステップ3: ロール名の設定</span></h3>
<table>
<thead>
<tr>
<th>設定項目</th>
<th>値</th>
</tr>
</thead>
<tbody>
<tr>
<td>ロール名</td>
<td><code>my-ec2-tomcat-role</code></td>
</tr>
</tbody>
</table>
<p>「ロールを作成」をクリック。</p>
<p><!-- ![IAMロール作成画面](images/iam-role-create.jpg) --></p>
<hr>
<h2><span id="toc16">③ EC2インスタンスの起動</span></h2>
<p>キーペアとIAMロールを作成したあと、EC2インスタンスを起動します。<br />セキュリティグループとUserData（Java + Tomcat自動インストール）も同時に設定します。</p>
<p><strong>AWSコンソール → EC2 → インスタンス → 「インスタンスを起動」</strong></p>
<h3><span id="toc17">3-1. 基本設定</span></h3>
<table>
<thead>
<tr>
<th>設定項目</th>
<th>値</th>
</tr>
</thead>
<tbody>
<tr>
<td>名前</td>
<td><code>my-ec2-tomcat-instance</code></td>
</tr>
<tr>
<td>アプリケーションおよびOSイメージ</td>
<td><strong>Amazon Linux 2023 AMI</strong>（デフォルトで選択済み）</td>
</tr>
<tr>
<td>インスタンスタイプ</td>
<td><strong>t2.micro</strong>（無料枠対象）</td>
</tr>
<tr>
<td>キーペア</td>
<td><code>my-ec2-tomcat-key</code></td>
</tr>
</tbody>
</table>
<p><!-- ![EC2インスタンス起動画面 - 基本設定](images/ec2-launch-basic.jpg) --></p>
<h3><span id="toc18">3-2. セキュリティグループの設定</span></h3>
<p>「ネットワーク設定」→「セキュリティグループを作成する」を選択します。</p>
<p><strong>セキュリティグループ名と説明を設定:</strong></p>
<table>
<thead>
<tr>
<th>設定項目</th>
<th>値</th>
</tr>
</thead>
<tbody>
<tr>
<td>セキュリティグループ名</td>
<td><code>my-ec2-tomcat-sg</code></td>
</tr>
<tr>
<td>説明</td>
<td><code>EC2 Tomcat hands-on SG</code></td>
</tr>
</tbody>
</table>
<p><strong>「インバウンドセキュリティグループのルールを追加」ボタンで以下の2ルールを追加します。</strong></p>
<p><strong>ルール1: SSH接続の許可</strong></p>
<table>
<thead>
<tr>
<th>設定項目</th>
<th>値</th>
</tr>
</thead>
<tbody>
<tr>
<td>タイプ</td>
<td>SSH</td>
</tr>
<tr>
<td>ソースタイプ</td>
<td>カスタム</td>
</tr>
<tr>
<td>ソース</td>
<td><code>203.0.113.1/32</code>（⓪で確認した自分のIP + /32）</td>
</tr>
</tbody>
</table>
<p><strong>ルール2: Tomcat HTTPアクセスの許可</strong></p>
<table>
<thead>
<tr>
<th>設定項目</th>
<th>値</th>
</tr>
</thead>
<tbody>
<tr>
<td>タイプ</td>
<td>カスタム TCP</td>
</tr>
<tr>
<td>ポート範囲</td>
<td><code>8080</code></td>
</tr>
<tr>
<td>ソースタイプ</td>
<td>カスタム</td>
</tr>
<tr>
<td>ソース</td>
<td><code>203.0.113.1/32</code>（⓪で確認した自分のIP + /32）</td>
</tr>
</tbody>
</table>
<blockquote>
<p><strong>ポート8080について</strong>: TomcatはデフォルトでHTTP <strong>8080番ポート</strong>をListenします。Apacheの80番とは異なるため、セキュリティグループでも8080を明示的に開ける必要があります。</p>
</blockquote>
<blockquote>
<p><strong>/32 とは</strong>: 「このIPアドレス1つだけ」という意味のCIDR表記です。<code>0.0.0.0/0</code> は全世界に開放することになりセキュリティリスクが高いため、必ず自分のIPのみに制限します。</p>
</blockquote>
<p><!-- ![セキュリティグループ設定画面](images/security-group-create.jpg) --></p>
<h3><span id="toc19">3-3. IAMロールの設定</span></h3>
<p>「高度な詳細」を開く → 「IAM インスタンスプロファイル」→ <code>my-ec2-tomcat-role</code> を選択します。</p>
<h3><span id="toc20">3-4. UserDataの設定（Java + Tomcatの自動インストール）</span></h3>
<p>「高度な詳細」の一番下にある「ユーザーデータ」に以下を貼り付けます。</p>
<pre><code class="language-bash">#!/bin/bash
dnf update -y
dnf install -y java-17-amazon-corretto

useradd -m -d /opt/tomcat -U -s /bin/false tomcat

TOMCAT_VERSION="10.1.25"
cd /tmp
wget -q "https://archive.apache.org/dist/tomcat/tomcat-10/v${TOMCAT_VERSION}/bin/apache-tomcat-${TOMCAT_VERSION}.tar.gz" \
  -O apache-tomcat.tar.gz
tar xzf apache-tomcat.tar.gz
mv "apache-tomcat-${TOMCAT_VERSION}" /opt/tomcat/latest
chown -R tomcat:tomcat /opt/tomcat
chmod -R u+x /opt/tomcat/latest/bin

cat &gt; /etc/systemd/system/tomcat.service &lt;&lt; 'SVCEOF'
[Unit]
Description=Apache Tomcat Web Application Container
After=network.target

[Service]
Type=forking
User=tomcat
Group=tomcat
Environment="JAVA_HOME=/usr/lib/jvm/java-17-amazon-corretto"
Environment="CATALINA_HOME=/opt/tomcat/latest"
Environment="CATALINA_BASE=/opt/tomcat/latest"
Environment="CATALINA_PID=/opt/tomcat/latest/temp/tomcat.pid"
Environment="JAVA_OPTS=-Xms256m -Xmx512m"
ExecStart=/opt/tomcat/latest/bin/startup.sh
ExecStop=/opt/tomcat/latest/bin/shutdown.sh
Restart=on-failure

[Install]
WantedBy=multi-user.target
SVCEOF

systemctl daemon-reload
systemctl enable tomcat
systemctl start tomcat

cat &gt; /opt/tomcat/latest/webapps/ROOT/index.jsp &lt;&lt; 'JSPEOF'
&lt;%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%&gt;
&lt;!DOCTYPE html&gt;
&lt;html&gt;
&lt;head&gt;&lt;meta charset="UTF-8"&gt;&lt;title&gt;Tomcat on EC2&lt;/title&gt;&lt;/head&gt;
&lt;body&gt;
&lt;h1&gt;Hello from Tomcat on Amazon Linux 2023!&lt;/h1&gt;
&lt;p&gt;Java Version: &lt;%= System.getProperty("java.version") %&gt;&lt;/p&gt;
&lt;p&gt;Tomcat Version: &lt;%= application.getServerInfo() %&gt;&lt;/p&gt;
&lt;/body&gt;
&lt;/html&gt;
JSPEOF
chown tomcat:tomcat /opt/tomcat/latest/webapps/ROOT/index.jsp</code></pre>
<p><strong>各コマンドの説明:</strong></p>
<table>
<thead>
<tr>
<th>コマンド</th>
<th>意味</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>dnf update -y</code></td>
<td>OSのパッケージを最新化する（Amazon Linux 2023はdnfを使用）</td>
</tr>
<tr>
<td><code>dnf install -y java-17-amazon-corretto</code></td>
<td>AWSが提供するJava 17ディストリビューションをインストール</td>
</tr>
<tr>
<td><code>useradd -m -d /opt/tomcat -U -s /bin/false tomcat</code></td>
<td>Tomcat専用システムユーザーを作成（ログイン不可・セキュリティ対策）</td>
</tr>
<tr>
<td><code>wget -q ... -O apache-tomcat.tar.gz</code></td>
<td>Apache公式アーカイブからTomcatをダウンロード</td>
</tr>
<tr>
<td><code>tar xzf apache-tomcat.tar.gz</code></td>
<td>ダウンロードしたtar.gzを展開</td>
</tr>
<tr>
<td><code>mv ... /opt/tomcat/latest</code></td>
<td>Tomcatを <code>/opt/tomcat/latest/</code> に配置</td>
</tr>
<tr>
<td><code>chown -R tomcat:tomcat /opt/tomcat</code></td>
<td>Tomcatディレクトリの所有者をtomcatユーザーに変更</td>
</tr>
<tr>
<td><code>chmod -R u+x /opt/tomcat/latest/bin</code></td>
<td>binディレクトリのスクリプトに実行権限を付与</td>
</tr>
<tr>
<td><code>cat &gt; /etc/systemd/system/tomcat.service</code></td>
<td>TomcatをLinuxサービスとして登録するファイルを作成</td>
</tr>
<tr>
<td><code>systemctl daemon-reload</code></td>
<td>systemdにサービス定義ファイルの変更を反映</td>
</tr>
<tr>
<td><code>systemctl enable tomcat</code></td>
<td>OS起動時にTomcatが自動起動するよう設定</td>
</tr>
<tr>
<td><code>systemctl start tomcat</code></td>
<td>Tomcatを起動</td>
</tr>
<tr>
<td><code>cat &gt; .../index.jsp</code></td>
<td>テスト用JSPページを作成（Javaコード入り）</td>
</tr>
</tbody>
</table>
<blockquote>
<p><strong>Amazon Corretto（コレット）とは</strong>: AWSが提供するOpenJDKのディストリビューション。無償・本番利用可能で、Amazon Linux 2023のパッケージリポジトリから直接インストールできます。</p>
</blockquote>
<blockquote>
<p><strong>JAVA_OPTS=-Xms256m -Xmx512m</strong>: Javaの使用メモリを制限する設定です。t2.microは1GBのメモリしかないため、最小256MB・最大512MBに制限して他のプロセスと共存できるようにしています。</p>
</blockquote>
<blockquote>
<p><strong>UserDataはインスタンスの初回起動時のみ実行されます</strong>。Tomcatのダウンロードを含むため、完了まで<strong>約5〜10分</strong>かかります。</p>
</blockquote>
<h3><span id="toc21">3-5. インスタンスを起動する</span></h3>
<p>「インスタンスを起動」ボタンをクリック。</p>
<p>起動完了まで約2〜3分待ちます。インスタンスの「状態」が「実行中」になったことを確認します。</p>
<p><strong>控えておく情報: インスタンスのパブリックIPアドレス</strong></p>
<p>インスタンス一覧 → 作成したインスタンスをクリック → 「パブリック IPv4 アドレス」を確認してメモします。</p>
<p><!-- ![EC2インスタンス起動後の画面](images/ec2-running.jpg) --></p>
<hr>
<h2><span id="toc22">④ 動作確認</span></h2>
<blockquote>
<p><strong>重要</strong>: UserDataでのJava + Tomcatインストールが完了するまで<strong>約5〜10分</strong>かかります。インスタンスが「実行中」になってもすぐには接続できません。</p>
</blockquote>
<h3><span id="toc23">ブラウザで確認</span></h3>
<p>ブラウザで以下のURLにアクセスします。ポート番号 <strong>8080</strong> を忘れずに入力してください。</p>
<pre><code class="language-plaintext">http://（パブリックIPアドレス）:8080</code></pre>
<p>以下のように表示されれば成功です。</p>
<pre><code class="language-plaintext">Hello from Tomcat on Amazon Linux 2023!
Java Version: 17.x.x
Tomcat Version: Apache Tomcat/10.1.25</code></pre>
<blockquote>
<p><strong>JSPが実行されている証拠</strong>: <code>Java Version</code> や <code>Tomcat Version</code> はJavaコード（<code>&lt;%= ... %&gt;</code>）がサーバー側で実行されて表示されています。ApacheのHTMLと違い、TomcatがJavaを動かして動的にページを生成しています。</p>
</blockquote>
<blockquote>
<p><strong>表示されない場合</strong>: UserDataのインストールが完了していない可能性があります。5〜10分待ってからリロードしてください。それでも表示されない場合はSSHで接続してログを確認します。</p>
</blockquote>
<p><!-- ![ブラウザでのTomcat動作確認](images/tomcat-web-browser.jpg) --></p>
<h3><span id="toc24">SSHで接続して確認</span></h3>
<p>ローカルPCのターミナル（VSCode CMD）で実行します。</p>
<pre><code class="language-cmd">ssh -i C:\Users\ユーザー名\.ssh\my-ec2-tomcat-key.pem ec2-user@（パブリックIPアドレス）</code></pre>
<p>初回接続時に以下の確認が出ます。<code>yes</code> を入力します。</p>
<pre><code class="language-plaintext">Are you sure you want to continue connecting (yes/no)? yes</code></pre>
<p>接続できたら以下を実行します。</p>
<pre><code class="language-bash">java -version

# Tomcatサービスの動作状態を確認（active (running) と表示されれば正常）
sudo systemctl status tomcat

# TomcatのメインログでERRORがないか確認
sudo tail -50 /opt/tomcat/latest/logs/catalina.out

# Tomcatが8080番ポートをListenしているか確認
sudo ss -tlnp | grep :8080

# EC2から切断
exit</code></pre>
<p><strong>Tomcatのディレクトリ構成:</strong></p>
<table>
<thead>
<tr>
<th>パス</th>
<th>役割</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>/opt/tomcat/latest/webapps/ROOT/</code></td>
<td>デフォルトWebアプリのルート（JSP/HTMLを置く場所）</td>
</tr>
<tr>
<td><code>/opt/tomcat/latest/conf/server.xml</code></td>
<td>Tomcatの設定ファイル（ポート番号などを管理）</td>
</tr>
<tr>
<td><code>/opt/tomcat/latest/logs/catalina.out</code></td>
<td>Tomcatのメインログ（エラー確認に使う）</td>
</tr>
<tr>
<td><code>/opt/tomcat/latest/bin/startup.sh</code></td>
<td>Tomcat起動スクリプト</td>
</tr>
<tr>
<td><code>/opt/tomcat/latest/bin/shutdown.sh</code></td>
<td>Tomcat停止スクリプト</td>
</tr>
</tbody>
</table>
<h3><span id="toc25">UserDataのインストール状況を確認する方法</span></h3>
<p>インスタンスにSSHで接続できた場合、UserDataの実行ログで進捗を確認できます。</p>
<pre><code class="language-bash"># UserDataのログを確認（インストールの進捗・エラーを確認できる）
sudo cat /var/log/cloud-init-output.log</code></pre>
<p><!-- ![SSH接続後のTomcat動作確認](images/ssh-tomcat-status.jpg) --></p>
<h3><span id="toc26">【接続できない場合】IPアドレスが異なる可能性</span></h3>
<p><code>curl</code> で確認したIPを設定したが接続できない場合、実際の接続元IPが異なる可能性があります。</p>
<p><strong>一時的に全開放して真のIPを確認する方法:</strong></p>
<p>コンソール → EC2 → セキュリティグループ → <code>my-ec2-tomcat-sg</code> → 「インバウンドルールを編集」</p>
<p>SSHのルールを一時的に <code>0.0.0.0/0</code> に変更してSSH接続し、以下を実行します。</p>
<pre><code class="language-bash">echo $SSH_CLIENT
# 出力例: 203.0.113.1 17508 22
# 先頭の値が真の接続元IP</code></pre>
<p>このIPをメモしてSSH接続を切断し、セキュリティグループのSSHルールを <code>真のIP/32</code> に戻します。</p>
<hr>
<h2><span id="toc27">⑤ リソースの削除</span></h2>
<p><strong>課金を止めるために、ハンズオン完了後は必ず削除してください。削除する順番が重要です。</strong></p>
<h3><span id="toc28">1. EC2インスタンスを終了する</span></h3>
<p><strong>EC2 → インスタンス → <code>my-ec2-tomcat-instance</code> を選択 → 「インスタンスの状態」→「インスタンスを終了」</strong></p>
<p>確認ダイアログで「終了」をクリック。状態が「終了済み」になるまで待ちます（2〜5分）。</p>
<blockquote>
<p><strong>「停止」と「終了」の違い</strong>: 「停止」は一時停止（EBSストレージ課金は続く）。「終了」は完全削除（課金停止）。学習後は「終了」を選びます。</p>
</blockquote>
<h3><span id="toc29">2. セキュリティグループを削除する</span></h3>
<p><strong>EC2 → セキュリティグループ → <code>my-ec2-tomcat-sg</code> を選択 → 「アクション」→「セキュリティグループを削除」</strong></p>
<blockquote>
<p>インスタンス終了が完了している必要があります。「使用中」エラーが出る場合はインスタンスが「終了済み」状態になるまで待ってください。</p>
</blockquote>
<h3><span id="toc30">3. IAMロールを削除する</span></h3>
<p><strong>IAM → ロール → <code>my-ec2-tomcat-role</code> を選択 → 「削除」→ ロール名を入力して確認</strong></p>
<h3><span id="toc31">4. キーペアを削除する（任意）</span></h3>
<p>他のEC2でも使い回す場合は残してよいです。不要な場合は削除します。</p>
<p><strong>EC2 → キーペア → <code>my-ec2-tomcat-key</code> を選択 → 「アクション」→「削除」→ 確認テキストを入力</strong></p>
<p>ローカルの <code>.pem</code> ファイルも手動で削除します。</p>
<pre><code class="language-plaintext">C:\Users\ユーザー名\.ssh\my-ec2-tomcat-key.pem</code></pre>
<hr>
<h2><span id="toc32">CloudFormation版との比較</span></h2>
<p>コンソール版を体験したら、次は同じ構成をCloudFormation（コード）で再現してみましょう。何が自動化されるのかがよくわかります。</p>
<table>
<thead>
<tr>
<th>作業</th>
<th>コンソール（手動）</th>
<th>CloudFormation</th>
</tr>
</thead>
<tbody>
<tr>
<td>IAMロール作成</td>
<td>画面でポチポチ（5クリック以上）</td>
<td>template.yaml に定義済み</td>
</tr>
<tr>
<td>セキュリティグループ作成</td>
<td>画面でポチポチ</td>
<td>template.yaml に定義済み</td>
</tr>
<tr>
<td>EC2起動（UserData含む）</td>
<td>画面でポチポチ</td>
<td>template.yaml に定義済み</td>
</tr>
<tr>
<td>デプロイ全体</td>
<td>複数画面を行き来（20〜30分）</td>
<td>コマンド1本（5〜10分）</td>
</tr>
<tr>
<td>削除</td>
<td>リソースを個別に依存関係順で手動削除</td>
<td><code>delete-stack</code> 1本</td>
</tr>
<tr>
<td>再現性</td>
<td>低い（手動ミスのリスクがある）</td>
<td>高い（同じ環境を何度でも再現可能）</td>
</tr>
<tr>
<td>バージョン管理</td>
<td>不可</td>
<td>Gitで管理可能</td>
</tr>
</tbody>
</table>
<p><strong>コンソール版で実感できたポイント:</strong></p>
<ul>
<li>Java + Tomcatのインストール手順が長く、手動では設定ミスが起きやすいことを実感できる</li>
<li>ポート8080の開放やTomcatユーザーの作成など、セキュリティ設定の重要性が身につく</li>
<li>UserDataの完了を待つ間に、コンソール版とCloudFormation版の差が体感できる</li>
</ul>
<p><strong>CloudFormation版でも試してみる</strong>: <a href="https://caymezon.com/aws-handson-cloudformation-ec2-tomcat/">EC2サーバ構築をIaC化：CloudFormationでEC2 Tomcatを自動デプロイする手順</a></p>
<hr>
<h2><span id="toc33">トラブルシューティング</span></h2>
<table>
<thead>
<tr>
<th>症状</th>
<th>原因</th>
<th>対処</th>
</tr>
</thead>
<tbody>
<tr>
<td>ブラウザで何も表示されない（起動後10分以内）</td>
<td>UserDataのインストールが完了していない</td>
<td><code>sudo cat /var/log/cloud-init-output.log</code> でインストール状況を確認</td>
</tr>
<tr>
<td>ブラウザで何も表示されない（10分以上経過）</td>
<td>Tomcatが起動に失敗している</td>
<td><code>sudo systemctl status tomcat</code> と <code>sudo tail -100 /opt/tomcat/latest/logs/catalina.out</code> を確認</td>
</tr>
<tr>
<td>ブラウザでTomcatのデフォルトページが表示される</td>
<td>JSPの配置タイミングがTomcat起動より遅れた</td>
<td><code>sudo systemctl restart tomcat</code> でTomcatを再起動する</td>
</tr>
<tr>
<td>SSH接続タイムアウト</td>
<td>セキュリティグループのIP設定誤り</td>
<td>セキュリティグループのSSH(22)ルールのIPを確認</td>
</tr>
<tr>
<td>ブラウザにアクセスできない（8080）</td>
<td>セキュリティグループのポート8080が開いていない</td>
<td>セキュリティグループのインバウンドルールで8080が追加されているか確認</td>
</tr>
<tr>
<td><code>java: command not found</code></td>
<td>Javaのインストールが失敗している</td>
<td><code>sudo dnf install -y java-17-amazon-corretto</code> を手動実行</td>
</tr>
<tr>
<td>Tomcatは起動しているがJSPが動かない</td>
<td>index.jspの所有者がtomcatユーザーになっていない</td>
<td><code>sudo chown tomcat:tomcat /opt/tomcat/latest/webapps/ROOT/index.jsp</code> を実行</td>
</tr>
<tr>
<td>セキュリティグループが削除できない</td>
<td>EC2インスタンスがまだ使用中</td>
<td>インスタンス「終了済み」状態になってから再試行</td>
</tr>
</tbody>
</table>
<hr>
<h2><span id="toc34">まとめ</span></h2>
<p>今回のハンズオンで体験できたこと：</p>
<table>
<thead>
<tr>
<th>確認項目</th>
<th>内容</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>キーペア作成</strong></td>
<td>SSH接続に必要な鍵ペアをコンソールで作成し、.pemファイルをローカルに保存</td>
</tr>
<tr>
<td><strong>IAMロール作成</strong></td>
<td>AmazonSSMManagedInstanceCoreポリシーをEC2にアタッチして接続権限を付与</td>
</tr>
<tr>
<td><strong>セキュリティグループ</strong></td>
<td>SSH(22)/Tomcat(8080)を自分のIPのみに制限してEC2を保護</td>
</tr>
<tr>
<td><strong>UserDataによる自動化</strong></td>
<td>Java 17 + Tomcat 10のインストールと起動を初回起動時のスクリプトで自動化</td>
</tr>
<tr>
<td><strong>APサーバー確認</strong></td>
<td>ブラウザとSSHの両方でTomcat動作・JSP実行を確認</td>
</tr>
<tr>
<td><strong>リソース削除</strong></td>
<td>依存関係順に4つのリソースを手動で削除</td>
</tr>
</tbody>
</table>
<p>手動操作でひとつひとつ作ると、CloudFormationが裏で何を自動化しているかが理解できます。ぜひ次は <a href="https://caymezon.com/aws-handson-cloudformation-ec2-tomcat/">CloudFormation版</a> で同じ構成をコードで再現してみてください。</p>
<hr>
<h2><span id="toc35">関連記事</span></h2>
<p><!-- <a rel="nofollow" href="//af.moshimo.com/af/c/click?a_id=1384942&p_id=170&pc_id=185&pl_id=4062&url=https%3A%2F%2Fwww.amazon.co.jp%2Fs%3Fk%3D%25E6%259C%25AC%2BAWS%2B%25E9%2596%258B%25E7%2599%25BA%26__mk_ja_JP%3D%25E3%2582%25AB%25E3%2582%25BF%25E3%2582%25AB%25E3%2583%258A%26crid%3D1DE63UBHFOR4K%26sprefix%3D%25E6%259C%25AC%2Baws%2B%25E9%2596%258B%25E7%2599%25BA%252Caps%252C167%26ref%3Dnb_sb_noss" referrerpolicy="no-referrer-when-downgrade" attributionsrc>Amazon検索[本 AWS 開発]</a><img decoding="async" src="//i.moshimo.com/af/i/impression?a_id=1384942&p_id=170&pc_id=185&pl_id=4062" width="1" height="1" style="border:none;" alt="" loading="lazy"> --></p>
<p><!-- <!-- START MoshimoAffiliateEasyLink --><script type="text/javascript">(function(b,c,f,g,a,d,e){b.MoshimoAffiliateObject=a;b[a]=b[a]||function(){arguments.currentScript=c.currentScript||c.scripts[c.scripts.length-2];(b[a].q=b[a].q||[]).push(arguments)};c.getElementById(a)||(d=c.createElement(f),d.src=g,d.id=a,e=c.getElementsByTagName("body")[0],e.appendChild(d))})(window,document,"script","//dn.msmstatic.com/site/cardlink/bundle.js?20220329","msmaflink");msmaflink({"n":"AWS運用入門 改訂第2版 押さえておきたいAWSの基本と運用ノウハウ [AWS深掘りガイド]","b":"SBクリエイティブ","t":"","d":"https:\/\/m.media-amazon.com","c_p":"\/images\/I","p":["\/51AAOubymTL._SL500_.jpg","\/51VMG6YKHdL._SL500_.jpg","\/41EdPB8azAL._SL500_.jpg","\/41v2JFE-9jL._SL500_.jpg","\/41FEEqR-yDL._SL500_.jpg","\/41JfZAdnTPL._SL500_.jpg","\/41vGK0czQrL._SL500_.jpg","\/41-SnYtz2aL._SL500_.jpg","\/41sPrV5fi3L._SL500_.jpg","\/41p7JtvYJ1L._SL500_.jpg","\/4169GVNTs8L._SL500_.jpg","\/41BPI5HP3zL._SL500_.jpg","\/41QOyk60CYL._SL500_.jpg","\/41APjk6FphL._SL500_.jpg","\/41ezKUu7VRL._SL500_.jpg","\/41A1n3K+r5L._SL500_.jpg","\/41aY2T8lEOL._SL500_.jpg","\/419Ca1V6HZL._SL500_.jpg","\/41zQkYyLPzL._SL500_.jpg","\/41YpHcyxiTL._SL500_.jpg","\/41-tKN5mt6L._SL500_.jpg","\/419Mv6m55IL._SL500_.jpg"],"u":{"u":"https:\/\/www.amazon.co.jp\/dp\/4815631085","t":"amazon","r_v":""},"v":"2.1","b_l":[{"id":1,"u_tx":"Amazonで見る","u_bc":"#f79256","u_url":"https:\/\/www.amazon.co.jp\/dp\/4815631085","a_id":1384942,"p_id":170,"pl_id":27060,"pc_id":185,"s_n":"amazon","u_so":1},{"id":2,"u_tx":"楽天市場で見る","u_bc":"#f76956","u_url":"https:\/\/search.rakuten.co.jp\/search\/mall\/AWS%E9%81%8B%E7%94%A8%E5%85%A5%E9%96%80%20%E6%94%B9%E8%A8%82%E7%AC%AC2%E7%89%88%20%E6%8A%BC%E3%81%95%E3%81%88%E3%81%A6%E3%81%8A%E3%81%8D%E3%81%9F%E3%81%84AWS%E3%81%AE%E5%9F%BA%E6%9C%AC%E3%81%A8%E9%81%8B%E7%94%A8%E3%83%8E%E3%82%A6%E3%83%8F%E3%82%A6%20%5BAWS%E6%B7%B1%E6%8E%98%E3%82%8A%E3%82%AC%E3%82%A4%E3%83%89%5D\/","a_id":1384917,"p_id":54,"pl_id":27059,"pc_id":54,"s_n":"rakuten","u_so":2},{"id":3,"u_tx":"Yahoo!ショッピングで見る","u_bc":"#66a7ff","u_url":"https:\/\/shopping.yahoo.co.jp\/search?first=1\u0026p=AWS%E9%81%8B%E7%94%A8%E5%85%A5%E9%96%80%20%E6%94%B9%E8%A8%82%E7%AC%AC2%E7%89%88%20%E6%8A%BC%E3%81%95%E3%81%88%E3%81%A6%E3%81%8A%E3%81%8D%E3%81%9F%E3%81%84AWS%E3%81%AE%E5%9F%BA%E6%9C%AC%E3%81%A8%E9%81%8B%E7%94%A8%E3%83%8E%E3%82%A6%E3%83%8F%E3%82%A6%20%5BAWS%E6%B7%B1%E6%8E%98%E3%82%8A%E3%82%AC%E3%82%A4%E3%83%89%5D","a_id":1466950,"p_id":1225,"pl_id":27061,"pc_id":1925,"s_n":"yahoo","u_so":3}],"eid":"E8MM1","s":"s"});</script></p>
<div id="msmaflink-E8MM1">リンク</div>
<p><!-- MoshimoAffiliateEasyLink END --> --></p><p>The post <a href="https://caymezon.com/aws-handson-console-ec2-tomcat/">EC2サーバ構築ハンズオン：AWSコンソールでTomcatを構築する手順【EC2 Tomcat / CloudFormation版との比較付き】</a> first appeared on <a href="https://caymezon.com">CayTech Lab</a>.</p>]]></content:encoded>
					
					<wfw:commentRss>https://caymezon.com/aws-handson-console-ec2-tomcat/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>EC2サーバ構築をIaC化：CloudFormationでEC2 Tomcatを自動デプロイする手順【コンソール版との比較付き】</title>
		<link>https://caymezon.com/aws-handson-cloudformation-ec2-tomcat/</link>
					<comments>https://caymezon.com/aws-handson-cloudformation-ec2-tomcat/#respond</comments>
		
		<dc:creator><![CDATA[caymezon]]></dc:creator>
		<pubDate>Sun, 29 Mar 2026 04:44:49 +0000</pubDate>
				<category><![CDATA[AWS Basic]]></category>
		<category><![CDATA[Cloud & Infra]]></category>
		<category><![CDATA[APサーバー]]></category>
		<category><![CDATA[AWS]]></category>
		<category><![CDATA[AWSCLI]]></category>
		<category><![CDATA[CloudFormation]]></category>
		<category><![CDATA[EC2]]></category>
		<category><![CDATA[ec2サーバ構築]]></category>
		<category><![CDATA[IaC]]></category>
		<category><![CDATA[IAM]]></category>
		<category><![CDATA[Java]]></category>
		<category><![CDATA[Tomcat]]></category>
		<category><![CDATA[UserData]]></category>
		<category><![CDATA[セキュリティグループ]]></category>
		<category><![CDATA[ハンズオン]]></category>
		<category><![CDATA[初心者]]></category>
		<guid isPermaLink="false">https://caymezon.com/?p=20311</guid>

					<description><![CDATA[<p>目次 はじめにCloudFormation vs コンソール：どれだけ違うかキーワード解説前提条件template.yaml の全文作業順序【重要】⓪ 自分のIPアドレスを確認する方法A: ルーター管理画面で確認（推奨） [&#8230;]</p>
<p>The post <a href="https://caymezon.com/aws-handson-cloudformation-ec2-tomcat/">EC2サーバ構築をIaC化：CloudFormationでEC2 Tomcatを自動デプロイする手順【コンソール版との比較付き】</a> first appeared on <a href="https://caymezon.com">CayTech Lab</a>.</p>]]></description>
										<content:encoded><![CDATA[<div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-4" checked><label class="toc-title" for="toc-checkbox-4">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">はじめに</a></li><li><a href="#toc2" tabindex="0">CloudFormation vs コンソール：どれだけ違うか</a></li><li><a href="#toc3" tabindex="0">キーワード解説</a></li><li><a href="#toc4" tabindex="0">前提条件</a></li><li><a href="#toc5" tabindex="0">template.yaml の全文</a></li><li><a href="#toc6" tabindex="0">作業順序</a></li><li><a href="#toc7" tabindex="0">【重要】⓪ 自分のIPアドレスを確認する</a><ol><li><a href="#toc8" tabindex="0">方法A: ルーター管理画面で確認（推奨）</a></li><li><a href="#toc9" tabindex="0">方法B: コマンドで確認</a></li></ol></li><li><a href="#toc10" tabindex="0">① キーペアの作成（コンソールで実施）</a></li><li><a href="#toc11" tabindex="0">② プロジェクトフォルダに移動する</a></li><li><a href="#toc12" tabindex="0">③ スタックの作成</a></li><li><a href="#toc13" tabindex="0">④ 作成完了・Outputsの確認</a><ol><li><a href="#toc14" tabindex="0">作成状況の確認</a></li><li><a href="#toc15" tabindex="0">Outputs（接続情報）の確認</a></li></ol></li><li><a href="#toc16" tabindex="0">⑤ 動作確認</a><ol><li><a href="#toc17" tabindex="0">ブラウザで確認</a></li><li><a href="#toc18" tabindex="0">SSHで接続して確認</a></li><li><a href="#toc19" tabindex="0">【接続できない場合】真のIPアドレスを確認する</a></li></ol></li><li><a href="#toc20" tabindex="0">⑥ スタックの削除</a></li><li><a href="#toc21" tabindex="0">コンソール版との比較</a></li><li><a href="#toc22" tabindex="0">トラブルシューティング</a></li><li><a href="#toc23" tabindex="0">まとめ</a><ol><li><a href="#toc24" tabindex="0">CloudFormationのメリットを実感できたポイント</a></li></ol></li><li><a href="#toc25" tabindex="0">コンソール版と比較してみる</a></li><li><a href="#toc26" tabindex="0">関連記事</a></li></ol>
    </div>
  </div>

<h2><span id="toc1">はじめに</span></h2>
<p>「コンソールで手動構築できた構成を、コードで再現したい」——それを実現するのが <strong>AWS CloudFormation</strong> です。</p>
<p>この記事では、<code>template.yaml</code> 1ファイルにリソース構成を定義し、<strong>コマンド1本でEC2 Tomcat環境を一括構築するハンズオン</strong>を紹介します。コンソール版（<a href="https://caymezon.com/aws-handson-console-ec2-tomcat/">AWSコンソール版ハンズオン</a>）と全く同じ構成を、CloudFormationで自動化します。</p>
<pre><code class="language-plaintext">ローカル環境（VSCode）
  ├── template.yaml（CloudFormationテンプレート）
  └── AWS CLI コマンド
        ↓ スタック作成（コマンド1本）
AWS環境
  ├── IAMロール（SSM接続用）                       ← template.yamlで定義
  ├── セキュリティグループ（SSH:22・Tomcat:8080）    ← template.yamlで定義
  └── EC2インスタンス（t2.micro / AL2023 + Java17 + Tomcat10）← template.yamlで定義</code></pre>
<p><strong>このハンズオンで体験できること：</strong></p>
<ul>
<li><code>template.yaml</code> へのリソース定義（IAMロール・セキュリティグループ・EC2インスタンス）</li>
<li><code>!Ref</code> / <code>!Sub</code> / <code>!GetAtt</code> を使ったリソース間参照</li>
<li><code>aws cloudformation create-stack</code> コマンド1本での全リソース一括デプロイ</li>
<li><code>aws cloudformation delete-stack</code> コマンド1本での全リソース一括削除</li>
</ul>
<p><strong>このハンズオンの特徴：</strong></p>
<ul>
<li>コンソール版では20〜30分かかった手動作業が、コマンド1本（約5〜10分）で完了する</li>
<li><code>delete-stack</code> 1本で依存関係を考慮した順番で全リソースを自動削除できる</li>
</ul>
<hr>
<p><!-- ![CloudFormationスタック作成完了画面](images/cfn-create-complete.jpg) --></p>
<p><!-- <a rel="nofollow" href="//af.moshimo.com/af/c/click?a_id=1384942&p_id=170&pc_id=185&pl_id=4062&url=https%3A%2F%2Fwww.amazon.co.jp%2Fs%3Fk%3D%25E6%259C%25AC%2BAWS%2B%25E9%2596%258B%25E7%2599%25BA%26__mk_ja_JP%3D%25E3%2582%25AB%25E3%2582%25BF%25E3%2582%25AB%25E3%2583%258A%26crid%3D1DE63UBHFOR4K%26sprefix%3D%25E6%259C%25AC%2Baws%2B%25E9%2596%258B%25E7%2599%25BA%252Caps%252C167%26ref%3Dnb_sb_noss" referrerpolicy="no-referrer-when-downgrade" attributionsrc>Amazon検索[本 AWS 開発]</a><img decoding="async" src="//i.moshimo.com/af/i/impression?a_id=1384942&p_id=170&pc_id=185&pl_id=4062" width="1" height="1" style="border:none;" alt="" loading="lazy"> --></p>
<p><!-- <!-- START MoshimoAffiliateEasyLink --><script type="text/javascript">(function(b,c,f,g,a,d,e){b.MoshimoAffiliateObject=a;b[a]=b[a]||function(){arguments.currentScript=c.currentScript||c.scripts[c.scripts.length-2];(b[a].q=b[a].q||[]).push(arguments)};c.getElementById(a)||(d=c.createElement(f),d.src=g,d.id=a,e=c.getElementsByTagName("body")[0],e.appendChild(d))})(window,document,"script","//dn.msmstatic.com/site/cardlink/bundle.js?20220329","msmaflink");msmaflink({"n":"AWSの基本・仕組み・重要用語が全部わかる教科書 (見るだけ図解)","b":"SBクリエイティブ","t":"","d":"https:\/\/m.media-amazon.com","c_p":"\/images\/I","p":["\/51DEDQXj6oL._SL500_.jpg","\/41F589smNwL._SL500_.jpg","\/41R6f9yyCWL._SL500_.jpg","\/41HqWQ9BvmL._SL500_.jpg","\/41p8p0ZU79L._SL500_.jpg","\/41qLC-fndBL._SL500_.jpg","\/41fcLv9VT5L._SL500_.jpg","\/51lRvCsvHqL._SL500_.jpg"],"u":{"u":"https:\/\/www.amazon.co.jp\/dp\/4815607850","t":"amazon","r_v":""},"v":"2.1","b_l":[{"id":1,"u_tx":"Amazonで見る","u_bc":"#f79256","u_url":"https:\/\/www.amazon.co.jp\/dp\/4815607850","a_id":1384942,"p_id":170,"pl_id":27060,"pc_id":185,"s_n":"amazon","u_so":1},{"id":2,"u_tx":"楽天市場で見る","u_bc":"#f76956","u_url":"https:\/\/search.rakuten.co.jp\/search\/mall\/AWS%E3%81%AE%E5%9F%BA%E6%9C%AC%E3%83%BB%E4%BB%95%E7%B5%84%E3%81%BF%E3%83%BB%E9%87%8D%E8%A6%81%E7%94%A8%E8%AA%9E%E3%81%8C%E5%85%A8%E9%83%A8%E3%82%8F%E3%81%8B%E3%82%8B%E6%95%99%E7%A7%91%E6%9B%B8%20(%E8%A6%8B%E3%82%8B%E3%81%A0%E3%81%91%E5%9B%B3%E8%A7%A3)\/","a_id":1384917,"p_id":54,"pl_id":27059,"pc_id":54,"s_n":"rakuten","u_so":2},{"id":3,"u_tx":"Yahoo!ショッピングで見る","u_bc":"#66a7ff","u_url":"https:\/\/shopping.yahoo.co.jp\/search?first=1\u0026p=AWS%E3%81%AE%E5%9F%BA%E6%9C%AC%E3%83%BB%E4%BB%95%E7%B5%84%E3%81%BF%E3%83%BB%E9%87%8D%E8%A6%81%E7%94%A8%E8%AA%9E%E3%81%8C%E5%85%A8%E9%83%A8%E3%82%8F%E3%81%8B%E3%82%8B%E6%95%99%E7%A7%91%E6%9B%B8%20(%E8%A6%8B%E3%82%8B%E3%81%A0%E3%81%91%E5%9B%B3%E8%A7%A3)","a_id":1466950,"p_id":1225,"pl_id":27061,"pc_id":1925,"s_n":"yahoo","u_so":3}],"eid":"eaCUB","s":"s"});</script></p>
<div id="msmaflink-eaCUB">リンク</div>
<p><!-- MoshimoAffiliateEasyLink END --> --></p>
<h2><span id="toc2">CloudFormation vs コンソール：どれだけ違うか</span></h2>
<table>
<thead>
<tr>
<th>比較項目</th>
<th>CloudFormation</th>
<th>コンソール（手動）</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>IAMロール作成</strong></td>
<td><code>--parameters</code> で値を渡すだけ</td>
<td>画面でポチポチ（5クリック以上）</td>
</tr>
<tr>
<td><strong>セキュリティグループ作成</strong></td>
<td>同上</td>
<td>画面でポチポチ</td>
</tr>
<tr>
<td><strong>EC2起動（UserData含む）</strong></td>
<td>同上</td>
<td>画面でポチポチ</td>
</tr>
<tr>
<td><strong>全リソースのデプロイ</strong></td>
<td>コマンド1本（5〜10分）</td>
<td>複数画面を行き来（20〜30分）</td>
</tr>
<tr>
<td><strong>リソース削除</strong></td>
<td><code>delete-stack</code> 1本</td>
<td>依存関係順に個別削除（4ステップ）</td>
</tr>
<tr>
<td><strong>再現性</strong></td>
<td>高い（同じ構成を何度でも再現可能）</td>
<td>低い（手動ミスのリスクがある）</td>
</tr>
<tr>
<td><strong>バージョン管理</strong></td>
<td>Gitで管理可能</td>
<td>不可（過去の設定を記録できない）</td>
</tr>
</tbody>
</table>
<hr>
<h2><span id="toc3">キーワード解説</span></h2>
<table>
<thead>
<tr>
<th>用語</th>
<th>意味</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>CloudFormation</strong></td>
<td>AWSが提供するIaC（Infrastructure as Code）サービス。YAMLテンプレートでリソースをコード化する</td>
</tr>
<tr>
<td><strong>スタック</strong></td>
<td>CloudFormationが管理するリソースのまとまり。作成・削除・更新をまとめて操作できる</td>
</tr>
<tr>
<td><strong><code>!Ref</code></strong></td>
<td>CloudFormation組み込み関数。パラメータの値やリソースのIDを参照する</td>
</tr>
<tr>
<td><strong><code>!Sub</code></strong></td>
<td>CloudFormation組み込み関数。文字列内の <code>${変数}</code> を展開する</td>
</tr>
<tr>
<td><strong><code>!GetAtt</code></strong></td>
<td>CloudFormation組み込み関数。リソースの属性値（ARNなど）を取得する</td>
</tr>
<tr>
<td><strong>CAPABILITY_NAMED_IAM</strong></td>
<td>名前付きIAMリソースを作成する場合に必要な明示的な許可フラグ</td>
</tr>
<tr>
<td><strong>UserData</strong></td>
<td>EC2の初回起動時のみ自動実行されるシェルスクリプト</td>
</tr>
</tbody>
</table>
<hr>
<h2><span id="toc4">前提条件</span></h2>
<table>
<thead>
<tr>
<th>ツール</th>
<th>確認コマンド</th>
<th>最低バージョン目安</th>
</tr>
</thead>
<tbody>
<tr>
<td>AWS CLI v2</td>
<td><code>aws --version</code></td>
<td>2.x</td>
</tr>
<tr>
<td>Git</td>
<td><code>git --version</code></td>
<td>2.x</td>
</tr>
<tr>
<td>VSCode</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>
<p>AWS認証確認:</p>
<pre><code class="language-cmd">aws sts get-caller-identity</code></pre>
<p>アカウントIDが表示されれば認証設定済みです。</p>
<hr>
<h2><span id="toc5">template.yaml の全文</span></h2>
<p>以下が今回使用する <code>template.yaml</code> の全文です。プロジェクトフォルダ（<code>ec2-tomcat-web/</code>）直下に配置します。</p>
<blockquote>
<p><strong>⚠️ コピー前に確認</strong>: <code>Default: &#39;123.456.78.901/32&#39;</code> の箇所は<strong>ダミーIPです</strong>。このまま使うとスタック作成は成功しますが、SSHもブラウザもアクセスできません。<code>--parameters</code> でIPを上書きするか（推奨）、Defaultを自分のIPに書き換えてから使ってください。</p>
</blockquote>
<pre><code class="language-yaml">AWSTemplateFormatVersion: '2010-09-09'
Description: 'EC2 + Tomcat Application Server Hands-on (Phase 1-2)'

Parameters:
  KeyName:
    Type: String
    Default: 'my-ec2-tomcat-key'
    Description: Name of an existing EC2 KeyPair

  MyIP:
    Type: String
    Default: '123.456.78.901/32'
    Description: Your IP address to allow SSH and Tomcat access (CIDR format e.g. 203.0.113.1/32)

Resources:
  EC2Role:
    Type: AWS::IAM::Role
    Properties:
      RoleName: 'my-ec2-tomcat-role'
      AssumeRolePolicyDocument:
        Version: '2012-10-17'
        Statement:
          - Effect: Allow
            Principal:
              Service: ec2.amazonaws.com
            Action: 'sts:AssumeRole'
      ManagedPolicyArns:
        - arn:aws:iam::aws:policy/AmazonSSMManagedInstanceCore
      Tags:
        - Key: Name
          Value: 'my-ec2-tomcat-role'

  # Instance Profile: wrapper that attaches the IAM role to EC2
  EC2InstanceProfile:
    Type: AWS::IAM::InstanceProfile
    Properties:
      InstanceProfileName: 'my-ec2-tomcat-profile'
      Roles:
        - !Ref EC2Role

  # Security Group: allow SSH(22) and Tomcat(8080) from MyIP only
  EC2SecurityGroup:
    Type: AWS::EC2::SecurityGroup
    Properties:
      GroupDescription: 'my EC2 Tomcat hands-on SG'
      SecurityGroupIngress:
        - IpProtocol: tcp
          FromPort: 22
          ToPort: 22
          CidrIp: !Ref MyIP
          Description: SSH access from my IP
        - IpProtocol: tcp
          FromPort: 8080
          ToPort: 8080
          CidrIp: !Ref MyIP
          Description: Tomcat HTTP access from my IP
      Tags:
        - Key: Name
          Value: 'my-ec2-tomcat-sg'

  # EC2 Instance: Amazon Linux 2023 + Java 17 + Tomcat 10 (installed via UserData)
  EC2Instance:
    Type: AWS::EC2::Instance
    Properties:
      ImageId: '{{resolve:ssm:/aws/service/ami-amazon-linux-latest/al2023-ami-kernel-default-x86_64}}'
      InstanceType: t2.micro
      KeyName: !Ref KeyName
      SecurityGroupIds:
        - !Ref EC2SecurityGroup
      IamInstanceProfile: !Ref EC2InstanceProfile
      # UserData: shell script executed automatically on first boot
      UserData:
        Fn::Base64: |
          #!/bin/bash
          dnf update -y
          dnf install -y java-17-amazon-corretto

          useradd -m -d /opt/tomcat -U -s /bin/false tomcat

          TOMCAT_VERSION="10.1.25"
          cd /tmp
          wget -q "https://archive.apache.org/dist/tomcat/tomcat-10/v${TOMCAT_VERSION}/bin/apache-tomcat-${TOMCAT_VERSION}.tar.gz" \
            -O apache-tomcat.tar.gz
          tar xzf apache-tomcat.tar.gz
          mv "apache-tomcat-${TOMCAT_VERSION}" /opt/tomcat/latest
          chown -R tomcat:tomcat /opt/tomcat
          chmod -R u+x /opt/tomcat/latest/bin

          cat &gt; /etc/systemd/system/tomcat.service &lt;&lt; 'SVCEOF'
          [Unit]
          Description=Apache Tomcat Web Application Container
          After=network.target

          [Service]
          Type=forking
          User=tomcat
          Group=tomcat
          Environment="JAVA_HOME=/usr/lib/jvm/java-17-amazon-corretto"
          Environment="CATALINA_HOME=/opt/tomcat/latest"
          Environment="CATALINA_BASE=/opt/tomcat/latest"
          Environment="CATALINA_PID=/opt/tomcat/latest/temp/tomcat.pid"
          Environment="JAVA_OPTS=-Xms256m -Xmx512m"
          ExecStart=/opt/tomcat/latest/bin/startup.sh
          ExecStop=/opt/tomcat/latest/bin/shutdown.sh
          Restart=on-failure

          [Install]
          WantedBy=multi-user.target
          SVCEOF

          systemctl daemon-reload
          systemctl enable tomcat
          systemctl start tomcat

          cat &gt; /opt/tomcat/latest/webapps/ROOT/index.jsp &lt;&lt; 'JSPEOF'
          &lt;%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%&gt;
          &lt;!DOCTYPE html&gt;
          &lt;html&gt;
          &lt;head&gt;&lt;meta charset="UTF-8"&gt;&lt;title&gt;Tomcat on EC2&lt;/title&gt;&lt;/head&gt;
          &lt;body&gt;
          &lt;h1&gt;Hello from Tomcat on Amazon Linux 2023!&lt;/h1&gt;
          &lt;p&gt;Java Version: &lt;%= System.getProperty("java.version") %&gt;&lt;/p&gt;
          &lt;p&gt;Tomcat Version: &lt;%= application.getServerInfo() %&gt;&lt;/p&gt;
          &lt;/body&gt;
          &lt;/html&gt;
          JSPEOF
          chown tomcat:tomcat /opt/tomcat/latest/webapps/ROOT/index.jsp
      Tags:
        - Key: Name
          Value: 'my-ec2-tomcat-instance'

Outputs:
  InstanceId:
    Description: EC2 Instance ID
    Value: !Ref EC2Instance

  PublicIP:
    Description: Public IP Address
    Value: !GetAtt EC2Instance.PublicIp

  TomcatURL:
    Description: Tomcat URL (open in browser)
    Value: !Sub 'http://${EC2Instance.PublicIp}:8080'

  SSHCommand:
    Description: SSH command (update the .pem path as needed)
    Value: !Sub 'ssh -i C:\Users\username\.ssh\${KeyName}.pem ec2-user@${EC2Instance.PublicIp}'</code></pre>
<p><strong><code>!Ref</code> と <code>!Sub</code> の使い分け:</strong></p>
<table>
<thead>
<tr>
<th>関数</th>
<th>意味</th>
<th>例</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>!Ref パラメータ名</code></td>
<td>パラメータの値を参照する</td>
<td><code>!Ref MyIP</code> → <code>203.0.113.1/32</code></td>
</tr>
<tr>
<td><code>!Ref リソースID</code></td>
<td>リソースのIDを参照する</td>
<td><code>!Ref EC2SecurityGroup</code> → <code>sg-xxxxx</code></td>
</tr>
<tr>
<td><code>!Sub &#39;文字列&#39;</code></td>
<td>文字列内の <code>${変数}</code> を展開する</td>
<td><code>!Sub &#39;http://${EC2Instance.PublicIp}:8080&#39;</code> → <code>http://x.x.x.x:8080</code></td>
</tr>
<tr>
<td><code>!GetAtt リソース.属性</code></td>
<td>リソースの属性値を取得する</td>
<td><code>!GetAtt EC2Instance.PublicIp</code> → IPアドレス</td>
</tr>
</tbody>
</table>
<p><strong>Apache版との主な違い（template.yaml）:</strong></p>
<table>
<thead>
<tr>
<th>項目</th>
<th>Apache版</th>
<th>Tomcat版（今回）</th>
</tr>
</thead>
<tbody>
<tr>
<td>セキュリティグループ</td>
<td>SSH(22) + HTTP(80)</td>
<td>SSH(22) + TCP(8080)</td>
</tr>
<tr>
<td>UserData</td>
<td>httpd のインストール</td>
<td>Java17 + Tomcat10 のインストール</td>
</tr>
<tr>
<td>Outputs</td>
<td>WebsiteURL（port 80）</td>
<td>TomcatURL（port 8080）</td>
</tr>
</tbody>
</table>
<p><strong>構築されるリソースと論理ID:</strong></p>
<table>
<thead>
<tr>
<th>リソース</th>
<th>template.yaml上の論理ID</th>
</tr>
</thead>
<tbody>
<tr>
<td>IAMロール</td>
<td><code>EC2Role</code></td>
</tr>
<tr>
<td>インスタンスプロファイル</td>
<td><code>EC2InstanceProfile</code></td>
</tr>
<tr>
<td>セキュリティグループ</td>
<td><code>EC2SecurityGroup</code></td>
</tr>
<tr>
<td>EC2インスタンス</td>
<td><code>EC2Instance</code></td>
</tr>
</tbody>
</table>
<hr>
<h2><span id="toc6">作業順序</span></h2>
<pre><code class="language-plaintext">⓪ 自分のIPアドレスを確認する（重要）
      ↓
① キーペアを作成する（コンソールで実施）
      ↓
② プロジェクトフォルダに移動する
      ↓
③ スタックを作成する（aws cloudformation create-stack）
      ↓
④ 作成状況・Outputsを確認する
      ↓
⑤ 動作確認（ブラウザ・SSH）
      ↓
⑥ スタックを削除する（aws cloudformation delete-stack）</code></pre>
<hr>
<h2><span id="toc7">【重要】⓪ 自分のIPアドレスを確認する</span></h2>
<p>セキュリティグループで自分のIPのみを許可するために、<strong>正確なIPアドレス</strong>を事前に確認します。</p>
<blockquote>
<p><strong>注意</strong>: <code>curl https://checkip.amazonaws.com</code> で表示されるIPと、EC2への実際の接続元IPが<strong>一致しない場合</strong>があります（ISPやプロキシの経路の違いによる）。</p>
</blockquote>
<h3><span id="toc8">方法A: ルーター管理画面で確認（推奨）</span></h3>
<ol>
<li>ブラウザで以下のURLにアクセスします
<pre><code class="language-plaintext">http://192.168.0.1  または  http://192.168.1.1</code></pre>
</li>
<li>「ネットワークマップ」または「インターネット」項目を開く</li>
<li>**「インターネットIPアドレス」または「WAN IPアドレス」**の値を控えます</li>
</ol>
<h3><span id="toc9">方法B: コマンドで確認</span></h3>
<pre><code class="language-cmd">curl https://checkip.amazonaws.com</code></pre>
<p><strong>控えておく情報</strong>: 自分のIPアドレス（例: <code>203.0.113.1</code>）</p>
<hr>
<h2><span id="toc10">① キーペアの作成（コンソールで実施）</span></h2>
<p>キーペアのみコンソールで作成します。CloudFormationではキーペアのダウンロードが行えないためです。</p>
<p><strong>AWSコンソール → EC2 → キーペア → 「キーペアを作成」</strong></p>
<table>
<thead>
<tr>
<th>設定項目</th>
<th>値</th>
</tr>
</thead>
<tbody>
<tr>
<td>名前</td>
<td><code>my-ec2-tomcat-key</code></td>
</tr>
<tr>
<td>キーペアのタイプ</td>
<td><strong>RSA</strong></td>
</tr>
<tr>
<td>プライベートキーファイル形式</td>
<td><strong>.pem</strong></td>
</tr>
</tbody>
</table>
<p>ダウンロードされた <code>my-ec2-tomcat-key.pem</code> を保存します。</p>
<pre><code class="language-plaintext">C:\Users\ユーザー名\.ssh\my-ec2-tomcat-key.pem</code></pre>
<blockquote>
<p><strong>前回のキーペアの流用について</strong>: Apacheハンズオンで作成した <code>my-ec2-apache-key</code> を流用する場合、この手順はスキップし、後続コマンドの <code>KeyName</code> の値を <code>my-ec2-apache-key</code> に変更します。</p>
</blockquote>
<hr>
<h2><span id="toc11">② プロジェクトフォルダに移動する</span></h2>
<p>VSCodeのターミナル（CMD）を開き、プロジェクトフォルダに移動します。</p>
<pre><code class="language-cmd">cd C:\my-aws\aws-learning-projects\ec2-tomcat-web</code></pre>
<p><code>template.yaml</code> があることを確認します。</p>
<pre><code class="language-cmd">dir template.yaml</code></pre>
<hr>
<h2><span id="toc12">③ スタックの作成</span></h2>
<p>以下のコマンドを実行します。<code>203.0.113.1</code> は⓪で確認した自分のIPアドレスに置き換えてください。</p>
<pre><code class="language-cmd">aws cloudformation create-stack ^
  --stack-name my-ec2-tomcat-stack ^
  --template-body file://template.yaml ^
  --region ap-northeast-1 ^
  --capabilities CAPABILITY_NAMED_IAM ^
  --parameters ^
    ParameterKey=KeyName,ParameterValue=my-ec2-tomcat-key ^
    ParameterKey=MyIP,ParameterValue=203.0.113.1/32</code></pre>
<p><strong>各オプションの説明:</strong></p>
<table>
<thead>
<tr>
<th>オプション</th>
<th>意味</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>--stack-name my-ec2-tomcat-stack</code></td>
<td>スタック名（英字始まり）</td>
</tr>
<tr>
<td><code>--template-body file://template.yaml</code></td>
<td>使用するテンプレートファイル</td>
</tr>
<tr>
<td><code>--region ap-northeast-1</code></td>
<td>デプロイ先リージョン（東京）</td>
</tr>
<tr>
<td><code>--capabilities CAPABILITY_NAMED_IAM</code></td>
<td>名前付きIAMロール作成の明示的な許可</td>
</tr>
<tr>
<td><code>--parameters ...</code></td>
<td>テンプレートのParametersに渡す値</td>
</tr>
</tbody>
</table>
<blockquote>
<p><strong><code>^</code> について</strong>: Windowsのコマンドプロンプトで長いコマンドを複数行に分けるための改行エスケープ文字です。1行で書いても動作します。</p>
</blockquote>
<blockquote>
<p><strong>template.yamlのコメントは英語のみ</strong>: 日本語コメントが含まれているとWindows上のAWS CLIがエンコードエラーを起こすため、コメントはすべて英語で記述しています。</p>
</blockquote>
<p>成功すると以下のようなStackIdが表示されます。</p>
<pre><code class="language-json">{
    "StackId": "arn:aws:cloudformation:ap-northeast-1:123456789012:stack/my-ec2-tomcat-stack/xxxxx"
}</code></pre>
<p><!-- ![スタック作成コマンドの実行結果](images/cfn-create-stack-cmd.jpg) --></p>
<hr>
<h2><span id="toc13">④ 作成完了・Outputsの確認</span></h2>
<p>スタック作成は完了まで<strong>約3〜5分</strong>かかります。ただし、Tomcatのインストール（UserData）はさらに<strong>5〜10分</strong>かかるため、スタック完了後もすぐにブラウザでアクセスできないことがあります。</p>
<h3><span id="toc14">作成状況の確認</span></h3>
<pre><code class="language-cmd">aws cloudformation describe-stacks ^
  --stack-name my-ec2-tomcat-stack ^
  --query "Stacks[0].StackStatus" ^
  --output text</code></pre>
<table>
<thead>
<tr>
<th>ステータス</th>
<th>意味</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>CREATE_IN_PROGRESS</code></td>
<td>作成中（しばらく待つ）</td>
</tr>
<tr>
<td><code>CREATE_COMPLETE</code></td>
<td>作成完了</td>
</tr>
<tr>
<td><code>CREATE_FAILED</code></td>
<td>作成失敗（トラブルシューティングを参照）</td>
</tr>
<tr>
<td><code>ROLLBACK_COMPLETE</code></td>
<td>失敗してロールバック完了（リソースは作成されていない）</td>
</tr>
</tbody>
</table>
<h3><span id="toc15">Outputs（接続情報）の確認</span></h3>
<p><code>CREATE_COMPLETE</code> になったら以下を実行します。</p>
<pre><code class="language-cmd">aws cloudformation describe-stacks ^
  --stack-name my-ec2-tomcat-stack ^
  --query "Stacks[0].Outputs" ^
  --output table</code></pre>
<p>以下のような出力が表示されます。</p>
<pre><code class="language-plaintext">------------------------------------------------------------------------------------------
|                                    DescribeStacks                                      |
+----------------+-----------------------------------------------------------------------+
|  OutputKey     |  OutputValue                                                          |
+----------------+-----------------------------------------------------------------------+
|  InstanceId    |  i-0123456789abcdef0                                                 |
|  PublicIP      |  x.x.x.x                                                             |
|  TomcatURL     |  http://x.x.x.x:8080                                                 |
|  SSHCommand    |  ssh -i C:\Users\...\.ssh\my-ec2-tomcat-key.pem ec2-user@x.x.x.x     |
+----------------+-----------------------------------------------------------------------+</code></pre>
<p><strong>控えておく情報</strong>: <code>PublicIP</code> と <code>TomcatURL</code></p>
<p><!-- ![Outputs確認コマンドの実行結果](images/cfn-outputs-table.jpg) --></p>
<hr>
<h2><span id="toc16">⑤ 動作確認</span></h2>
<h3><span id="toc17">ブラウザで確認</span></h3>
<p>Outputsに表示された <code>TomcatURL</code>（<code>http://x.x.x.x:8080</code>）をブラウザで開きます。</p>
<pre><code class="language-plaintext">Hello from Tomcat on Amazon Linux 2023!
Java Version: 17.x.x
Tomcat Version: Apache Tomcat/10.1.25</code></pre>
<p>が表示されれば成功です。</p>
<blockquote>
<p><strong>表示されない場合</strong>: UserDataのインストール完了まで5〜10分かかります。スタックが <code>CREATE_COMPLETE</code> になった後も少し待ってからアクセスしてください。</p>
</blockquote>
<p><!-- ![ブラウザでのTomcat動作確認](images/tomcat-web-browser.jpg) --></p>
<h3><span id="toc18">SSHで接続して確認</span></h3>
<p>Outputsに表示された <code>SSHCommand</code> を実行します（パスは実際のパスに修正します）。</p>
<pre><code class="language-cmd">ssh -i C:\Users\ユーザー名\.ssh\my-ec2-tomcat-key.pem ec2-user@（PublicIP）</code></pre>
<p>初回接続時の確認には <code>yes</code> を入力します。</p>
<pre><code class="language-bash"># Javaのバージョン確認
java -version

# Tomcatサービスの状態確認（active (running) と表示されれば正常）
sudo systemctl status tomcat

# TomcatのログでERRORがないか確認
sudo tail -50 /opt/tomcat/latest/logs/catalina.out

# UserDataの実行ログ確認（インストール状況を詳細に確認できる）
sudo cat /var/log/cloud-init-output.log

# 8080番ポートのListen確認
sudo ss -tlnp | grep :8080

exit</code></pre>
<h3><span id="toc19">【接続できない場合】真のIPアドレスを確認する</span></h3>
<p><code>curl</code> で確認したIPを設定したが接続できない場合、実際の接続元IPが異なる可能性があります。</p>
<p><strong>セキュリティグループIDを取得:</strong></p>
<pre><code class="language-cmd">aws cloudformation describe-stack-resources ^
  --stack-name my-ec2-tomcat-stack ^
  --query "StackResources[?ResourceType=='AWS::EC2::SecurityGroup'].PhysicalResourceId" ^
  --output text</code></pre>
<p><strong>SSH全開放（一時的・テスト用）:</strong></p>
<pre><code class="language-cmd">aws ec2 authorize-security-group-ingress ^
  --group-id sg-XXXXXXXXX ^
  --protocol tcp ^
  --port 22 ^
  --cidr 0.0.0.0/0 ^
  --region ap-northeast-1</code></pre>
<p>SSH接続して真のIPを確認します。</p>
<pre><code class="language-bash">echo $SSH_CLIENT
# 出力例: 203.0.113.1 17508 22
# 先頭の値が真の接続元IP
exit</code></pre>
<p>確認後、全開放を削除して真のIPで制限し直します。</p>
<pre><code class="language-cmd">rem 全開放を削除
aws ec2 revoke-security-group-ingress ^
  --group-id sg-XXXXXXXXX ^
  --protocol tcp ^
  --port 22 ^
  --cidr 0.0.0.0/0 ^
  --region ap-northeast-1

rem 真のIPで再制限
aws ec2 authorize-security-group-ingress ^
  --group-id sg-XXXXXXXXX ^
  --protocol tcp ^
  --port 22 ^
  --cidr 真のIP/32 ^
  --region ap-northeast-1</code></pre>
<hr>
<h2><span id="toc20">⑥ スタックの削除</span></h2>
<p><strong>課金を止めるために、ハンズオン完了後は必ず削除してください。</strong></p>
<p>CloudFormationはスタック削除で全リソースを一括削除できます。手動でリソースを1つ1つ削除する必要はありません。</p>
<pre><code class="language-cmd">aws cloudformation delete-stack ^
  --stack-name my-ec2-tomcat-stack ^
  --region ap-northeast-1</code></pre>
<p>削除の進行状況を確認します（完了まで約3〜5分）。</p>
<pre><code class="language-cmd">aws cloudformation describe-stacks ^
  --stack-name my-ec2-tomcat-stack ^
  --query "Stacks[0].StackStatus" ^
  --output text</code></pre>
<table>
<thead>
<tr>
<th>ステータス</th>
<th>意味</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>DELETE_IN_PROGRESS</code></td>
<td>削除中（しばらく待つ）</td>
</tr>
<tr>
<td><code>DELETE_FAILED</code></td>
<td>削除失敗（トラブルシューティングを参照）</td>
</tr>
</tbody>
</table>
<p>削除完了の確認（以下のエラーが表示されれば削除完了）。</p>
<pre><code class="language-cmd">aws cloudformation describe-stacks ^
  --stack-name my-ec2-tomcat-stack ^
  --region ap-northeast-1</code></pre>
<pre><code class="language-plaintext">An error occurred (ValidationError) when calling the DescribeStacks operation:
Stack with id my-ec2-tomcat-stack does not exist</code></pre>
<p>このメッセージが表示されれば削除完了です。キーペアはCloudFormationで管理していないため、手動で削除します。</p>
<p><strong>EC2 → キーペア → <code>my-ec2-tomcat-key</code> を選択 → 「アクション」→「削除」</strong></p>
<p>ローカルの <code>.pem</code> ファイルも削除します。</p>
<hr>
<h2><span id="toc21">コンソール版との比較</span></h2>
<p>コンソール版でIAMロール・セキュリティグループ・EC2を手動作成した手順が、CloudFormationではすべて <code>template.yaml</code> に定義されています。</p>
<table>
<thead>
<tr>
<th>CFnの記述</th>
<th>コンソールでやること</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>EC2Role</code>（IAMロール定義）</td>
<td>IAM → ロールを作成（AmazonSSMManagedInstanceCore付与）</td>
</tr>
<tr>
<td><code>EC2SecurityGroup</code>（SGルール定義）</td>
<td>EC2 → セキュリティグループを作成（SSH/TCP8080各ルール追加）</td>
</tr>
<tr>
<td><code>EC2Instance</code>（UserData含む）</td>
<td>EC2 → インスタンスを起動（UserData貼り付け・キーペア選択）</td>
</tr>
<tr>
<td><code>--parameters MyIP=...</code></td>
<td>セキュリティグループのインバウンドルールに自分のIPを入力</td>
</tr>
<tr>
<td><code>delete-stack</code></td>
<td>インスタンス終了 → SG削除 → IAMロール削除（順番が重要）</td>
</tr>
</tbody>
</table>
<blockquote>
<p><strong>コンソール版で詰まりやすいポイント:</strong><br />UserDataのTomcatインストールが5〜10分かかるため、コンソール版では「インスタンスが動いているのにアクセスできない」状態が続きます。<br />CloudFormationでも待ち時間は同じですが、デプロイ自体はコマンド1本で完了します。</p>
</blockquote>
<hr>
<h2><span id="toc22">トラブルシューティング</span></h2>
<table>
<thead>
<tr>
<th>症状</th>
<th>原因</th>
<th>対処</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>CREATE_FAILED</code> になる</td>
<td>キーペアが存在しない</td>
<td>コンソールでキーペアを作成し、<code>--parameters KeyName=...</code> の値を確認</td>
</tr>
<tr>
<td><code>CREATE_FAILED</code> になる</td>
<td><code>CAPABILITY_NAMED_IAM</code> が不足</td>
<td>コマンドに <code>--capabilities CAPABILITY_NAMED_IAM</code> が含まれているか確認</td>
</tr>
<tr>
<td><code>stackName failed to satisfy regular expression pattern</code></td>
<td>スタック名が数字始まり</td>
<td>CloudFormationのスタック名は<strong>英字で始まる</strong>必要がある</td>
</tr>
<tr>
<td><code>Unable to load paramfile, text contents could not be decoded</code></td>
<td>template.yaml に日本語が含まれている</td>
<td>template.yaml のコメントを<strong>すべて英語</strong>で記述する（Windows環境の既知の問題）</td>
</tr>
<tr>
<td>ブラウザで8080に接続できない</td>
<td>UserDataのインストールが未完了</td>
<td>スタック完了後5〜10分待つ。SSHで <code>sudo cat /var/log/cloud-init-output.log</code> を確認</td>
</tr>
<tr>
<td>Tomcatは起動しているがJSPが動かない</td>
<td>index.jspがTomcat起動後に配置されなかった</td>
<td><code>sudo systemctl restart tomcat</code> でTomcatを再起動する</td>
</tr>
<tr>
<td>SSH接続タイムアウト</td>
<td>セキュリティグループのIP設定誤り</td>
<td>SGのインバウンドルールでSSH(22)のIPを確認</td>
</tr>
<tr>
<td><code>DELETE_FAILED</code> になる</td>
<td>手動でリソースを変更したためCFnが管理できない</td>
<td>コンソールで該当リソースを確認して手動削除後、<code>delete-stack</code> を再実行</td>
</tr>
<tr>
<td><code>ValidationError: Template format error</code></td>
<td>template.yamlのインデントが崩れている</td>
<td>YAMLはインデントが厳格。スペース2つ単位でインデントを確認する</td>
</tr>
</tbody>
</table>
<hr>
<h2><span id="toc23">まとめ</span></h2>
<p>今回のハンズオンで実現できたこと：</p>
<table>
<thead>
<tr>
<th>確認項目</th>
<th>内容</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>IaCの体験</strong></td>
<td>template.yaml 1ファイルにIAMロール・SG・EC2をコードで定義</td>
</tr>
<tr>
<td><strong>一括デプロイ</strong></td>
<td><code>create-stack</code> コマンド1本でコンソール版と同じ構成を5〜10分で構築</td>
</tr>
<tr>
<td><strong>Outputs活用</strong></td>
<td>デプロイ後にIPアドレス・TomcatURL・SSHコマンドを <code>describe-stacks</code> で自動取得</td>
</tr>
<tr>
<td><strong>一括削除</strong></td>
<td><code>delete-stack</code> 1本でリソースの依存関係を自動解決して全削除</td>
</tr>
</tbody>
</table>
<h3><span id="toc24">CloudFormationのメリットを実感できたポイント</span></h3>
<ul>
<li>コンソール版では20〜30分かかった作業がコマンド1本（5〜10分）で完了した</li>
<li><code>delete-stack</code> で依存関係を気にせず全リソースを一括削除できた</li>
<li><code>template.yaml</code> をGitで管理することで、環境構成の変更履歴が残せる</li>
</ul>
<hr>
<h2><span id="toc25">コンソール版と比較してみる</span></h2>
<p>CloudFormationが裏で何をやっているか、同じ構成をAWSコンソールのみで構築する手順をまとめました。コンソール版ではキーペア・IAMロール・セキュリティグループ・EC2を依存関係順に手動で作成する必要があり、各リソースの役割と繋がりが視覚的に理解できます。</p>
<p><a href="https://caymezon.com/aws-handson-console-ec2-tomcat/">EC2サーバ構築ハンズオン：AWSコンソールでTomcatを構築する手順</a></p>
<hr>
<h2><span id="toc26">関連記事</span></h2>
<p><!-- <a rel="nofollow" href="//af.moshimo.com/af/c/click?a_id=1384942&p_id=170&pc_id=185&pl_id=4062&url=https%3A%2F%2Fwww.amazon.co.jp%2Fs%3Fk%3D%25E6%259C%25AC%2BAWS%2B%25E9%2596%258B%25E7%2599%25BA%26__mk_ja_JP%3D%25E3%2582%25AB%25E3%2582%25BF%25E3%2582%25AB%25E3%2583%258A%26crid%3D1DE63UBHFOR4K%26sprefix%3D%25E6%259C%25AC%2Baws%2B%25E9%2596%258B%25E7%2599%25BA%252Caps%252C167%26ref%3Dnb_sb_noss" referrerpolicy="no-referrer-when-downgrade" attributionsrc>Amazon検索[本 AWS 開発]</a><img decoding="async" src="//i.moshimo.com/af/i/impression?a_id=1384942&p_id=170&pc_id=185&pl_id=4062" width="1" height="1" style="border:none;" alt="" loading="lazy"> --></p>
<p><!-- <!-- START MoshimoAffiliateEasyLink --><script type="text/javascript">(function(b,c,f,g,a,d,e){b.MoshimoAffiliateObject=a;b[a]=b[a]||function(){arguments.currentScript=c.currentScript||c.scripts[c.scripts.length-2];(b[a].q=b[a].q||[]).push(arguments)};c.getElementById(a)||(d=c.createElement(f),d.src=g,d.id=a,e=c.getElementsByTagName("body")[0],e.appendChild(d))})(window,document,"script","//dn.msmstatic.com/site/cardlink/bundle.js?20220329","msmaflink");msmaflink({"n":"AWS運用入門 改訂第2版 押さえておきたいAWSの基本と運用ノウハウ [AWS深掘りガイド]","b":"SBクリエイティブ","t":"","d":"https:\/\/m.media-amazon.com","c_p":"\/images\/I","p":["\/51AAOubymTL._SL500_.jpg","\/51VMG6YKHdL._SL500_.jpg","\/41EdPB8azAL._SL500_.jpg","\/41v2JFE-9jL._SL500_.jpg","\/41FEEqR-yDL._SL500_.jpg","\/41JfZAdnTPL._SL500_.jpg","\/41vGK0czQrL._SL500_.jpg","\/41-SnYtz2aL._SL500_.jpg","\/41sPrV5fi3L._SL500_.jpg","\/41p7JtvYJ1L._SL500_.jpg","\/4169GVNTs8L._SL500_.jpg","\/41BPI5HP3zL._SL500_.jpg","\/41QOyk60CYL._SL500_.jpg","\/41APjk6FphL._SL500_.jpg","\/41ezKUu7VRL._SL500_.jpg","\/41A1n3K+r5L._SL500_.jpg","\/41aY2T8lEOL._SL500_.jpg","\/419Ca1V6HZL._SL500_.jpg","\/41zQkYyLPzL._SL500_.jpg","\/41YpHcyxiTL._SL500_.jpg","\/41-tKN5mt6L._SL500_.jpg","\/419Mv6m55IL._SL500_.jpg"],"u":{"u":"https:\/\/www.amazon.co.jp\/dp\/4815631085","t":"amazon","r_v":""},"v":"2.1","b_l":[{"id":1,"u_tx":"Amazonで見る","u_bc":"#f79256","u_url":"https:\/\/www.amazon.co.jp\/dp\/4815631085","a_id":1384942,"p_id":170,"pl_id":27060,"pc_id":185,"s_n":"amazon","u_so":1},{"id":2,"u_tx":"楽天市場で見る","u_bc":"#f76956","u_url":"https:\/\/search.rakuten.co.jp\/search\/mall\/AWS%E9%81%8B%E7%94%A8%E5%85%A5%E9%96%80%20%E6%94%B9%E8%A8%82%E7%AC%AC2%E7%89%88%20%E6%8A%BC%E3%81%95%E3%81%88%E3%81%A6%E3%81%8A%E3%81%8D%E3%81%9F%E3%81%84AWS%E3%81%AE%E5%9F%BA%E6%9C%AC%E3%81%A8%E9%81%8B%E7%94%A8%E3%83%8E%E3%82%A6%E3%83%8F%E3%82%A6%20%5BAWS%E6%B7%B1%E6%8E%98%E3%82%8A%E3%82%AC%E3%82%A4%E3%83%89%5D\/","a_id":1384917,"p_id":54,"pl_id":27059,"pc_id":54,"s_n":"rakuten","u_so":2},{"id":3,"u_tx":"Yahoo!ショッピングで見る","u_bc":"#66a7ff","u_url":"https:\/\/shopping.yahoo.co.jp\/search?first=1\u0026p=AWS%E9%81%8B%E7%94%A8%E5%85%A5%E9%96%80%20%E6%94%B9%E8%A8%82%E7%AC%AC2%E7%89%88%20%E6%8A%BC%E3%81%95%E3%81%88%E3%81%A6%E3%81%8A%E3%81%8D%E3%81%9F%E3%81%84AWS%E3%81%AE%E5%9F%BA%E6%9C%AC%E3%81%A8%E9%81%8B%E7%94%A8%E3%83%8E%E3%82%A6%E3%83%8F%E3%82%A6%20%5BAWS%E6%B7%B1%E6%8E%98%E3%82%8A%E3%82%AC%E3%82%A4%E3%83%89%5D","a_id":1466950,"p_id":1225,"pl_id":27061,"pc_id":1925,"s_n":"yahoo","u_so":3}],"eid":"E8MM1","s":"s"});</script></p>
<div id="msmaflink-E8MM1">リンク</div>
<p><!-- MoshimoAffiliateEasyLink END --> --></p><p>The post <a href="https://caymezon.com/aws-handson-cloudformation-ec2-tomcat/">EC2サーバ構築をIaC化：CloudFormationでEC2 Tomcatを自動デプロイする手順【コンソール版との比較付き】</a> first appeared on <a href="https://caymezon.com">CayTech Lab</a>.</p>]]></content:encoded>
					
					<wfw:commentRss>https://caymezon.com/aws-handson-cloudformation-ec2-tomcat/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
	</channel>
</rss>
