Run a CI/CD workflow with a Databricks Asset Bundle and GitHub Actions (2024)

  • Documentation
  • Develop on Databricks
  • Developer tools and guidance
  • What are Databricks Asset Bundles?
  • Run a CI/CD workflow with a Databricks Asset Bundle and GitHub Actions

This article describes how to run a CI/CD (continuous integration/continuous deployment) workflow in GitHub with GitHub Actions and a Databricks Asset Bundle. See What are Databricks Asset Bundles?

You can use GitHub Actions along with Databricks CLI bundle commands to automate, customize, and run your CI/CD workflows from within your GitHub repositories.

You can add GitHub Actions YAML files such as the following to your repo’s .github/workflows directory. The following example GitHub Actions YAML file validates, deploys, and runs the specified job in the bundle within a pre-production target named “qa” as defined within a bundle configuration file. This example GitHub Actions YAML file relies on the following:

  • A bundle configuration file at the root of the repository, which is explicitly declared through the GitHub Actions YAML file’s setting working-directory: . (This setting can be omitted if the bundle configuration file is already at the root of the repository.) This bundle configuration file defines a Databricks workflow named my-job and a target named qa. See Databricks Asset Bundle configurations.

  • A GitHub secret named SP_TOKEN, representing the Databricks access token for a Databricks service principal that is associated with the Databricks workspace to which this bundle is being deployed and run. See Encrypted secrets.

# This workflow validates, deploys, and runs the specified bundle# within a pre-production target named "qa".name: "QA deployment"# Ensure that only a single job or workflow using the same concurrency group# runs at a time.concurrency: 1# Trigger this workflow whenever a pull request is opened against the repo's# main branch or an existing pull request's head branch is updated.on: pull_request: types: - opened - synchronize branches: - mainjobs: # Used by the "pipeline_update" job to deploy the bundle. # Bundle validation is automatically performed as part of this deployment. # If validation fails, this workflow fails. deploy: name: "Deploy bundle" runs-on: ubuntu-latest steps: # Check out this repo, so that this workflow can access it. - uses: actions/checkout@v3 # Download the Databricks CLI. # See https://github.com/databricks/setup-cli - uses: databricks/setup-cli@main # Deploy the bundle to the "qa" target as defined # in the bundle's settings file. - run: databricks bundle deploy working-directory: . env: DATABRICKS_TOKEN: ${{ secrets.SP_TOKEN }} DATABRICKS_BUNDLE_ENV: qa # Validate, deploy, and then run the bundle. pipeline_update: name: "Run pipeline update" runs-on: ubuntu-latest # Run the "deploy" job first. needs: - deploy steps: # Check out this repo, so that this workflow can access it. - uses: actions/checkout@v3 # Use the downloaded Databricks CLI. - uses: databricks/setup-cli@main # Run the Databricks workflow named "my-job" as defined in the # bundle that was just deployed. - run: databricks bundle run my-job --refresh-all working-directory: . env: DATABRICKS_TOKEN: ${{ secrets.SP_TOKEN }} DATABRICKS_BUNDLE_ENV: qa

The following GitHub Actions YAML file can exist in the same repo as the preceding file. This file validates, deploys, and runs the specified bundle within a production target named “prod” as defined within a bundle configuration file. This example GitHub Actions YAML file relies on the following:

  • A bundle configuration file at the root of the repository, which is explicitly declared through the GitHub Actions YAML file’s setting working-directory: . (This setting can be omitted if the bundle configuration file is already at the root of the repository.). This bundle configuration file defines a Databricks workflow named my-job and a target named prod. See Databricks Asset Bundle configurations.

  • A GitHub secret named SP_TOKEN, representing the Databricks access token for a Databricks service principal that is associated with the Databricks workspace to which this bundle is being deployed and run. See Encrypted secrets.

# This workflow validates, deploys, and runs the specified bundle# within a production target named "prod".name: "Production deployment"# Ensure that only a single job or workflow using the same concurrency group# runs at a time.concurrency: 1# Trigger this workflow whenever a pull request is pushed to the repo's# main branch.on: push: branches: - mainjobs: deploy: name: "Deploy bundle" runs-on: ubuntu-latest steps: # Check out this repo, so that this workflow can access it. - uses: actions/checkout@v3 # Download the Databricks CLI. # See https://github.com/databricks/setup-cli - uses: databricks/setup-cli@main # Deploy the bundle to the "prod" target as defined # in the bundle's settings file. - run: databricks bundle deploy working-directory: . env: DATABRICKS_TOKEN: ${{ secrets.SP_TOKEN }} DATABRICKS_BUNDLE_ENV: prod # Validate, deploy, and then run the bundle. pipeline_update: name: "Run pipeline update" runs-on: ubuntu-latest # Run the "deploy" job first. needs: - deploy steps: # Check out this repo, so that this workflow can access it. - uses: actions/checkout@v3 # Use the downloaded Databricks CLI. - uses: databricks/setup-cli@main # Run the Databricks workflow named "my-job" as defined in the # bundle that was just deployed. - run: databricks bundle run my-job --refresh-all working-directory: . env: DATABRICKS_TOKEN: ${{ secrets.SP_TOKEN }} DATABRICKS_BUNDLE_ENV: prod
Run a CI/CD workflow with a Databricks Asset Bundle and GitHub Actions (2024)

