62 lines
2.4 KiB
YAML
62 lines
2.4 KiB
YAML
name: Build and Deploy
|
|
|
|
on:
|
|
push:
|
|
branches: [main]
|
|
|
|
env:
|
|
INTERNAL_REGISTRY: gitea-http.gitea.svc.cluster.local:3000
|
|
NODE_REGISTRY: localhost:30300
|
|
|
|
jobs:
|
|
build-and-deploy:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Install Docker CLI
|
|
run: |
|
|
curl -fsSL https://download.docker.com/linux/static/stable/x86_64/docker-27.5.1.tgz \
|
|
| tar xz --strip-components=1 -C /usr/local/bin docker/docker
|
|
docker version
|
|
|
|
- name: Install kubectl
|
|
run: |
|
|
curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl"
|
|
chmod +x kubectl
|
|
mv kubectl /usr/local/bin/
|
|
kubectl version --client
|
|
|
|
- name: Login to Gitea Registry
|
|
run: |
|
|
echo "${{ secrets.REGISTRY_PASSWORD }}" | \
|
|
docker login ${{ env.INTERNAL_REGISTRY }} \
|
|
-u ${{ secrets.REGISTRY_USERNAME }} --password-stdin
|
|
|
|
- name: Build and push server
|
|
run: |
|
|
docker build -f Dockerfile \
|
|
-t ${{ env.INTERNAL_REGISTRY }}/admin/monitoring-tg-server:${{ github.sha }} \
|
|
-t ${{ env.INTERNAL_REGISTRY }}/admin/monitoring-tg-server:latest \
|
|
.
|
|
docker push ${{ env.INTERNAL_REGISTRY }}/admin/monitoring-tg-server:${{ github.sha }}
|
|
docker push ${{ env.INTERNAL_REGISTRY }}/admin/monitoring-tg-server:latest
|
|
|
|
- name: Deploy to Kubernetes
|
|
env:
|
|
KUBECONFIG: /kubeconfig/config
|
|
run: |
|
|
kubectl apply -f k8s/namespace.yaml
|
|
kubectl apply -f k8s/secrets.yaml
|
|
kubectl apply -f k8s/configmap.yaml
|
|
kubectl apply -f k8s/postgres.yaml
|
|
kubectl apply -f k8s/server-deployment.yaml
|
|
kubectl apply -f k8s/server-service.yaml
|
|
kubectl -n monitoring-tg set image deployment/monitoring-tg-server \
|
|
monitoring-tg-migrate=${{ env.NODE_REGISTRY }}/admin/monitoring-tg-server:${{ github.sha }} \
|
|
monitoring-tg-server=${{ env.NODE_REGISTRY }}/admin/monitoring-tg-server:${{ github.sha }} \
|
|
monitoring-tg-telegram=${{ env.NODE_REGISTRY }}/admin/monitoring-tg-server:${{ github.sha }} \
|
|
monitoring-tg-classifier=${{ env.NODE_REGISTRY }}/admin/monitoring-tg-server:${{ github.sha }}
|
|
kubectl -n monitoring-tg rollout status deployment/monitoring-tg-server --timeout=180s
|