| name: Release Docker Images (NPU) |
| on: |
| push: |
| tags: |
| - 'v[0-9]+.*' |
| workflow_dispatch: |
| inputs: |
| version: |
| description: 'Version to build (without v prefix, e.g., 0.5.7)' |
| required: true |
|
|
| jobs: |
| build: |
| runs-on: ubuntu-22.04-arm |
| strategy: |
| matrix: |
| cann_version: ["8.5.0"] |
| device_type: ["910b", "a3"] |
| steps: |
| - name: Checkout repository |
| uses: actions/checkout@v4 |
|
|
| - name: Free up disk space |
| uses: jlumbroso/free-disk-space@54081f138730dfa15788a46383842cd2f914a1be |
| with: |
| tool-cache: true |
| docker-images: false |
|
|
| |
| - name: Docker meta |
| id: meta |
| uses: docker/metadata-action@v5 |
| with: |
| images: | |
| lmsysorg/sglang |
| tags: | |
| type=ref,event=pr |
| flavor: | |
| latest=false |
| |
| |
| |
| - name: Login to Docker Hub |
| uses: docker/login-action@v2 |
| if: ${{ github.repository == 'sgl-project/sglang' && github.event_name != 'pull_request' }} |
| with: |
| username: ${{ secrets.DOCKERHUB_USERNAME }} |
| password: ${{ secrets.DOCKERHUB_TOKEN }} |
|
|
| - name: Get version from tag |
| id: version |
| run: | |
| if [ "${{ github.event_name }}" = "workflow_dispatch" ]; then |
| VERSION="${{ github.event.inputs.version }}" |
| else |
| # Extract version from tag (e.g., v0.5.7 -> 0.5.7) |
| VERSION="${GITHUB_REF_NAME#v}" |
| fi |
| # Validate version format |
| if [ -z "$VERSION" ]; then |
| echo "::error::Version is empty" |
| exit 1 |
| fi |
| if ! echo "$VERSION" | grep -qE '^[0-9]+\.[0-9]+\.[0-9]+'; then |
| echo "::error::Invalid version format: $VERSION (expected: X.Y.Z)" |
| exit 1 |
| fi |
| echo "version=v${VERSION}" >> $GITHUB_OUTPUT |
| echo "TAG=lmsysorg/sglang:v${VERSION}-cann${{ matrix.cann_version }}-${{ matrix.device_type }}" >> $GITHUB_OUTPUT |
| |
| |
| - name: Set up QEMU |
| uses: docker/setup-qemu-action@v3 |
| |
| - name: Set up Docker Buildx |
| uses: docker/setup-buildx-action@v3 |
|
|
| - name: Build and push Docker image |
| id: build-and-push |
| uses: docker/build-push-action@v6 |
| with: |
| context: docker |
| file: docker/npu.Dockerfile |
| platforms: linux/arm64,linux/amd64 |
| labels: ${{ steps.meta.outputs.labels }} |
| tags: ${{ steps.meta.outputs.tags || steps.version.outputs.TAG }} |
| push: ${{ github.repository == 'sgl-project/sglang' && github.event_name != 'pull_request' }} |
| provenance: false |
| build-args: | |
| SGLANG_KERNEL_NPU_TAG=2026.02.01.post2 |
| CANN_VERSION=${{ matrix.cann_version }} |
| DEVICE_TYPE=${{ matrix.device_type }} |
| SGLANG_TAG=${{ steps.version.outputs.version }} |
| |