FAQs

How do I build a CI CD pipeline with GitHub Actions? ›

To implement a CI/CD pipeline using GitHub Actions, create a . github/workflows directory in your repository, add a YAML workflow file defining the build, test, and deploy steps, configure any necessary secrets in the repository settings, and push the changes to trigger the workflow.

How to implement a CI CD workflow for iOS using GitHub Actions? ›

Okay, let's do this.
  1. Step 1: Create or choose a repository, and pick a project. ...
  2. Step 2: Open GitHub Actions in your repository to start building your CI/CD workflow. ...
  3. Step 3: Make changes to your code to trigger your CI/CD pipeline.
Jul 23, 2024

Is GitHub a CICD workflow? ›

GitHub Actions is a continuous integration and continuous delivery (CI/CD) platform that allows you to automate your build, test, and deployment pipeline. You can create workflows that build and test every pull request to your repository, or deploy merged pull requests to production.

What is the difference between GitHub Actions and GitHub workflow? ›

GitHub Actions helps you automate your software development workflows from within GitHub. You can deploy workflows in the same place where you store code and collaborate on pull requests and issues. In GitHub Actions, a workflow is an automated process that you set up in your GitHub repository.

How do I create a CI CD pipeline in Jenkins with GitHub? ›

Configure Jenkins Job:
  1. Create a new Jenkins job or edit an existing one.
  2. In the pipeline definition, choose "Pipeline script from SCM" or a similar option.
  3. Select "Git" (1) as the SCM type and provide your GitHub repository URL.
  4. Specify the branch or branches you want to monitor for changes.
Apr 17, 2024

Can GitHub be used to perform CI CD? ›

Compared with other automation or CI/CD tools, GitHub Actions offers native capabilities right in your GitHub flow. It also makes it easy to leverage any of the 10,000+ pre-written and tested automations and CI/CD actions in the GitHub Marketplace as well as the ability to write your own with easy-to-use YAML files.

How do I trigger Jenkins pipeline from GitHub Actions? ›

Trigger jenkins job action
  1. Required The name of the jenkins user that will trigger the Jenkins job (The user must have the neccessary permissions).
  2. Required Jenkins API token. ...
  3. Important JENKINS_USER and JENKINS_TOKEN should be declared in repository secrets for security purposes. ...
  4. Required Jenkins base url.

How to automate CI CD pipeline? ›

Ready to implement a CI/CD pipeline?
  1. Create a free Semaphore account.
  2. Select a Git repository that you have access to.
  3. Commit and push an example pipeline.
  4. Take the guided tour and learn from many tutorials and example projects in Semaphore documentation.
May 21, 2024

How to create CI CD pipeline in Jenkins step by step? ›

Tutorial: How to Create a CI/CD Pipeline with Jenkins
  1. Step 1: Download and Install Jenkins. The first step is to download and install Jenkins on your local machine. ...
  2. Step 2: Start and Configure Jenkins. ...
  3. Step 3: Create CI/CD Pipeline in Jenkins.

What is the difference between GitHub CI CD and actions? ›

Both GitLab CI/CD and GitHub Actions allow you to run workflows at a specific interval. In GitLab CI/CD, pipeline schedules are configured with the UI, while in GitHub Actions you can trigger a workflow on a scheduled interval with the "on" key.

How to run a workflow in GitHub? ›

Running a workflow
  1. On GitHub.com, navigate to the main page of the repository.
  2. Under your repository name, click Actions.
  3. In the left sidebar, click the name of the workflow you want to run.
  4. Above the list of workflow runs, click the Run workflow button.

What is the difference between GitHub Actions CI CD and Jenkins? ›

GitHub Actions and Jenkins can be used together. While they are independent CI/CD tools, teams often leverage them in a complementary manner. Jenkins can handle complex, customized pipelines, while GitHub Actions provides seamless integration with GitHub repositories, allowing for a unified CI/CD workflow.

