docker file & compose setup
This commit is contained in:
parent
748cc21b95
commit
934809a651
|
@ -18,4 +18,6 @@ data
|
|||
|
||||
build
|
||||
|
||||
dist
|
||||
|
||||
samples
|
||||
|
|
|
@ -4,10 +4,10 @@ NODE_ENV=development
|
|||
WEBHOOK_SHARED_KEY=mykey
|
||||
|
||||
# JWT
|
||||
JWT_TOKEN_SECRET=JWT_TOKEN_SECRET
|
||||
JWT_TOKEN_SECRET=jwtSecret
|
||||
JWT_ACCESS_TOKEN_EXPIRES_IN=5m
|
||||
JWT_REFRESH_TOKEN_EXPIRES_IN=30d
|
||||
|
||||
# Redis
|
||||
REDIS_HOST=localhost
|
||||
REDIS_HOST=redis
|
||||
REDIS_PORT=6379
|
||||
|
|
|
@ -1,21 +1,17 @@
|
|||
FROM node:20-alpine
|
||||
FROM node:18.20.2-buster
|
||||
|
||||
WORKDIR /app
|
||||
ENV PATH /app/bin:$PATH
|
||||
|
||||
COPY package.json .
|
||||
COPY package-lock.json .
|
||||
COPY package*.json .
|
||||
|
||||
RUN npm install --silent
|
||||
|
||||
COPY src ./src
|
||||
COPY public ./public
|
||||
COPY db ./db
|
||||
COPY configs ./configs
|
||||
COPY bin ./bin
|
||||
COPY tsconfig.json .
|
||||
COPY .env.development .
|
||||
COPY .sequelizerc .
|
||||
COPY . .
|
||||
|
||||
EXPOSE 3000
|
||||
|
||||
CMD ["npm", "run", "dev"]
|
||||
RUN chmod +x /app/bin/start_server.sh
|
||||
RUN chmod +x /app/bin/www
|
||||
|
||||
CMD ["start_server.sh", "--env", "development"]
|
|
@ -1,25 +1,38 @@
|
|||
FROM node:20-alpine
|
||||
FROM node:18.20.2-buster as build
|
||||
|
||||
WORKDIR /app
|
||||
WORKDIR /src
|
||||
|
||||
COPY package.json .
|
||||
COPY package-lock.json .
|
||||
COPY package*.json .
|
||||
|
||||
RUN npm install --silent
|
||||
|
||||
COPY src ./src
|
||||
COPY public ./public
|
||||
COPY db ./db
|
||||
COPY configs ./configs
|
||||
COPY bin ./bin
|
||||
COPY tsconfig.json .
|
||||
COPY .env.production .
|
||||
COPY .sequelizerc .
|
||||
COPY . .
|
||||
|
||||
RUN npm run build
|
||||
|
||||
FROM node:18.20.2-buster as production
|
||||
|
||||
WORKDIR /app
|
||||
ENV PATH /app/bin:$PATH
|
||||
|
||||
COPY --from=build /src/dist /app/dist
|
||||
COPY --from=build /src/package*.json /app/
|
||||
COPY --from=build /src/bin /app/bin
|
||||
COPY --from=build /src/configs /app/configs
|
||||
COPY --from=build /src/db /app/db
|
||||
COPY --from=build /src/private /app/private
|
||||
COPY --from=build /src/public /app//public
|
||||
COPY --from=build /src/scripts /app/scripts
|
||||
COPY --from=build /src/.sequelizerc /app/.sequelizerc
|
||||
COPY --from=build /src/.env.production /app/.env.production
|
||||
|
||||
RUN rm -rf /app/dist/__test__
|
||||
|
||||
RUN npm ci --omit=dev
|
||||
|
||||
EXPOSE 3000
|
||||
|
||||
RUN chmod +x ./bin/start_server.sh
|
||||
RUN chmod +x /app/bin/start_server.sh
|
||||
RUN chmod +x /app/bin/www
|
||||
|
||||
CMD ["sh", "./bin/start_server.sh"]
|
||||
CMD ["start_server.sh", "--env", "production"]
|
||||
|
|
|
@ -10,7 +10,7 @@ Todo
|
|||
|
||||
Application:
|
||||
- [ ] Create an error handler wrapper for all the routes.
|
||||
- [ ] On 1.0.0 release, finish the docker file and docker-compose file.
|
||||
- [x] Create docker file and docker-compose file.
|
||||
- [ ] Create tests using samples data
|
||||
- [ ] Create seed data
|
||||
|
||||
|
|
31
bin/start_server.sh
Normal file → Executable file
31
bin/start_server.sh
Normal file → Executable file
|
@ -1,4 +1,31 @@
|
|||
#!/bin/sh
|
||||
|
||||
npx sequelize db:migrate --env production
|
||||
node --trace-deprecation -r ts-node/register/transpile-only -r tsconfig-paths/register bin/node-api-template
|
||||
# check if argument --env is passed and set variable to the value of --env else set variable to development
|
||||
if [ "$1" = "--env" ]; then
|
||||
ENV=$2
|
||||
else
|
||||
ENV="development"
|
||||
fi
|
||||
|
||||
# check if the value of --env is either development or production
|
||||
if [ "$ENV" != "development" ] && [ "$ENV" != "production" ]; then
|
||||
echo "Invalid environment. Please use either development or production"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# check if the value of --env is production
|
||||
if [ "$ENV" = "production" ]; then
|
||||
npx sequelize db:create --env $ENV
|
||||
npx sequelize db:migrate --env $ENV
|
||||
npx sequelize db:seed:all --env $ENV
|
||||
www
|
||||
exit 0
|
||||
fi
|
||||
|
||||
# check if the value of --env is development
|
||||
if [ "$ENV" = "development" ]; then
|
||||
npx sequelize db:create --env $ENV
|
||||
npx sequelize db:migrate --env $ENV
|
||||
npm run dev
|
||||
exit 0
|
||||
fi
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
#!/usr/bin/env node
|
||||
|
||||
require('@configs/env.config')('production');
|
||||
require('../configs/env.config')('production');
|
||||
const logger = require('../dist/utils/logger.util').default;
|
||||
const App = require('../dist/app').default;
|
||||
const app = new App().app;
|
|
@ -1,6 +1,6 @@
|
|||
{
|
||||
"development": {
|
||||
"username": "root",
|
||||
"username": "postgres",
|
||||
"password": "",
|
||||
"database": "node_api_template_development",
|
||||
"host": "127.0.0.1",
|
||||
|
@ -8,7 +8,7 @@
|
|||
"dialect": "postgres"
|
||||
},
|
||||
"test": {
|
||||
"username": "root",
|
||||
"username": "postgres",
|
||||
"password": "",
|
||||
"database": "node_api_template_test",
|
||||
"host": "127.0.0.1",
|
||||
|
@ -16,7 +16,7 @@
|
|||
"dialect": "postgres"
|
||||
},
|
||||
"production": {
|
||||
"username": "root",
|
||||
"username": "postgres",
|
||||
"password": "",
|
||||
"database": "node_api_template_production",
|
||||
"host": "127.0.0.1",
|
||||
|
|
|
@ -23,12 +23,12 @@ http {
|
|||
server_name localhost;
|
||||
|
||||
location / {
|
||||
proxy_set_header X-Forwarded-For $remote_addr;
|
||||
proxy_set_header Host $host;
|
||||
proxy_pass http://api-server;
|
||||
proxy_http_version 1.1;
|
||||
proxy_set_header Upgrade $http_upgrade;
|
||||
proxy_set_header Connection 'upgrade';
|
||||
proxy_set_header Host $host;
|
||||
proxy_cache_bypass $http_upgrade;
|
||||
proxy_set_header Connection "upgrade";
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -40,5 +40,4 @@ http {
|
|||
|
||||
sendfile on;
|
||||
keepalive_timeout 65;
|
||||
include /etc/nginx/conf.d/*.conf;
|
||||
}
|
||||
|
|
|
@ -1,24 +1,25 @@
|
|||
version: '3.9'
|
||||
|
||||
services:
|
||||
redis:
|
||||
container_name: redis
|
||||
container_name: node_api_redis
|
||||
image: redis:6.2.14-alpine
|
||||
healthcheck:
|
||||
test: ["CMD", "redis-cli", "ping"]
|
||||
timeout: 10s
|
||||
retries: 10
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 5
|
||||
ports:
|
||||
- 6379:6379
|
||||
expose:
|
||||
- 6379
|
||||
restart: always
|
||||
networks:
|
||||
- x_trait_network
|
||||
- node_api_network
|
||||
|
||||
server:
|
||||
container_name: server
|
||||
image: pandrive:0.1.0
|
||||
container_name: node_api_server
|
||||
build:
|
||||
context: .
|
||||
dockerfile: Dockerfile.development
|
||||
volumes:
|
||||
- .:/app
|
||||
ports:
|
||||
|
@ -27,7 +28,9 @@ services:
|
|||
- 3000
|
||||
restart: always
|
||||
networks:
|
||||
- x_trait_network
|
||||
- node_api_network
|
||||
environment:
|
||||
- REDIS_HOST=redis
|
||||
links:
|
||||
- database
|
||||
- redis
|
||||
|
@ -38,29 +41,30 @@ services:
|
|||
condition: service_healthy
|
||||
|
||||
database:
|
||||
container_name: database
|
||||
image: mysql:8
|
||||
container_name: node_api_database
|
||||
image: postgres:16.3
|
||||
user: postgres
|
||||
healthcheck:
|
||||
test: [ "CMD", "mysqladmin" ,"ping", "-h", "database" ]
|
||||
timeout: 10s
|
||||
retries: 10
|
||||
test: ["CMD-SHELL", "pg_isready"]
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 5
|
||||
cap_add:
|
||||
- SYS_NICE
|
||||
ports:
|
||||
- 3306:3306
|
||||
- 5432:5432
|
||||
expose:
|
||||
- 3306
|
||||
- 5432
|
||||
volumes:
|
||||
- db:/var/lib/mysql
|
||||
- db:/var/lib/postgresql/data
|
||||
restart: always
|
||||
networks:
|
||||
- x_trait_network
|
||||
- node_api_network
|
||||
environment:
|
||||
- MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}
|
||||
- MYSQL_DATABASE=${MYSQL_DATABASE}
|
||||
- POSTGRES_PASSWORD=myPassword
|
||||
|
||||
networks:
|
||||
x_trait_network:
|
||||
node_api_network:
|
||||
driver: bridge
|
||||
|
||||
volumes:
|
||||
|
|
|
@ -1,8 +1,6 @@
|
|||
version: '3.9'
|
||||
|
||||
services:
|
||||
proxy:
|
||||
container_name: proxy
|
||||
container_name: node_api_proxy
|
||||
image: nginx:alpine
|
||||
ports:
|
||||
- 80:80
|
||||
|
@ -14,37 +12,42 @@ services:
|
|||
- ./configs/nginx.conf:/etc/nginx/nginx.conf
|
||||
restart: always
|
||||
networks:
|
||||
- x_trait_network
|
||||
- node_api_network
|
||||
depends_on:
|
||||
- server
|
||||
links:
|
||||
- server
|
||||
|
||||
redis:
|
||||
container_name: redis
|
||||
container_name: node_api_redis
|
||||
image: redis:6.2.14-alpine
|
||||
healthcheck:
|
||||
test: ["CMD", "redis-cli", "ping"]
|
||||
timeout: 10s
|
||||
retries: 10
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 5
|
||||
ports:
|
||||
- 6379:6379
|
||||
expose:
|
||||
- 6379
|
||||
restart: always
|
||||
networks:
|
||||
- x_trait_network
|
||||
- node_api_network
|
||||
|
||||
server:
|
||||
container_name: server
|
||||
image: pandrive:0.1.0
|
||||
container_name: node_api_server
|
||||
build:
|
||||
context: .
|
||||
dockerfile: Dockerfile.production
|
||||
ports:
|
||||
- 3000:3000
|
||||
expose:
|
||||
- 3000
|
||||
restart: always
|
||||
networks:
|
||||
- x_trait_network
|
||||
- node_api_network
|
||||
environment:
|
||||
- REDIS_HOST=redis
|
||||
links:
|
||||
- database
|
||||
- redis
|
||||
|
@ -55,29 +58,30 @@ services:
|
|||
condition: service_healthy
|
||||
|
||||
database:
|
||||
container_name: database
|
||||
image: mysql:8
|
||||
container_name: node_api_database
|
||||
image: postgres:16.3
|
||||
user: postgres
|
||||
healthcheck:
|
||||
test: [ "CMD", "mysqladmin" ,"ping", "-h", "database" ]
|
||||
timeout: 10s
|
||||
retries: 10
|
||||
test: ["CMD-SHELL", "pg_isready"]
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 5
|
||||
cap_add:
|
||||
- SYS_NICE
|
||||
ports:
|
||||
- 3306:3306
|
||||
- 5432:5432
|
||||
expose:
|
||||
- 3306
|
||||
- 5432
|
||||
volumes:
|
||||
- db:/var/lib/mysql
|
||||
- db:/var/lib/postgresql/data
|
||||
restart: always
|
||||
networks:
|
||||
- x_trait_network
|
||||
- node_api_network
|
||||
environment:
|
||||
- MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}
|
||||
- MYSQL_DATABASE=${MYSQL_DATABASE}
|
||||
- POSTGRES_PASSWORD=myPassword
|
||||
|
||||
networks:
|
||||
x_trait_network:
|
||||
node_api_network:
|
||||
driver: bridge
|
||||
|
||||
volumes:
|
||||
|
|
1607
package-lock.json
generated
1607
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
11
package.json
11
package.json
|
@ -4,9 +4,9 @@
|
|||
"description": "node-api-template is a micro service api template.",
|
||||
"main": "bin/node-api-template",
|
||||
"scripts": {
|
||||
"start": "node --trace-deprecation -r ts-node/register/transpile-only -r tsconfig-paths/register bin/node-api-template",
|
||||
"start": "node --trace-deprecation bin/node-api-template",
|
||||
"dev": "npx nodemon",
|
||||
"build": "npx rimraf dist && npx tsc",
|
||||
"build": "npx rimraf dist && npx tsc --project tsconfig.json && tscpaths -p tsconfig.json -s ./src -o ./dist",
|
||||
"clean": "npx rimraf dist",
|
||||
"skip:postinstall": "npx sequelize db:migrate",
|
||||
"db:setup:production": "npx sequelize db:create --env production && npx sequelize db:migrate --env production && npx sequelize db:seed:all --env production",
|
||||
|
@ -66,7 +66,10 @@
|
|||
"rimraf": "^5.0.5",
|
||||
"supertest": "^6.3.4",
|
||||
"ts-jest": "^29.1.2",
|
||||
"typescript": "^5.3.3"
|
||||
"ts-node": "^10.9.2",
|
||||
"tsconfig-paths": "^4.2.0",
|
||||
"tscpaths": "^0.0.9",
|
||||
"typescript": "^5.5.3"
|
||||
},
|
||||
"dependencies": {
|
||||
"axios": "^1.6.7",
|
||||
|
@ -91,8 +94,6 @@
|
|||
"sequelize": "^6.37.3",
|
||||
"sequelize-cli": "^6.6.2",
|
||||
"sequelize-typescript": "^2.1.6",
|
||||
"ts-node": "^10.9.2",
|
||||
"tsconfig-paths": "^4.2.0",
|
||||
"winston": "^3.13.0",
|
||||
"winston-daily-rotate-file": "^5.0.0"
|
||||
}
|
||||
|
|
|
@ -71,7 +71,7 @@ const errorDailyRotateTransport = new DailyRotateFile({
|
|||
});
|
||||
|
||||
const logger = createLogger({
|
||||
level: process.env.NODE_ENV === 'production' ? 'info' : 'debug',
|
||||
level: process.env.NODE_ENV === 'production' ? 'http' : 'debug',
|
||||
silent: process.env.NODE_ENV === 'test',
|
||||
format: format.combine(
|
||||
format.timestamp({
|
||||
|
|
|
@ -28,7 +28,7 @@
|
|||
"@middlewares/*": ["src/middlewares/*"],
|
||||
"@events": ["src/events/*"],
|
||||
"@base": ["src/base/*"],
|
||||
"@content": ["src/content/*"],
|
||||
"@content": ["src/content/*"]
|
||||
},
|
||||
|
||||
"resolveJsonModule": true,
|
||||
|
|
Loading…
Reference in New Issue
Block a user