Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Develop #226

Closed
wants to merge 10 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
47 changes: 47 additions & 0 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
version: 2.1

jobs:
int-application:
docker:
- image: circleci/node:14
steps:
- checkout
build-docker:
machine: true
steps:
- checkout
- run:
name: Build docker container
command: |
echo "--------- Building Image ------------"

docker build -t udagram-api-feed ./udagram-api-feed
docker tag udagram-api-feed quangnm1999/udagram-api-feed:latest

docker build -t udagram-api-user ./udagram-api-user
docker tag udagram-api-user quangnm1999/udagram-api-user:latest

docker build -t udagram-frontend ./udagram-frontend
docker tag udagram-frontend quangnm1999/udagram-frontend:latest

docker build -t reverseproxy ./udagram-reverseproxy
docker tag reverseproxy quangnm1999/reverseproxy:latest

echo "-------- All images succesfully----------"

echo " ------- login in to hub--------"

echo "$DOCKER_PASSWORD" | docker login -u "$DOCKER_USERNAME" --password-stdin

echo "-------------- Pushing images to dockerhub-------"

docker push quangnm1999/udagram-api-feed:latest
docker push quangnm1999/udagram-api-user:latest
docker push quangnm1999/udagram-frontend:latest
docker push quangnm1999/reverseproxy:latest
workflows:
default:
jobs:
- int-application
- build-docker:
requires: [int-application]
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -40,3 +40,4 @@ venv/
.elasticbeanstalk/*
!.elasticbeanstalk/*.cfg.yml
!.elasticbeanstalk/*.global.yml
.env
7 changes: 7 additions & 0 deletions deployment/aws-secret.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
apiVersion: v1
kind: Secret
metadata:
name: aws-secret
type: Opaque
data:
credentials: W2RlZmF1bHRdCmF3c19hY2Nlc3Nfa2V5X2lkID0gQUtJQTRYM1hHSEM2Q0lJTU9LUkMKYXdzX3NlY3JldF9hY2Nlc3Nfa2V5ID0gL3NyZUlOU0YvVURVMGlQYXQ4eWxDZ29xT1AzNVg2OXVqekRBVEk0ag==
82 changes: 82 additions & 0 deletions deployment/backend-feed-deployment.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
service: backend-feed
name: backend-feed
spec:
replicas: 2
selector:
matchLabels:
service: backend-feed
template:
metadata:
labels:
service: backend-feed
spec:
containers:
- image: quangnm1999/udagram-api-feed:latest
name: backend-feed
imagePullPolicy: Always
resources:
requests:
memory: "64Mi"
cpu: "250m"
limits:
memory: "2048Mi"
cpu: "500m"
env:
- name: POSTGRES_USERNAME
valueFrom:
secretKeyRef:
name: env-secret
key: POSTGRES_USERNAME
- name: POSTGRES_PASSWORD
valueFrom:
secretKeyRef:
name: env-secret
key: POSTGRES_PASSWORD
- name: POSTGRES_DB
valueFrom:
configMapKeyRef:
name: env-config
key: POSTGRES_DB
- name: POSTGRES_HOST
valueFrom:
configMapKeyRef:
name: env-config
key: POSTGRES_HOST
- name: AWS_BUCKET
valueFrom:
configMapKeyRef:
name: env-config
key: AWS_BUCKET
- name: AWS_PROFILE
valueFrom:
configMapKeyRef:
name: env-config
key: AWS_PROFILE
- name: AWS_REGION
valueFrom:
configMapKeyRef:
name: env-config
key: AWS_REGION
- name: JWT_SECRET
valueFrom:
configMapKeyRef:
name: env-config
key: JWT_SECRET
- name: URL
valueFrom:
configMapKeyRef:
name: env-config
key: URL
volumeMounts:
- name: aws-secret
mountPath: "/root/.aws/"
readOnly: true
restartPolicy: Always
volumes:
- name: aws-secret
secret:
secretName: aws-secret
13 changes: 13 additions & 0 deletions deployment/backend-feed-service.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
apiVersion: v1
kind: Service
metadata:
labels:
service: backend-feed
name: backend-feed
spec:
ports:
- name: "8080"
port: 8080
targetPort: 8080
selector:
service: backend-feed
82 changes: 82 additions & 0 deletions deployment/backend-user-deployment.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
service: backend-user
name: backend-user
spec:
replicas: 1
selector:
matchLabels:
service: backend-user
template:
metadata:
labels:
service: backend-user
spec:
containers:
- image: quangnm1999/udagram-api-user:latest
name: backend-user
imagePullPolicy: Always
resources:
requests:
memory: "64Mi"
cpu: "250m"
limits:
memory: "2048Mi"
cpu: "500m"
env:
- name: POSTGRES_USERNAME
valueFrom:
secretKeyRef:
name: env-secret
key: POSTGRES_USERNAME
- name: POSTGRES_PASSWORD
valueFrom:
secretKeyRef:
name: env-secret
key: POSTGRES_PASSWORD
- name: POSTGRES_DB
valueFrom:
configMapKeyRef:
name: env-config
key: POSTGRES_DB
- name: POSTGRES_HOST
valueFrom:
configMapKeyRef:
name: env-config
key: POSTGRES_HOST
- name: AWS_BUCKET
valueFrom:
configMapKeyRef:
name: env-config
key: AWS_BUCKET
- name: AWS_PROFILE
valueFrom:
configMapKeyRef:
name: env-config
key: AWS_PROFILE
- name: AWS_REGION
valueFrom:
configMapKeyRef:
name: env-config
key: AWS_REGION
- name: JWT_SECRET
valueFrom:
configMapKeyRef:
name: env-config
key: JWT_SECRET
- name: URL
valueFrom:
configMapKeyRef:
name: env-config
key: URL
volumeMounts:
- name: aws-secret
mountPath: "/root/.aws/"
readOnly: true
restartPolicy: Always
volumes:
- name: aws-secret
secret:
secretName: aws-secret
13 changes: 13 additions & 0 deletions deployment/backend-user-service.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
apiVersion: v1
kind: Service
metadata:
labels:
service: backend-user
name: backend-user
spec:
ports:
- name: "8080"
port: 8080
targetPort: 8080
selector:
service: backend-user
15 changes: 15 additions & 0 deletions deployment/env-configmap.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
apiVersion: v1
kind: ConfigMap
data:
POSTGRES_USERNAME: postgres
POSTGRES_PASSWORD: postgres
POSTGRES_DB: postgres
POSTGRES_HOST: postgres.codctohgfvrc.us-east-1.rds.amazonaws.com
POSTGRES_POST: "5432"
AWS_BUCKET: mybucket-project03
AWS_PROFILE: default
AWS_REGION: us-east-1
JWT_SECRET: udagram@2024
URL: http://localhost:8100/
metadata:
name: env-config
8 changes: 8 additions & 0 deletions deployment/env-secret.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
apiVersion: v1
kind: Secret
metadata:
name: env-secret
type: Opaque
data:
POSTGRES_USERNAME: cG9zdGdyZXM=
POSTGRES_PASSWORD: cG9zdGdyZXM=
30 changes: 30 additions & 0 deletions deployment/frontend-deployment.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
service: udagram-frontend
name: udagram-frontend
spec:
replicas: 1
selector:
matchLabels:
service: udagram-frontend
template:
metadata:
labels:
service: udagram-frontend
spec:
containers:
- image: quangnm1999/udagram-frontend:latest
name: udagram-frontend
imagePullPolicy: Always
ports:
- containerPort: 80
resources:
requests:
memory: "64Mi"
cpu: "250m"
limits:
memory: "1024Mi"
cpu: "500m"
restartPolicy: Always
13 changes: 13 additions & 0 deletions deployment/frontend-service.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
apiVersion: v1
kind: Service
metadata:
labels:
service: udagram-frontend
name: udagram-frontend
spec:
ports:
- name: "8100"
port: 8100
targetPort: 80
selector:
service: udagram-frontend
30 changes: 30 additions & 0 deletions deployment/reverseproxy-deployment.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
apiVersion: apps/v1
kind: Deployment
metadata:
name: reverseproxy
labels:
app: reverseproxy
spec:
replicas: 1
selector:
matchLabels:
app: reverseproxy
template:
metadata:
labels:
app: reverseproxy
spec:
containers:
- image: quangnm1999/reverseproxy:latest
name: reverseproxy
imagePullPolicy: Always
resources:
requests:
memory: "64Mi"
cpu: "200m"
limits:
memory: "1024Mi"
cpu: "500m"
ports:
- containerPort: 8080
restartPolicy: Always
13 changes: 13 additions & 0 deletions deployment/reverseproxy-service.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
apiVersion: v1
kind: Service
metadata:
labels:
app: reverseproxy
name: reverseproxy
spec:
ports:
- name: "8080"
port: 8080
targetPort: 8080
selector:
app: reverseproxy
Loading