livebook/docs/teams/deploy_via_cli.md
2025-08-07 16:25:53 -03:00

4.4 KiB

Deploy Livebook Apps via CLI

Livebook provides a way to deploy Livebook apps via a CLI command to your deployment group's app servers.

This is particularly useful for automating deployments in CI/CD pipelines.

Deploying via CLI is as simple as calling livebook deploy with your configurations:

livebook deploy
  --deploy-key="lb_dk_your_deploy_key_here"
  --teams-key="lb_tk_your_teams_key_here"
  --deployment-group-id="13"
  path/to/notebook.livemd

Livebook version requirement {: .info}

Requires Livebook v0.17 or newer.

Overview

CLI deployment enables you to:

  • Deploy Livebook apps from the command line
  • Automate app deployments in CI/CD pipelines
  • Deploy single or multiple notebooks

Prerequisites

Before using CLI deployment, ensure you have:

  1. A configured deployment group in your Livebook Teams organization
  2. Deploy and Teams keys from your Livebook Teams organization
  3. Elixir installed on the machine where deployment will be performed
  4. Livebook CLI v0.17 or newer installed via mix escript.install hex livebook

Authentication

CLI deployment requires two authentication tokens:

Deploy key

Deploy keys are organization-level authentication tokens that allow CLI access for deployments.

To create a deploy key, follow these steps:

  1. Log in to Livebook Teams
  2. Navigate to your organization
  3. Go to the Deploy keys page in the menu
  4. Click the Create deploy key button
  5. Provide a descriptive name (e.g., "CI/CD Pipeline" or "Local CLI") and copy the generated key

Teams key

Each organization has a unique Teams key available in the local Livebook of each member of the organization.

To get the Teams key of your organization, follow these steps:

  1. Open Livebook
  2. Navigate to your Teams workspace in the sidebar
  3. Click on "Display Teams key" at the top, and copy your Teams key

Usage

Deploying a single app

Deploy a single notebook:

livebook deploy \
  --deploy-key="lb_dk_..." \
  --teams-key="lb_tk_..." \
  --deployment-group-id="17" \
  path/to/notebook.livemd

Deploying multiple apps at once

Deploy multiple notebooks:

livebook deploy \
  --deploy-key="lb_dk_..." \
  --teams-key="lb_tk_..." \
  --deployment-group-id="13" \
  app1.livemd app2.livemd app3.livemd

Use glob patterns for convenience:

livebook deploy \
  --deploy-key="lb_dk_..." \
  --teams-key="lb_tk_..." \
  --deployment-group-id="7" \
  notebooks/*.livemd

Available options

  • --deploy-key: A deploy key from your Livebook Teams organization (required)
  • --teams-key: Teams key from your Teams organization (required)
  • --deployment-group-id: ID of the target deployment group (required)

CI/CD integration

CLI deployment integrates seamlessly with automated workflows. Here's a GitHub Actions example:

name: Deploy Livebook Apps
on:
  push:
    branches: [main]

jobs:
  deploy:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v4

      # Install Elixir
      - name: Set up Elixir
        uses: erlef/setup-beam@v1
        with:
          elixir-version: '1.18.3'
          otp-version: '27.3.4.1'

      # Install Livebook CLI
      - name: Install Livebook
        run:
          mix escript.install hex livebook --force

      # Uses Livebook CLI to deploy your notebooks
      - name: Deploy notebooks
        run: |
          livebook deploy \
            --deploy-key="${{ secrets.LIVEBOOK_DEPLOY_KEY }}" \
            --teams-key="${{ secrets.LIVEBOOK_TEAMS_KEY }}" \
            --deployment-group-id="3" \
            ./notebooks/*.livemd

Store your deploy key and teams key as repository secrets for secure access.

FAQ

Do I need a running app server to deploy?

No, you don't need a running app server at deployment time. If your app server isn't running, Livebook Teams will queue the deployment and automatically deploy when the server comes online.

Why am I getting an "invalid notebook stamp" error when deploying?

This error occurs when the notebook you're trying to deploy hasn't been properly stamped. Stamping happens automatically whenever a notebook is saved via Livebook.

Notebook stamping is a security mechanism to ensure only notebooks processed through your team's workspace can be deployed.

To fix this error, open the notebook inside Livebook, make sure it's using your Teams organization workspace, and save the notebook.