素敵なサムシングを独断と偏見で一方的に紹介するブログ(´・ω・`)

投稿日: 2018年3月18日
最終更新日:

【お便利AWS】S3バケットで静的サイトホスティングをしてみよう

YouTubeも見てね♪

ねこじゃすり

created by Rinker
PEPPY(ペピイ)
¥3,850 (2025/01/05 12:56:12時点 Amazon調べ-詳細)

猫を魅了する魔法の装備品!

[ノースフェイス] THE NORTH FACE メンズ アウター マウンテンライトジャケット

created by Rinker
THE NORTH FACE(ザノースフェイス)
¥33,000 (2025/01/05 13:22:08時点 Amazon調べ-詳細)

防水暴風で耐久性抜群なので旅行で大活躍です!

モンスターエナジー 355ml×24本 [エナジードリンク]

created by Rinker
モンスター
¥4,718 (2025/01/05 12:33:40時点 Amazon調べ-詳細)

脳を活性化させるにはこれ!

Bauhutte ( バウヒュッテ ) 昇降式 L字デスク ブラック BHD-670H-BK

created by Rinker
Bauhutte(バウヒュッテ)
¥15,855 (2025/01/05 12:09:12時点 Amazon調べ-詳細)

メインデスクの横に置くのにぴったりなおしゃれな可動式ラック!

BANDAI SPIRITS ULTIMAGEAR 遊戯王 千年パズル 1/1スケール

created by Rinker
BANDAI SPIRITS(バンダイ スピリッツ)
¥10,429 (2025/01/05 12:09:13時点 Amazon調べ-詳細)

もう一人の僕を呼び覚ませ!!

MOFT X 【新型 ミニマム版】 iPhone対応 スマホスタンド

Amazon一番人気のスマホスタンド!カード類も収納出来てかさ張らないのでオススメです!

サンディスク microSD 128GB

スマホからSwitchまで使える大容量MicroSDカード!

静的サイトを公開したい

サーバー借りるのは負担

WordPressではなく、単純なHTML/JS/CSSのみ静的なサイト(LP等)を作って公開したいけど、そのためだけにサーバーを借りるのは勿体ない!と思ってらっしゃる方は少なくないと思います。

サーバーを借りると地味に月額費用がかさんでいくんですよね。。。orz

Githubでソース管理している場合はGithubPagesを利用すれば良いのですが、その場合publicリポジトリであることが前提になってしまうので、privateリポジトリで運用している場合は選択肢に入れることが不可能になってしまいます。

また、サーバーを借りるとなると、インフラの初期設定ネットワーク整備等を行う必要があるので、インフラの知識が無いコーダーさんだとちょっと敷居が高くなってしまいます。

そんな時はAWSのS3

そんな時にぴったりなサービスがAWSS3です。

S3とはAWSのストレージサービスの一つで、正式名称はAmazon Simple Storage Serviceと言います。

様々なファイルをオンラインストレージ上で管理することができ、静的コンテンツをおくことでWebページとして利用することが可能です。

今回はS3を使ったシンプルなWebページの公開方法についてご紹介します。

手順

前提

Point
  • AWSアカウント取得済み

バケットの作成

AWSにログインしたら、サービスメニューをクリックし、ストレージカテゴリS3を選択します。

次の画面では、バケットを作成ボタンをクリックします。

すると、ダイアログが表示されるので、任意のバケット名を入力し作成ボタンをクリックしてください。

これでS3バケットの作成は完了です。

静的コンテンツを配置

では、実際にファイルをS3バケット内に配置してみましょう。
今回は表示確認さえ出来れば良いので、コチラテンプレートをダウンロードし、そのまま配置してみます。

対象のバケットを選択し、ファイルをドラッグ&ドロップします。
するとアップロードするファイルの確認ダイアログが表示されるので、アップロードボタンをクリックします。

これでアップロード作業は完了です。

確認

では、実際にindex.htmlの表示を確認してみましょう。
まずはindex.htmlを選択します。

すると、index.htmlファイルの詳細ページが表示されるので、下部にあるリンクURLをクリックしてみましょう。

あれ、表示されない。。。

Webサイトホスティング関連の設定

上記エラーの原因は、アップロードしたファイルがデフォルトでは非公開で設定されるため、Webサイト用として公開するための設定をバケットに対して行う必要があります。

まずは、バケットメニュープロパティタブをクリックし、Static website hostingを選択します。

すると、設定ダイアログが表示されるので、

Point
  • このバケットを利用してウェブサイトをホストするにチェック
  • インデックスドキュメントにindex.htmlを入力

を設定の上、保存ボタンをクリックします。
※このエンドポイントがブラウザからアクセスするURLになるので控えておきましょう

これでWebサイトホスティングの設定は完了です。

バケットポリシーの設定

次にバケットポリシーの設定を行います。
こちらではバケットにアップロードしたファイルの閲覧権限を設定します。

バケットメニューアクセス権限タブを選択し、バケットポリシーボタンをクリックします。
するとバケットポリシーを入力するエリアが表示されるので、以下のコードを参考に、対象のバケット名を編集した内容を入力し、保存ボタンをクリックします。

これで準備は完了です。

確認

では、先ほど控えたエンドポイントにブラウザからアクセスしてみてください。

正常にHTML/CSS/JavaScriptが読み込まれて表示されていますね♩

終わりに

いかがだったでしょうか?

AWSのアカウント情報さえ持っていれば、簡単にWebページを公開することが出来ました。

しかし、今のままだとドメインがAWSのものになってしまっているので、CloudFrontを利用するか、Nginx等のプロキシサーバーを挟んで表示するなどして、調整してみてください♩

CATEGORIES & TAGS

IT