Installation
System Requirements:
Automatic Installation
To get started, you can scaffold the project with the mbc-cqrs-serverless CLI. To scaffold the project with the mbc-cqrs-serverless CLI, run the following commands. This will create a new project directory, and populate the directory with the initial core mbc-cqrs-serverless files and supporting modules, creating a conventional base structure for your project.
npm i -g @mbc-cqrs-serverless/cli
mbc new project-name
If you're new to mbc-cqrs-serverless, see the project structure docs for an overview of all the possible files and folders in your application.
Run the Development Server
- Run
npm run buildto the build project using development mode. - Open in other terminal session and run
npm run offline:docker - Open in other terminal session and run
npm run migrateto migrate RDS and dynamoDB table - Finally, run
npm run offline:slsto start serverless offline mode.
After the server runs successfully, you can see:
DEBUG[serverless-offline-sns][adapter]: successfully subscribed queue "http://localhost:9324/101010101010/notification-queue" to topic: "arn:aws:sns:ap-northeast-1:101010101010:MySnsTopic"
Offline Lambda Server listening on http://localhost:4000
serverless-offline-aws-eventbridge :: Plugin ready
serverless-offline-aws-eventbridge :: Mock server running at port: 4010
Starting Offline SQS at stage dev (ap-northeast-1)
Starting Offline Dynamodb Streams at stage dev (ap-northeast-1)
Starting Offline at stage dev (ap-northeast-1)
Offline [http for lambda] listening on http://localhost:3002
Function names exposed for local invocation by aws-sdk:
* main: serverless-example-dev-main
Configuring JWT Authorization: ANY /{proxy+}
┌────────────────────────────────────────────────────────────────────────┐
│ │
│ ANY | http://localhost:3000/api/public │
│ POST | http://localhost:3000/2015-03-31/functions/main/invocations │
│ ANY | http://localhost:3000/swagger-ui/{proxy*} │
│ POST | http://localhost:3000/2015-03-31/functions/main/invocations │
│ ANY | http://localhost:3000/{proxy*} │
│ POST | http://localhost:3000/2015-03-31/functions/main/invocations │
│ │
└────────────────────────────────────────────────────────────────────────┘
Server ready: http://localhost:3000 🚀
You can also use several endpoints:
- API gateway: http://localhost:3000
- Offline Lambda Server: http://localhost:4000
- HTTP for lambda: http://localhost:3002
- Step functions: http://localhost:8083
- DynamoDB: http://localhost:8000
- DynamoDB admin: http://localhost:8001
- SNS: http://localhost:4002
- SQS: http://localhost:9324
- SQS admin: http://localhost:9325
- Localstack: http://localhost:4566
- AppSync: http://localhost:4001
- Cognito: http://localhost:9229
- EventBridge: http://localhost:4010
- Simple Email Service: http://localhost:8005
- Run
npx prisma studioto open studio web: http://localhost:5000
Configuring Local Service Ports
Local port configuration feature was added in version 1.0.26.
If you have port conflicts with other services (e.g., another MySQL instance, another application using port 3000), you can configure the local service ports via environment variables in your .env file.
Available Port Variables
| Variable | Default | Service |
|---|---|---|
LOCAL_HTTP_PORT | 3000 | API Gateway (Serverless Offline) |
LOCAL_LAMBDA_PORT | 3002 | Lambda HTTP endpoint |
LOCAL_DYNAMODB_PORT | 8000 | DynamoDB Local |
LOCAL_RDS_PORT | 3306 | MySQL (RDS) |
LOCAL_S3_PORT | 4566 | LocalStack (S3) |
LOCAL_SNS_PORT | 4002 | SNS |
LOCAL_SQS_PORT | 9324 | SQS (ElasticMQ) |
LOCAL_SQS_UI_PORT | 9325 | SQS Admin UI |
LOCAL_SFN_PORT | 8083 | Step Functions Local |
LOCAL_COGNITO_PORT | 9229 | Cognito Local |
LOCAL_APPSYNC_PORT | 4001 | AppSync Simulator |
LOCAL_EVENTBRIDGE_PORT | 4010 | EventBridge |
LOCAL_SES_PORT | 8005 | Simple Email Service |
LOCAL_DDB_ADMIN_PORT | 8001 | DynamoDB Admin UI |
Example: Changing Ports
To change the API Gateway port from 3000 to 3010 and MySQL port from 3306 to 3307, add the following to your .env file:
# Change API Gateway port to 3010
LOCAL_HTTP_PORT=3010
# Change MySQL port to 3307
LOCAL_RDS_PORT=3307
# Change DynamoDB port to 9000
LOCAL_DYNAMODB_PORT=9000
After changing the ports, restart all services:
- Stop all running services (Docker and Serverless Offline)
- Run
npm run offline:dockerto restart Docker services - Run
npm run offline:slsto restart Serverless Offline
The port configuration is automatically applied to all related services including Docker Compose, Serverless Offline, and the DynamoDB stream trigger script. You only need to set the environment variables once in your .env file.
In the local environment, if you have trouble with the npm run migrate command or cannot log in with local Cognito, you will need to add more permissions to files and folders using the command below:
sudo chmod -R 777 ./infra-local/cognito-local
sudo chmod -R 777 ./infra-local/cognito-local/db/clients.json
sudo chmod -R 777 ./infra-local
sudo chmod -R 777 ./infra-local/docker-data/
sudo chmod -R 777 ./infra-local/docker-data/dynamodb-local