-
Notifications
You must be signed in to change notification settings - Fork 0
47 lines (45 loc) · 1.79 KB
/
deploy.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
name: Deploy to Production
on:
push:
branches:
- main
jobs:
deploy:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Build Docker Image
uses: docker/build-push-action@v2
with:
context: .
push: true
tags: ai-request-handler:latest
# Optional: Add Docker Hub credentials if needed
# dockerhub/username: ${DOCKER_HUB_USERNAME}
# dockerhub/password: ${DOCKER_HUB_PASSWORD}
- name: Deploy to Kubernetes
uses: kubernetes/kubectl-action@v1
with:
# Specify your Kubernetes configuration (e.g., kubeconfig file)
# kubeconfig: ${{ secrets.KUBECONFIG }}
# If you're using a cluster from a different provider, use appropriate secrets.
# For example, for AWS EKS, use:
# kubeconfig: ${{ secrets.AWS_EKS_KUBECONFIG }}
command: apply
# Specify the deployment YAML file
# This file should define your deployment in a way compatible with your Kubernetes cluster
# It should be named 'deployment.yaml' and placed in the root of your repository
# Update this if you use a different deployment file or folder:
path: deployment.yaml
# Add labels for versioning, environment, etc. as needed
# Example:
# labels: |
# version: ${{ secrets.CI_COMMIT_TAG }}
# environment: production
- name: Wait for deployment
run: |
# Optional: Implement a wait command to verify successful deployment
# This might involve waiting for a specific pod status, or other verification steps
# Example:
# kubectl wait --for=condition=Available deployment/ai-request-handler
echo "Deployment complete."