Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tonyfromundefined/nuxt-serverless
Nuxt.js Serverless SSR Starter on AWS (Lambda + API Gateway + S3) with Serverless Framework
https://github.com/tonyfromundefined/nuxt-serverless
aws aws-api-gateway aws-lambda aws-s3 nuxt serverless-framework typescript
Last synced: 2 months ago
JSON representation
Nuxt.js Serverless SSR Starter on AWS (Lambda + API Gateway + S3) with Serverless Framework
- Host: GitHub
- URL: https://github.com/tonyfromundefined/nuxt-serverless
- Owner: tonyfromundefined
- Archived: true
- Created: 2018-04-06T16:22:29.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2022-02-11T12:28:41.000Z (almost 3 years ago)
- Last Synced: 2024-08-04T04:03:01.645Z (6 months ago)
- Topics: aws, aws-api-gateway, aws-lambda, aws-s3, nuxt, serverless-framework, typescript
- Language: JavaScript
- Homepage:
- Size: 3.07 MB
- Stars: 254
- Watchers: 10
- Forks: 32
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# π Nuxt.js SSR on AWS Serverless Stack (Lambda + API Gateway + S3)
Nuxt.js Serverless Server-side Rendering Starter on AWS Serverless Stack (Lambda + API Gateway + S3) with *Serverless Framework*
### Pre-Installed
- Nuxt.js 2.8.1
- Serverless Framework
- TypeScript
- Sass (SCSS)
- TSLintIf you have a feature request, please create a new issue. And also, pull requests are always welcomeπ
### Caution
- Libraries that are used in the client should be included in the `devDependencies` for Bundle size optimization. (because of Lambda Limit)
- If you install a `module` for nuxt.js, it must be in a the `dependencies` not `devDependencies`
- Auto generated URL `https://*.execute-api.{region}.amazonaws.com/{stage}/` will result in a JavaScript error. (routing problem) **Please use the Custom Domain.**
- If you encounter `Cannot GET /` error message, the error log can be founded in the AWS CloudWatch.## Pre-requisites
- π **IAM Account** for *Serverless framework* (Requires pre-configuration using `aws configure`)```bash
$ aws configure
```## Configuration
Edit `serverless.yml````yaml
service: nuxt-serverless # 1. Edit whole service nameplugins:
- serverless-s3-sync
- serverless-apigw-binary
- serverless-dotenv-pluginpackage:
individually: true
excludeDevDependencies: trueprovider:
name: aws
runtime: nodejs10.x
stage: ${opt:stage, 'dev'}
region: us-east-1 # 2. Edit AWS region namecustom:
#######################################
# Unique ID included in resource names.
# Replace it with a random value for every first distribution.
# https://www.random.org/strings/?num=1&len=6&digits=on&loweralpha=on&unique=on&format=html&rnd=new
stackId: abcdef # 3. Update Random Stack ID
#######################################buckets:
ASSETS_BUCKET_NAME: ${self:service}-${self:custom.stackId}-${self:provider.stage}-assets
STATIC_BUCKET_NAME: ${self:service}-${self:custom.stackId}-${self:provider.stage}-static
s3Sync:
- bucketName: ${self:custom.buckets.ASSETS_BUCKET_NAME}
localDir: .nuxt/dist/client
- bucketName: ${self:custom.buckets.STATIC_BUCKET_NAME}
localDir: static
apigwBinary:
types:
- '*/*'
```## Build Setup
```bash
# Install dependencies
$ yarn# Serve develop server at localhost:3000 using Nuxt.js
$ yarn dev# Build
$ yarn build# Prod server start with built assets
$ yarn start## SERVERLESS DEPLOYMENT ##
# Build and deploy the function and bundled assets
$ yarn deploy:dev
$ yarn deploy:stage
$ yarn deploy:prod# Remove Deployment
$ yarn undeploy:dev
$ yarn undeploy:stage
$ yarn undeploy:prod
```## Environment Variables
- update `.env.development`, `.env.production`.
- If env variable key started with `NUXT_APP`, it injected to client in `this.$store.state.environments`.
- WARNING!: Untrack the `.env.development` and the `.env.production` before commit## Folder Structure
- `/api`: You can create a sub-API based on Express.js. dynamic ajax Set-Cookie is mainly used.
> Let the URL be a `* .json` to distinguish it from the REST API that returns JSON.
- `/pages`: File-based page routing. All ts files in `/pages` are only alias with `export {default}` to `/services/${serviceName}/pages/**`. all implementations should be done inside `/services`.```typescript
export { default } from '~/services/home/pages/index'
```
- `/services`: The application is divided into several services and should be implemented in a folder named by service name. (Example: `/home`, `/auth`, ...)
- Inside a Service: `/components`, `/queries`, `/pages`, `/helpers`, `/types`, ...
- `/store`: One Store that is globally used.
- `/types`: Declare only `.d.ts`. The type used for each service should be stored in `/types' in each service.## To-do
- [x] optimize the lambda capacity (create SSR bundle with no dependencies)
- [x] static file serve
- [ ] gzip Compression