AWS Serverless——将create-react-ap
People don't want to buy a quarter-inch drill, they want a quarter-inch hole.
—Theodore Levitt
程序员并不是想买一个EC2,他们只想运行自己的代码。
这就有了serverless。
本文大部分内容引用和翻译来自React官方推荐的博文: Deploying create-react-app to S3 and CloudFront,还有一个第三方网站的资料也很详细:Learn to Build Full-Stack Apps with Serverless and React on AWS.
Prepare
如果你已经考虑到将前端项目部署在S3上,那么这种设计的优点就已无须赘述。
当前React的版本是v16.7.0,建议新建项目,因为不能保证old version可以适配S3。默认管理package的工具是npm,我使用的是yarn,这不影响项目打包运行。
将app build完后将会在build/ 或者dist/目录下得到若干文件和文件夹。
Deploy to S3
默认你已经有了AWS账号,打开控制台,导航至S3。
Create bucket
点击`Create bucket`,为你的bucket选择一个合适的名字。然后点击`Create`。
Region这一项可以选择目标客户所在的地理位置,因为后面会用 cloud front做全球CDN加速,所以这一项没那么重要。
data:image/s3,"s3://crabby-images/b12c2/b12c2b46ad03483f8e3431b3ea3715ddf9fb5ec6" alt=""
点击`Next`,如果你不知道这一页是做什么的,可以跳过继续点击`Next`
data:image/s3,"s3://crabby-images/282e2/282e240079a1e9e4dcb02d6c4ae59148e7790fe0" alt=""
在这一页将`Block new public bucket policies `和`Block public and cross-account access if bucket has public policies`这两项反选
data:image/s3,"s3://crabby-images/167a9/167a9adf77435639ffeaccd0feeffbd5bda86b7b" alt=""
点击`Next`后再点击`Create bucket`就可以完成bucket的创建。
enable and configure static website hosting
点击打开你新建的bucket,选中`Properties`标签栏,点击打开`Static website hosting`,选中`Use this bucket to host a website`.
在index document 和Error document中皆填入`index.html`,然后Save。
这个Endpoint就会是你网页的地址。
data:image/s3,"s3://crabby-images/2899d/2899d7df07eafee7116aae4be538f0157487efa1" alt=""
configure bucket policy
选中`Permissions`标签栏,再点击选中`Bucket Policy`,在文字框内输入
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "PublicReadForGetBucketObjects",
"Effect": "Allow",
"Principal": "*",
"Action": "s3:GetObject",
"Resource": "arn:aws:s3:::you-bucket-name/*"
}
]
}
确保resource属性中bucket的名字和你创建的是一致的。
data:image/s3,"s3://crabby-images/f7fec/f7fec95e628198b661adc68b4da398047f7266d9" alt=""
点击`Save`.
configure CORS configuration
点击 CORS configuration,输入
<?xml version="1.0" encoding="UTF-8"?>
<CORSConfiguration xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
<CORSRule>
<AllowedOrigin>*</AllowedOrigin>
<AllowedMethod>GET</AllowedMethod>
<MaxAgeSeconds>3000</MaxAgeSeconds>
<AllowedHeader>*</AllowedHeader>
</CORSRule>
</CORSConfiguration>
data:image/s3,"s3://crabby-images/3b73b/3b73b564826bf54a4e097660b058fafcfaf38ece" alt=""
这时候你可以将 build/ 目录下的文件都upload到该bucket下。再去打开`static website hosting`里提供的`endpoint`,就可以看到你的网站。
Deploy to CloudFront
进入Cloud Front,
Create distribution
点击`Create Distribution`,在`Web`下选择`Get Started`
data:image/s3,"s3://crabby-images/4c661/4c6612dce075055eb5efa11774727e9d5a490ef0" alt=""
然后填入自己项目合适的参数,这是我自己的参数。
Origin Domain Name 这一栏里填入刚刚创建的bucket中static web hosting的endpoint,鼠标选中后也会有提示在下拉栏里。
Default Root Object这一项输入 `index.html`。
一切填写完后点击`Create distribution`。
data:image/s3,"s3://crabby-images/b8c23/b8c23c0c9506213c8ed5035787c7102092db4057" alt=""
data:image/s3,"s3://crabby-images/93c24/93c2406d914bea4b32038d8e1b5c5b1d3cf64b51" alt=""
configure Error Pages
在新建好的 distribution里进入`Error Pages`,然后新建一个`Error Response`主要是让你的项目自己处理一些http status error.
data:image/s3,"s3://crabby-images/90f63/90f634f7884ba2115a9eba1e553cf7fba0cbd972" alt=""
Last
在General 选项中的Domain Name,就是CDN加速后的URL,用Route53处理就好了
data:image/s3,"s3://crabby-images/e66ab/e66ab9b84f088a99739955ee076cccbf2e43ba52" alt=""