カテゴリー
サブドメイン付きURLで静的なWebサイトをAWS S3/CloudFront(とCloudFront Functions)/Route53で作成する
※ 当ページには【広告/PR】を含む場合があります。
2021/03/10
2022/02/03
サブドメイン付きのウェブサイト?
www.yahoo.co.jp(メインのドメイン)
travel.yahoo.co.jp
finance.yahoo.co.jp
weather.yahoo.co.jp
auctions.yahoo.co.jp
shopping.yahoo.co.jp
....
yahoo.co.jp
【通常CloudFront版・作業①】S3でHtmlファイル等を準備
バケットの作成
geek.tacoskingdom.com
data:image/s3,"s3://crabby-images/8d7af/8d7afb52392608a282acbee6cede81c9ba4b248f" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
[バケットを作成]
data:image/s3,"s3://crabby-images/e20ee/e20ee741cf9ed9a356b8475fcf9baf1997c9ba5e" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
index.html
<!doctype html>
<html lang="jp">
<head>
<meta charset="utf-8">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta http-equiv="Content-Style-Type" content="text/css; charset=UTF-8">
<meta http-equiv="Content-Script-Type" content="text/javascript; charset=UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=Edge">
<base href="/">
<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
<h1>404 not found</h1>
</body>
</html>
data:image/s3,"s3://crabby-images/4e074/4e074aa2265353916c1ccdc3a7ed1acb0aa93eb4" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
ポリシーの付与
[アクセス許可]
ブロックパブリックアクセス(バケット設定)
data:image/s3,"s3://crabby-images/2141e/2141e4075aeadd84ccda89362780d941461d5820" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
バケットポリシー
s3:GetObject
ARN値
geek.tacoskingdom.com
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Public Policy #1",
"Effect": "Allow",
"Principal": "*",
"Action": "s3:GetObject",
"Resource": "arn:aws:s3:::geek.tacoskingdom.com/*"
}
]
}
【通常CloudFront版・作業②】CloudFrontを設定する
AWS Certificate Manager
data:image/s3,"s3://crabby-images/398e9/398e927c31f5cde9a1c13a070f0c96e0beead188" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
Create Distribution
geek.tacoskingdom.com
Default Root Object
index.html
[Create Distribution]
in Progress
data:image/s3,"s3://crabby-images/e6dad/e6dad45c2b3d0cfeb4fe13b9b442efa0718e6eef" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
S3バケットポリシーの修正
Grant Read Permissions on Bucket
Yes, Update Bucket Policy
Sid:2
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Public Policy #1",
"Effect": "Allow",
"Principal": "*",
"Action": "s3:GetObject",
"Resource": "arn:aws:s3:::geek.tacoskingdom.com/*"
},
{
"Sid": "2",
"Effect": "Allow",
"Principal": {
"AWS": "arn:aws:iam::cloudfront:user/CloudFront Origin Access Identity *******"
},
"Action": "s3:GetObject",
"Resource": "arn:aws:s3:::geek.tacoskingdom.com/*"
}
]
}
CloudFront Origin Access Identity <ID値>
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Public Policy #1",
"Effect": "Allow",
"Principal": {
"AWS": "arn:aws:iam::cloudfront:user/CloudFront Origin Access Identity ***************"
},
"Action": "s3:GetObject",
"Resource": "arn:aws:s3:::geek.tacoskingdom.com/*"
}
]
}
data:image/s3,"s3://crabby-images/8c735/8c7358ea52305f6b87eae146d5b611122f6f024a" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
【通常CloudFront版・作業③】Route53の設定する
Route53
レコード名:
<サブドメイン名>.ドメイン
レコードタイプ:
A
エイリアス:
はい
エイリアス先:
CloudFrontディストリビューション
> どこかのリージョン
> 先程設定したCFデストリビューションのURL
data:image/s3,"s3://crabby-images/258f2/258f26e74eafd07fd3d41b82b7e66ae7e5e9a88f" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
https://geek.tacoskingdom.com
data:image/s3,"s3://crabby-images/b1a37/b1a372fdf2a66b305dbf307323c1b5602e6c8ff3" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
S3/CloudFront/Route53
https://geek.tacoskingdom.com.s3.ap-northeast-3.amazonaws.com/index.html
https://geek.tacoskingdom.com
Origin Domain Name
Origin Domain Name(変更前):hoge.piyo.com.s3.amazonaws.com
👇(S3バケットのあるリージョンをつける)
Origin Domain Name(変更後):hoge.piyo.com.s3-ap-northeast-1.amazonaws.com
【CloudFront Functions版・作業①】S3でHtmlファイル等を準備
geek.tacoskingdom.com
CloudFront Functions
kabu-app.tacoskingdom.com
data:image/s3,"s3://crabby-images/8a860/8a860032b0905e1bfd2463d9827ca3197549de37" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
index.html
<!doctype html>
<html lang="jp">
<head>
<meta charset="utf-8">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta http-equiv="Content-Style-Type" content="text/css; charset=UTF-8">
<meta http-equiv="Content-Script-Type" content="text/javascript; charset=UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=Edge">
<base href="/">
<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body><h1>404 not found</h1></body>
</html>
[アクセス許可]
data:image/s3,"s3://crabby-images/b7816/b7816535b1477a4d5e4ea808218f43bf767c5c70" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
s3:GetObject
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Public Policy #2",
"Effect": "Allow",
"Principal": "*",
"Action": "s3:GetObject",
"Resource": "arn:aws:s3:::kabu-app.tacoskingdom.com/*"
}
]
}
data:image/s3,"s3://crabby-images/4c262/4c262bdfedd0e14851bbd706b1fddab9802e609e" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
【CloudFront Functions版・作業②】CloudFrontとCloudFront Functionsを設定する
コンピューティング使用率
CloudFront Functionsを作成・発行する
[CloudFront] > [関数] > [関数を作成]ボタン
data:image/s3,"s3://crabby-images/64916/64916ffc5fcad0efacc402e22b1ce361127aaaed" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
kabu-app-handler
data:image/s3,"s3://crabby-images/0928f/0928f943a0c91a5d6221de48089db0a6cd9a1bd4" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
[関数コード]
function handler(event) {
const request = event.request;
const uri = request.uri;
if (!/index\.html$/m.test(uri)) {
if (/\/$/m.test(uri)) {
request.uri += 'index.html';
} else {
request.uri += '/index.html';
}
}
return request;
}
data:image/s3,"s3://crabby-images/16533/1653380fc8f0825b01908f94b646d4407fd5270f" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
data:image/s3,"s3://crabby-images/12e29/12e29de6cd1f2bf67c8d4a3f3f0316ecdc00423a" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
data:image/s3,"s3://crabby-images/68698/686988c0880f7db12312ff2a11b873197b96a509" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
[関連付けを追加]
(やっぱり)CloudFrontのディストリビューションを作成する
https://...
data:image/s3,"s3://crabby-images/8563a/8563a7c1a27547ac47dd10593b4aa66f88d3a5ea" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
ワイルドカード(*)
[関数の関連付け - オプション]
data:image/s3,"s3://crabby-images/c2949/c294945dcf63d2d693733c831176053d9b269ace" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
[ビューワーリクエスト]
CloudFront Functions
kabu-app-hander(先ほど作成したもの)
data:image/s3,"s3://crabby-images/683fe/683fe8654a36e081c1195eca68fa4235d74260ef" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Public Policy #2",
"Effect": "Allow",
"Principal": {
"AWS": "arn:aws:iam::cloudfront:user/CloudFront Origin Access Identity ***************"
},
"Action": "s3:GetObject",
"Resource": "arn:aws:s3:::geek.tacoskingdom.com/*"
}
]
}
【CloudFront Functions版・作業③】Route53の設定する
https://kabu-app.tacoskingdom.com
data:image/s3,"s3://crabby-images/d74eb/d74eb4374c8bb1593384c03f0649bf542968b67e" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
まとめ
参考サイト
記事を書いた人
ナンデモ系エンジニア
主にAngularでフロントエンド開発することが多いです。 開発環境はLinuxメインで進めているので、シェルコマンドも多用しております。 コツコツとプログラミングするのが好きな人間です。
カテゴリー