What are the two types of actions in GitHub Actions? ›

Types of actions. You can build Docker container, JavaScript, and composite actions. Actions require a metadata file to define the inputs, outputs and main entrypoint for your action. The metadata filename must be either action.

What triggers GitHub Actions workflow? ›

This example uses the push event, so a workflow run is triggered every time someone pushes a change to the repository or merges a pull request. This is triggered by a push to every branch; for examples of syntax that runs only on pushes to specific branches, paths, or tags, see "Workflow syntax for GitHub Actions."

Is GitHub Actions better than Azure DevOps? ›

GitHub is suitable for smaller projects and open-source collaborations, whereas Azure DevOps is more suitable for large-scale enterprise development.

What is the difference between GitLab CI CD pipeline and GitHub Actions? ›

Usability and configuration: GitLab CI/CD offers a visual editor out-of-the-box for basic workflows, but complex configurations require YAML code. GitHub Actions primarily uses YAML, and the thriving community offers prebuilt workflows and tools to simplify configuration.

Why are GitHub Actions better than Jenkins? ›

Jenkins deployments generally involve self-hosting, where the users oversee servers in their data centers. On the other hand, GitHub Actions uses a hybrid cloud strategy. It hosts its own job runners and also lets users host their own job runners. Find out more about runners who are on their own.

Top Articles
Orlando Police Department
Ruins of Xadaron - Corruption of Champions II
SZA: Weinen und töten und alles dazwischen
Senior Tax Analyst Vs Master Tax Advisor
Pj Ferry Schedule
Remnant Graveyard Elf
Bme Flowchart Psu
DIN 41612 - FCI - PDF Catalogs | Technical Documentation
Craigslist Farm And Garden Tallahassee Florida
No Hard Feelings Showtimes Near Cinemark At Harlingen
Christina Khalil Forum
Games Like Mythic Manor
Cvb Location Code Lookup
Craigslist Panama City Fl
Hocus Pocus Showtimes Near Amstar Cinema 16 - Macon
Watch The Lovely Bones Online Free 123Movies
Webcentral Cuny
Kirksey's Mortuary - Birmingham - Alabama - Funeral Homes | Tribute Archive
Asteroid City Showtimes Near Violet Crown Charlottesville
Mythical Escapee Of Crete
Boise Craigslist Cars And Trucks - By Owner
Sorrento Gourmet Pizza Goshen Photos
Royalfh Obituaries Home
Nearest Ups Ground Drop Off
Roseann Marie Messina · 15800 Detroit Ave, Suite D, Lakewood, OH 44107-3748 · Lay Midwife
Meggen Nut
Mawal Gameroom Download
Dailymotion
Warren County Skyward
2012 Street Glide Blue Book Value
Bimmerpost version for Porsche forum?
D3 Boards
Otter Bustr
Stanford Medicine scientists pinpoint COVID-19 virus’s entry and exit ports inside our noses
Tiny Pains When Giving Blood Nyt Crossword
Insideaveritt/Myportal
Linda Sublette Actress
Carroll White Remc Outage Map
11 Best Hotels in Cologne (Köln), Germany in 2024 - My Germany Vacation
R: Getting Help with R
✨ Flysheet for Alpha Wall Tent, Guy Ropes, D-Ring, Metal Runner & Stakes Included for Hunting, Family Camping & Outdoor Activities (12'x14', PE) — 🛍️ The Retail Market
Swsnj Warehousing Inc
25 Hotels TRULY CLOSEST to Woollett Aquatics Center, Irvine, CA
Www Pig11 Net
Blippi Park Carlsbad
SF bay area cars & trucks "chevrolet 50" - craigslist
Fallout 76 Fox Locations
Goosetown Communications Guilford Ct
Publix Store 840
Helpers Needed At Once Bug Fables
BYU Football: Instant Observations From Blowout Win At Wyoming
Latest Posts
Article information

Author: Tish Haag

Last Updated:

Views: 6649

Rating: 4.7 / 5 (47 voted)

Reviews: 86% of readers found this page helpful

Author information

Name: Tish Haag

Birthday: 1999-11-18

Address: 30256 Tara Expressway, Kutchburgh, VT 92892-0078

Phone: +4215847628708

Job: Internal Consulting Engineer

Hobby: Roller skating, Roller skating, Kayaking, Flying, Graffiti, Ghost hunting, scrapbook

Introduction: My name is Tish Haag, I am a excited, delightful, curious, beautiful, agreeable, enchanting, fancy person who loves writing and wants to share my knowledge and understanding with you.