Add tracing needed for LLM rate limit dashboards (#16388) #229
Workflow file for this run
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: Publish Collab Server Image | |
on: | |
push: | |
tags: | |
- collab-production | |
- collab-staging | |
env: | |
DOCKER_BUILDKIT: 1 | |
DIGITALOCEAN_ACCESS_TOKEN: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN }} | |
jobs: | |
style: | |
name: Check formatting and Clippy lints | |
runs-on: | |
- self-hosted | |
- test | |
steps: | |
- name: Checkout repo | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
with: | |
clean: false | |
fetch-depth: 0 | |
- name: Run style checks | |
uses: ./.github/actions/check_style | |
- name: Run clippy | |
run: ./script/clippy | |
tests: | |
name: Run tests | |
runs-on: | |
- self-hosted | |
- test | |
needs: style | |
steps: | |
- name: Checkout repo | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
with: | |
clean: false | |
fetch-depth: 0 | |
- name: Install cargo nextest | |
shell: bash -euxo pipefail {0} | |
run: | | |
cargo install cargo-nextest | |
- name: Limit target directory size | |
shell: bash -euxo pipefail {0} | |
run: script/clear-target-dir-if-larger-than 100 | |
- name: Run tests | |
shell: bash -euxo pipefail {0} | |
run: cargo nextest run --package collab --no-fail-fast | |
publish: | |
name: Publish collab server image | |
needs: | |
- style | |
- tests | |
runs-on: | |
- self-hosted | |
- deploy | |
steps: | |
- name: Add Rust to the PATH | |
run: echo "$HOME/.cargo/bin" >> $GITHUB_PATH | |
- name: Sign into DigitalOcean docker registry | |
run: doctl registry login | |
- name: Checkout repo | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4 | |
with: | |
clean: false | |
- name: Set up default .cargo/config.toml | |
run: cp ./.cargo/collab-config.toml ./.cargo/config.toml | |
- name: Build docker image | |
run: docker build . --build-arg GITHUB_SHA=$GITHUB_SHA --tag registry.digitalocean.com/zed/collab:$GITHUB_SHA | |
- name: Publish docker image | |
run: docker push registry.digitalocean.com/zed/collab:${GITHUB_SHA} | |
- name: Prune Docker system | |
run: docker system prune --filter 'until=72h' -f | |
deploy: | |
name: Deploy new server image | |
needs: | |
- publish | |
runs-on: | |
- self-hosted | |
- deploy | |
steps: | |
- name: Sign into Kubernetes | |
run: doctl kubernetes cluster kubeconfig save --expiry-seconds 600 ${{ secrets.CLUSTER_NAME }} | |
- name: Start rollout | |
run: | | |
set -eu | |
if [[ $GITHUB_REF_NAME = "collab-production" ]]; then | |
export ZED_KUBE_NAMESPACE=production | |
export ZED_COLLAB_LOAD_BALANCER_SIZE_UNIT=10 | |
export ZED_API_LOAD_BALANCER_SIZE_UNIT=2 | |
export ZED_LLM_LOAD_BALANCER_SIZE_UNIT=2 | |
elif [[ $GITHUB_REF_NAME = "collab-staging" ]]; then | |
export ZED_KUBE_NAMESPACE=staging | |
export ZED_COLLAB_LOAD_BALANCER_SIZE_UNIT=1 | |
export ZED_API_LOAD_BALANCER_SIZE_UNIT=1 | |
export ZED_LLM_LOAD_BALANCER_SIZE_UNIT=1 | |
else | |
echo "cowardly refusing to deploy from an unknown branch" | |
exit 1 | |
fi | |
echo "Deploying collab:$GITHUB_SHA to $ZED_KUBE_NAMESPACE" | |
source script/lib/deploy-helpers.sh | |
export_vars_for_environment $ZED_KUBE_NAMESPACE | |
export ZED_DO_CERTIFICATE_ID=$(doctl compute certificate list --format ID --no-header) | |
export ZED_IMAGE_ID="registry.digitalocean.com/zed/collab:${GITHUB_SHA}" | |
export ZED_SERVICE_NAME=collab | |
export ZED_LOAD_BALANCER_SIZE_UNIT=$ZED_COLLAB_LOAD_BALANCER_SIZE_UNIT | |
envsubst < crates/collab/k8s/collab.template.yml | kubectl apply -f - | |
kubectl -n "$ZED_KUBE_NAMESPACE" rollout status deployment/$ZED_SERVICE_NAME --watch | |
echo "deployed ${ZED_SERVICE_NAME} to ${ZED_KUBE_NAMESPACE}" | |
export ZED_SERVICE_NAME=api | |
export ZED_LOAD_BALANCER_SIZE_UNIT=$ZED_API_LOAD_BALANCER_SIZE_UNIT | |
envsubst < crates/collab/k8s/collab.template.yml | kubectl apply -f - | |
kubectl -n "$ZED_KUBE_NAMESPACE" rollout status deployment/$ZED_SERVICE_NAME --watch | |
echo "deployed ${ZED_SERVICE_NAME} to ${ZED_KUBE_NAMESPACE}" | |
export ZED_SERVICE_NAME=llm | |
export ZED_LOAD_BALANCER_SIZE_UNIT=$ZED_LLM_LOAD_BALANCER_SIZE_UNIT | |
envsubst < crates/collab/k8s/collab.template.yml | kubectl apply -f - | |
kubectl -n "$ZED_KUBE_NAMESPACE" rollout status deployment/$ZED_SERVICE_NAME --watch | |
echo "deployed ${ZED_SERVICE_NAME} to ${ZED_KUBE_NAMESPACE}" |