Update docker-image.yml #9
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI/CD Pipeline 24markets web | |
on: | |
push: | |
branches: | |
- develop | |
- main | |
jobs: | |
build: | |
name: Build Docker Image | |
runs-on: ubuntu-latest | |
environment: ${{ github.ref == 'refs/heads/main' && 'production' || github.ref == 'refs/heads/develop' && 'development' }} | |
steps: | |
- name: Checkout code | |
uses: actions/[email protected] | |
- name: Set Environment Variables Based on Branch | |
run: | | |
echo "DOCKER_IMAGE=${{ vars.ACR }}/web-${{ vars.ENV }}" >> $GITHUB_ENV | |
- name: Azure Container Registry login | |
uses: azure/docker-login@v2 | |
with: | |
login-server: ${{ vars.ACR }} | |
username: ${{ secrets.ACR_USERNAME }} | |
password: ${{ secrets.ACR_PASSWORD }} | |
- name: Build and push Docker image | |
run: | | |
cp .env.${{ vars.ENVIRONMENT }} .env | |
docker build --build-arg BUILDKIT_INLINE_CACHE=1 --build-arg RELEASE=$GITHUB_SHA \ | |
--cache-from ${{ env.DOCKER_IMAGE }}:latest -f Dockerfile -t ${{ env.DOCKER_IMAGE }}:latest -t ${{ env.DOCKER_IMAGE }}:$GITHUB_SHA . | |
echo "${{ env.DOCKER_IMAGE }}:$GITHUB_SHA" | |
echo "Pushing image to ${{ env.DOCKER_IMAGE }}" | |
docker push ${{ env.DOCKER_IMAGE }}:latest | |
docker push ${{ env.DOCKER_IMAGE }}:$GITHUB_SHA | |
deploy: | |
permissions: | |
actions: read | |
contents: read | |
id-token: write | |
name: Deploy Helm Charts | |
needs: build | |
runs-on: ubuntu-latest | |
environment: ${{ github.ref == 'refs/heads/main' && 'production' || github.ref == 'refs/heads/develop' && 'development' }} | |
steps: | |
- name: Checkout code | |
uses: actions/[email protected] | |
# Logs in with your Azure credentials | |
- name: Azure Login | |
uses: Azure/[email protected] | |
with: | |
creds: ${{ secrets.AZURE_CREDENTIALS }} | |
# Use kubelogin to configure your kubeconfig for Azure auth | |
- name: Set up kubelogin for non-interactive login | |
uses: azure/use-kubelogin@v1 | |
with: | |
kubelogin-version: 'v0.0.25' | |
# Retrieves your Azure Kubernetes Service cluster's kubeconfig file | |
- name: Get K8s context | |
uses: azure/aks-set-context@v3 | |
with: | |
resource-group: ${{ vars.RESOURCE_GROUP }} | |
cluster-name: ${{ vars.CLUSTER_NAME }} | |
admin: 'false' | |
use-kubelogin: 'true' | |
- name: Set Environment Variables Based on Branch | |
run: | | |
echo "DOCKER_IMAGE=${{ vars.ACR }}/web-${{ vars.ENV }}" >> $GITHUB_ENV | |
- name: Deploy Helm | |
run: | | |
helm upgrade --install web devops/helm \ | |
--namespace ${{ vars.K8S_NAMESPACE }} \ | |
--values devops/helm/env/${{ vars.VALUES_FILE }} \ | |
--set image.repository=${{ env.DOCKER_IMAGE }} \ | |
--set image.tag=$GITHUB_SHA \ | |
--set imageCredentials.username=${{ secrets.ACR_USERNAME }} \ | |
--set imageCredentials.password=${{ secrets.ACR_PASSWORD }} \ | |
--atomic --timeout 5m0s |