diff --git a/.github/workflows/deploy-staging.yml b/.github/workflows/deploy-staging.yml index d1c8400..2b612fe 100644 --- a/.github/workflows/deploy-staging.yml +++ b/.github/workflows/deploy-staging.yml @@ -47,4 +47,5 @@ jobs: script: | sudo apt update && sudo apt install -y jq python3-pip cd infra-hideyoshi.com - ./deploy.sh --staging \ No newline at end of file + ./deploy.sh --staging + ./refresh.sh \ No newline at end of file diff --git a/.github/workflows/refresh-deployment.yml b/.github/workflows/refresh-deployment.yml new file mode 100644 index 0000000..3c1f566 --- /dev/null +++ b/.github/workflows/refresh-deployment.yml @@ -0,0 +1,47 @@ +name: workflow_02 + +on: + workflow_run: + workflows: ["build"] + branches: [main] + types: + - completed + repository_dispatch: + types: [refresh-deployments] + +jobs: + refresh-deployments: + name: Refresh deployments + environment: prod + runs-on: ubuntu-latest + steps: + - name: Checkout + uses: actions/checkout@v3 + + - name: Executing Remote Commands - Refresh All Deployments + env: + deployments: ${{ github.event.client_payload.deployments }} + if: ${{ env.deployments == '' || github.event.workflow_run.conclusion == 'success' }} + uses: appleboy/ssh-action@master + with: + host: ${{ secrets.SSH_HOST }} + username: ${{ secrets.SSH_USER }} + port: ${{ secrets.SSH_PORT }} + key: ${{ secrets.SSH_KEY }} + script: | + [[ -d infra-hideyoshi.com ]] && \ + ./infra-hideyoshi.com/refresh.sh + + - name: Executing Remote Commands - Refresh Specific Deployments + env: + deployments: ${{ github.event.client_payload.deployments }} + if: ${{ env.deployments != '' }} + uses: appleboy/ssh-action@master + with: + host: ${{ secrets.SSH_HOST }} + username: ${{ secrets.SSH_USER }} + port: ${{ secrets.SSH_PORT }} + key: ${{ secrets.SSH_KEY }} + script: | + [[ -d infra-hideyoshi.com ]] && \ + ./infra-hideyoshi.com/refresh.sh ${{ env.deployments }} \ No newline at end of file diff --git a/deployment/backend/backend.yaml b/deployment/backend/backend.yaml index 1200bab..c129cd0 100644 --- a/deployment/backend/backend.yaml +++ b/deployment/backend/backend.yaml @@ -22,8 +22,8 @@ spec: memory: "256Mi" cpu: "250m" limits: - memory: "512Mi" - cpu: "750m" + memory: "768Mi" + cpu: "500m" ports: - containerPort: 8070 env: diff --git a/deployment/frontend/frontend.yaml b/deployment/frontend/frontend.yaml index a9e62af..f9638fd 100644 --- a/deployment/frontend/frontend.yaml +++ b/deployment/frontend/frontend.yaml @@ -24,8 +24,8 @@ spec: memory: "256Mi" cpu: "250m" limits: - memory: "1536Mi" - cpu: "750m" + memory: "512Mi" + cpu: "500m" ports: - containerPort: 5000 env: diff --git a/deployment/postgres/postgres.yaml b/deployment/postgres/postgres.yaml index e6f8399..827e349 100644 --- a/deployment/postgres/postgres.yaml +++ b/deployment/postgres/postgres.yaml @@ -22,7 +22,7 @@ spec: memory: "512Mi" cpu: "500m" limits: - memory: "512Mi" + memory: "768Mi" cpu: "500m" ports: - containerPort: 5432 diff --git a/deployment/redis/redis.yaml b/deployment/redis/redis.yaml index bf3ba34..3c1eaec 100644 --- a/deployment/redis/redis.yaml +++ b/deployment/redis/redis.yaml @@ -23,7 +23,7 @@ spec: cpu: "250m" limits: memory: "1024Mi" - cpu: "500m" + cpu: "250m" ports: - containerPort: 6379 env: diff --git a/deployment/storage/storage.yaml b/deployment/storage/storage.yaml index bfceda1..2ffe59d 100644 --- a/deployment/storage/storage.yaml +++ b/deployment/storage/storage.yaml @@ -22,8 +22,8 @@ spec: memory: "256Mi" cpu: "250m" limits: - memory: "512Mi" - cpu: "500m" + memory: "256Mi" + cpu: "250m" ports: - containerPort: 8000 env: diff --git a/refresh.sh b/refresh.sh new file mode 100755 index 0000000..9f3e17d --- /dev/null +++ b/refresh.sh @@ -0,0 +1,23 @@ +#!/bin/bash + +NAMESPACES=( + portfolio +) + +if [ $# -eq 0 ]; then + DEPLOYMENTS=( + "frontend-deployment" + "backend-deployment" + "storage-deployment" + "storage-processor-deployment" + ) +else + DEPLOYMENTS=("$@") +fi + +for i in "${NAMESPACES[@]}"; do + for x in "${DEPLOYMENTS[@]}"; do + PODS=$(kubectl -n $i get pods --no-headers | awk '{print $1}' | grep $x | tr '\n' ' ') + kubectl -n $i delete pods $PODS + done +done diff --git a/setup.py b/setup.py index d9466b7..f8edc4b 100644 --- a/setup.py +++ b/setup.py @@ -13,6 +13,7 @@ def write_template(template: str, output: str): open(output, 'w') as output: output.write(envsubst(template.read())) + def configure_templates(environment: str): if not environment in ("prod", "staging", "local"): raise ValueError("Invalid Environment Selected")