This is sample nestjs project.
- link: https://nestjs.com
This is REST api made by node.js, nest, redis, mysql with typescript.
So you have to get node.js environment, redis for cache, mysql for database, know typescript syntax.
Please install node.js and I recommend to use docker for your database.
My recommand node.js version is dubnium and latest docker version.
-
Install node.js: https://nodejs.org/en/download/
-
Install Docker Desktop for MAC: https://docs.docker.com/docker-for-mac/install/
-
Install Docker Desktop for Windows: https://docs.docker.com/docker-for-windows/install/
-
Install compose: https://docs.docker.com/compose/install/
First, clone this repository into your local environment. Run followed command in your terminal.
git clone https://github.com/kyhsa93/nestjs-rest-cqrs-example.git
Second step, install package that needed in this project.
If your node.js environment is successly downloaded, you can use node package manager.
Run followed command in your terminal.
npm install
Next up, generate mysql and redis.
If you already have mysql, redis in your development environment, you can use that.
But if you don't have one or both, try this process.
Install docker for your OS from link in top of this documentation.
And run followed command.
If your docker is successfully installed, you can use docker cli.
docker run --name nest -d -p 3306:3306 -e MYSQL_DATABASE=nest -e MYSQL_ROOT_PASSWORD=test -v ~/database/nest:/var/lib/mysql mysql:5.7
docker run --name redis -d -p 6379:6379 redis:alpine
OR
docker-compose -f docker-compose.development.yml up -d # create mysql, redis container for development environment
docker-compose -f docker-compose.development.yml down # remove created containers
And then, you can connect mysql in http://localhost:3306, user name 'root' and password is 'test'.
Finaly, your develop environment is created.
You can start api with followed command.
npm start
And if you modify code and save, you can see the process detect code changes and restart it self.
If you can use docker cli, you can build docker image.
docker build -t nest-sample
docker images # list up docker images
And then you can create and run docker container using builded image.
docker run -d -p 5000:5000 nest-sample
docker ps # list up running container
and now you can connect api through http://localhost:5000.
Docker compose in this project is include api redis and mysql 5.7 for database.
Run followed command in project directory.
docker-compose up -d # build images, create and run containers in background
If container is created, you can access api on http://localhost:5000.
And you can access database through http://localhost:3306.
Default database user is root and password is test.
If you want apply your modified code into the running container, you can add build option.
docker-compose up -d --build # if source code is changed, rebuidl image, recreate and start container
After use compose, you have to stop and remove containers.
docker-compose down # stop and remove container in compose
If you want to use kubernetes, you can use manifest.yaml for apply to your kubernetes cluster.
Use minikube for create kubernetes locally or use your own kubernetes. (docker for desktop can be enable local cluster)
Minikube: https://kubernetes.io/docs/setup/learning-environment/minikube/
kubectl apply -f manifest.yaml # create kubernetes resource in your kubernetes using manifest.yaml file
kubectl delete -f manifest.yaml # delete kubernetes resource using manifest.yaml file
When all Deployment, Service and Pods is created, you can use api through http://localhost.
Also swagger ui address is http://localhost/api.
If you want see all container in deployment, you can use kubectl.
kubectl get all # print all kubernetes default namespace
kubectl logs deployment.apps/nestjs-rest-cqrs-example --all-containers=true
kubectl logs deployment.apps/nestjs-rest-cqrs-example --all-containers=true -f
About kubernetes: https://kubernetes.io/
Helm can help you to manage kubernetes applications.
Helm Charts help you define, install, and upgrade even the most complex Kubernetes application.
helm install --name <releasename> helm # create helm chart
helm delete --purge <releasename> # delete helm chart
About helm: https://helm.sh/
All configuration is in src/app.config.ts
Most default configuration can use through you environment values.
And also you can modify configurations.
Documentaion about this project is made swagger.
Start this api and connect http://localhost:5000/api in your browser.
git clone https://github.com/kyhsa93/nestjs-rest-cqrs-example.git # clone this project
# run mysql database container
docker run --name nest -d -p 3306:3306 -e MYSQL_DATABASE=nest -e MYSQL_ROOT_PASSWORD=test -v ~/database/nest:/var/lib/mysql mysql:5.7
docker build -t nest-sample # build docker image named nest-sample
docker images # list up docker images
docker run -d -p 5000:5000 nest-sample # run docker container using image nameed nest-sample (host port 5000 is mapped container port 5000 and container run background process)
docker ps # list up running container
docker-compose up -d # build images, create and start containers in background
docker-compose up -d --build # if container image's change exists, rebuild image, recreate and restart container
docker-compose down # stop and remove container in compose
npm install # install packges
npm test # run test
npm run build # transpile typescript
npm start # run sample code
docker-compose up # use compose
kubectl apply -f manifest.yaml # create kubernetes resource in your kubernetes using manifest.yaml file
kubectl delete -f manifest.yaml # delete kubernetes resource using manifest.yaml file
kubectl get all # print all kubernetes default namespace
kubectl logs deployment.apps/nestjs-rest-cqrs-example --all-containers=true
kubectl logs deployment.apps/nestjs-rest-cqrs-example --all-containers=true -f
helm install --name <releasename> helm # create helm chart
helm delete --purge <releasename> # delete helm chart
Github: https://github.com/kyhsa93/nestjs-rest-cqrs-example
Dockerhub: https://cloud.docker.com/repository/docker/kyhsa93/nestjs-rest-cqrs-example/