From buildkite
This skill should be used when the user asks to "trigger a build", "check build status", "watch a build", "view build logs", "retry a build", "cancel a build", "list builds", "download artifacts", "upload artifacts", "manage secrets", "create a pipeline", "list pipelines", or "interact with Buildkite from the command line". Also use when the user mentions bk commands, bk build, bk job, bk pipeline, bk secret, bk artifact, bk cluster, bk package, bk auth, bk configure, bk use, bk init, bk api, or asks about Buildkite CLI installation, terminal-based Buildkite workflows, or command-line CI/CD operations.
npx claudepluginhub buildkite/skills --plugin buildkiteThis skill uses the workspace's default tool permissions.
The Buildkite CLI (`bk`) provides terminal access to builds, jobs, pipelines, secrets, artifacts, clusters, and packages. Use it to trigger builds, tail logs, manage secrets, and automate CI/CD workflows without leaving the command line.
This skill should be used when the user asks to "call the Buildkite API", "use the REST API", "write a GraphQL query", "set up webhooks", "automate Buildkite", "integrate with Buildkite programmatically", "write a script that calls Buildkite", "handle webhook events", "paginate API results", or "authenticate with the Buildkite API". Also use when the user mentions api.buildkite.com, graphql.buildkite.com, Buildkite REST endpoints, GraphQL mutations, webhook payloads, API tokens, or asks about programmatic access to Buildkite data.
Guides GitLab CI/CD pipeline creation, debugging, and configuration including runners, jobs, stages, artifacts, caches, environments, and deployment automation.
Automates Buildkite CI/CD tasks like pipelines, builds, and agents via Composio toolkit and Rube MCP. Discovers tools dynamically and manages connections for reliable execution.
Share bugs, ideas, or general feedback.
The Buildkite CLI (bk) provides terminal access to builds, jobs, pipelines, secrets, artifacts, clusters, and packages. Use it to trigger builds, tail logs, manage secrets, and automate CI/CD workflows without leaving the command line.
# Install
brew tap buildkite/buildkite && brew install buildkite/buildkite/bk
# Authenticate
bk configure
# Trigger a build on the current branch
bk build create --pipeline my-app
# Watch it run
bk build watch 42 --pipeline my-app
# View logs for a failed job
bk job log <job-id> --pipeline my-app --build 42
brew tap buildkite/buildkite && brew install buildkite/buildkite/bk
For binary downloads, shell completion, and verification, see references/command-reference.md.
Run bk configure to set the organization slug and API access token. This creates $HOME/.config/bk.yaml on first run.
bk configure
# Non-interactive (CI/Docker): bk configure --org my-org --token "$BUILDKITE_API_TOKEN" --no-input
Or use keychain-based auth (v3.31+): bk auth login
read_builds, write_builds, read_pipelines, read_artifacts at minimumbk configureFor the full bk auth subcommand reference and organization switching (bk use), see references/command-reference.md.
Manage pipeline builds — create, view, list, cancel, retry, and watch.
# Build the current branch and commit (pipeline auto-detected from repo)
bk build create
# Explicit pipeline
bk build create --pipeline my-app
# Build with environment variables and metadata
bk build create -e "FOO=BAR" -e "BAR=BAZ"
bk build create --branch feature/auth --commit abc1234 --env "DEPLOY_ENV=staging"
| Flag | Short | Default | Description |
|---|---|---|---|
--pipeline | -p | auto-detected | Pipeline slug; resolved from repo context when omitted |
--branch | -b | current branch | Git branch to build |
--commit | -c | HEAD | Git commit SHA |
--message | -m | — | Build message |
--env | -e | — | Environment variables (repeatable) |
--env-file | -f | — | Load environment variables from a file |
--metadata | -M | — | Build metadata key=value (repeatable) |
bk build view 42 --pipeline my-app
# List recent builds for a pipeline
bk build list --pipeline my-app
# List only failed builds
bk build list --pipeline my-app --state failed
| Flag | Short | Default | Description |
|---|---|---|---|
--pipeline | -p | — | Pipeline slug (omit for org-wide listing) |
--state | -s | — | Filter by state: running, scheduled, passed, failed, blocked, canceled, canceling, skipped, not_run, finished |
--output | -o | text | Output format: text, json |
Stream real-time build progress to the terminal. Blocks until the build completes or is canceled.
bk build watch 42 --pipeline my-app
bk build cancel 42 --pipeline my-app
The build must be in a scheduled, running, or failing state.
bk build retry 42 --pipeline my-app
Combine create and watch for a complete trigger-and-follow workflow:
# Trigger a build and immediately stream progress
bk build create --pipeline my-app --branch main && bk build watch --pipeline my-app
Manage individual jobs within a build — view logs, retry failures, cancel running jobs.
bk job log <job-id> --pipeline my-app --build 42 --follow
| Flag | Short | Default | Description |
|---|---|---|---|
--pipeline | -p | — | Pipeline slug (required) |
--build | -b | — | Build number (required) |
--follow | -f | false | Stream logs in real-time |
Each job ID can only be retried once — subsequent retries must use the new job ID returned by the first retry.
bk job retry <job-id> --pipeline my-app --build 42
bk job cancel <job-id> --pipeline my-app --build 42
# Find failed builds
bk build list --pipeline my-app --state failed
# View the build to identify which jobs failed
bk build view 42 --pipeline my-app
# Read logs for the failed job
bk job log <job-id> --pipeline my-app --build 42
Manage pipeline configuration — list, create, and update pipelines.
For converting pipelines from other CI systems, see the buildkite-migration skill.
Convert a GitHub Actions, Jenkins, CircleCI, Bitbucket, GitLab, Harness, or Bitrise pipeline to Buildkite YAML. No login required — uses a public API.
# Auto-detect vendor from file path and save to .buildkite/pipeline.<vendor>.yml
bk pipeline convert -F .github/workflows/ci.yml
bk pipeline convert -F .circleci/config.yml
bk pipeline convert -F Jenkinsfile
# Specify vendor explicitly (required for gitlab, harness, bitrise)
bk pipeline convert -F .gitlab-ci.yml --vendor gitlab
# Custom output path
bk pipeline convert -F .github/workflows/ci.yml --output .buildkite/pipeline.yml
# Read from stdin
cat .github/workflows/ci.yml | bk pipeline convert --vendor github
| Flag | Short | Default | Description |
|---|---|---|---|
--file | -F | — | Path to source pipeline file (required unless using stdin) |
--vendor | -v | auto-detected | Source CI vendor: github, bitbucket, circleci, jenkins, gitlab, harness, bitrise |
--output | -o | .buildkite/pipeline.<vendor>.yml | Output file path |
--timeout | — | 300 | Cancellation timeout in seconds |
bk pipeline list
bk pipeline create --name "My App" --repository "git@github.com:org/my-app.git"
| Flag | Short | Default | Description |
|---|---|---|---|
--name | -n | — | Pipeline name (required) |
--repository | -r | — | Git repository URL (required) |
--cluster | — | Cluster UUID to assign the pipeline to | |
--description | -d | — | Pipeline description |
For pipeline YAML configuration after creation, see the buildkite-pipelines skill.
bk pipeline update my-app --description "Production application pipeline"
Manage cluster-scoped secrets for pipelines. Secrets are encrypted and accessible to all agents within a cluster.
For using secrets inside pipeline YAML (
secrets:key) and inside job steps (buildkite-agent secret get), see the buildkite-pipelines skill and buildkite-agent-runtime skill respectively.
bk secret create MY_SECRET --cluster my-cluster --value "$TOKEN"
| Flag | Short | Default | Description |
|---|---|---|---|
--cluster | — | Cluster UUID or slug (required) | |
--value | — | Secret value (omit for interactive prompt) | |
--description | -d | — | Human-readable description |
Naming rules:
buildkite or bk (case-insensitive)BUILDKITE_API_TOKEN is allowedbk secret list --cluster my-cluster
bk secret update MY_SECRET --cluster my-cluster --value "$NEW_TOKEN"
bk secret delete MY_SECRET --cluster my-cluster
Upload and download build artifacts from the terminal.
bk artifact download "dist/*.tar.gz" --pipeline my-app --build 42
bk artifact upload "dist/**/*" --pipeline my-app --build 42 --job <job-id>
For uploading artifacts from within a running job step, use
buildkite-agent artifact upload— see the buildkite-agent-runtime skill. For declaring artifact paths in pipeline YAML (artifact_paths:), see the buildkite-pipelines skill.
List and view clusters with bk cluster list and bk cluster view <slug>. For flags and examples, see references/command-reference.md.
For cluster creation, queue management, and infrastructure provisioning, see the buildkite-agent-infrastructure skill.
List registries with bk package list and push packages with bk package push <file> --registry <slug>. For flags and supported formats, see references/command-reference.md.
For OIDC-based authentication to package registries (no static credentials), see the buildkite-secure-delivery skill.
Make direct REST or GraphQL API calls with bk api <path> (REST) or bk api --graphql --data '<query>' (GraphQL). For flags and examples, see references/command-reference.md.
For comprehensive REST and GraphQL API documentation (endpoints, mutations, pagination, webhooks), see the buildkite-api skill.
Invite users with bk user invite user@example.com. See references/command-reference.md for details.
Scaffold a starter pipeline.yaml with bk init. For pipeline YAML syntax and step types, see the buildkite-pipelines skill. See references/command-reference.md for details.
When the Buildkite MCP server is available, agents can use MCP tools for direct access without shell execution. The table below maps CLI commands to their MCP equivalents:
| CLI Command | MCP Tool | Notes |
|---|---|---|
bk build create | create_build | MCP handles auth automatically |
bk build view | get_build | MCP returns structured data |
bk build list | list_builds | MCP supports the same filters |
bk job log | read_logs, tail_logs | MCP supports streaming |
bk pipeline list | list_pipelines | |
bk pipeline create | create_pipeline | |
bk pipeline update | update_pipeline | |
bk artifact download | list_artifacts_for_build, get_artifact | |
bk cluster list | list_clusters | |
bk auth status | current_user, access_token | |
bk secret create/list/delete | — | No MCP equivalent; CLI required |
bk package push | — | No MCP equivalent; CLI required |
bk job retry | — | No MCP equivalent; CLI required |
bk job cancel | — | No MCP equivalent; CLI required |
bk build watch | — | No MCP equivalent; CLI required |
bk api | — | Use MCP tools for read operations; CLI for custom API calls |
When to use CLI vs MCP: Use MCP tools when available — they handle authentication, pagination, and response parsing automatically. Fall back to the CLI when MCP does not cover the operation (secrets, packages, job retry, build watch) or when the agent needs to execute commands in a Bash workflow.
| Mistake | What happens | Fix |
|---|---|---|
Running bk commands before bk configure | Every command fails with authentication errors | Run bk configure or bk auth login first |
Running bk configure in Docker/CI without --no-input | Hangs or fails trying to read from TTY or system keychain | Add --no-input flag: bk configure --org my-org --token "$TOKEN" --no-input |
Omitting --pipeline on build commands | Command fails or targets the wrong pipeline | Always pass --pipeline <slug> explicitly |
| Retrying a job ID that was already retried | API returns 422 error — each job ID can only be retried once | Use the new job ID returned by the first retry |
Creating secrets with keys starting with buildkite or bk | Creation fails — reserved prefix | Choose a different key name (exception: BUILDKITE_API_TOKEN) |
Passing secret values as literal strings in --value | Values persist in shell history and process list | Use env var references (--value "$TOKEN") or interactive prompts |
Using bk build cancel on a completed build | API returns error — only scheduled, running, or failing builds can be canceled | Check build state with bk build view first |
Expecting bk artifact download to work cross-cluster | Artifacts are cluster-scoped by default | Ensure both pipelines are in the same cluster or configure cross-cluster artifact access |
Confusing bk CLI with buildkite-agent | bk runs on local machines to interact with the Buildkite API; buildkite-agent runs inside CI job steps | Use bk from terminal, buildkite-agent inside pipeline step commands |
references/command-reference.md — Full installation methods, auth subcommands, organization switching, and detailed flags/examples for clusters, packages, API access, users, and pipeline initialization