Earthfile 6.33 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# SPDX-FileCopyrightText: Copyright (c) 2024-2025 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
# SPDX-License-Identifier: Apache-2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

VERSION 0.8

############### ARTIFACTS TARGETS ##############################
# These targets are invoked in child Earthfiles to pass top-level files that are out of their build context
# https://docs.earthly.dev/earthly-0.6/best-practices#copying-files-from-outside-the-build-context

############### SHARED LIBRARY TARGETS ##############################
golang-base:
24
25
    FROM golang:1.24
    RUN apt-get update && apt-get install -y git && apt-get clean && rm -rf /var/lib/apt/lists/* && go install github.com/golangci/golangci-lint/cmd/golangci-lint@v1.64.8
26

27
28
operator-src:
    FROM +golang-base
29
    COPY ./deploy/cloud/operator /artifacts/operator
30
31
    SAVE ARTIFACT /artifacts/operator

32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70

# artifact-base:
#     FROM python:3.12-slim-bookworm
#     WORKDIR /artifacts

# dynamo-source-artifacts:
#     FROM +artifact-base
#     COPY . /artifacts
#     SAVE ARTIFACT /artifacts

uv-source:
    FROM ghcr.io/astral-sh/uv:latest
    SAVE ARTIFACT /uv

dynamo-base:
    FROM ubuntu:24.04
    RUN apt-get update && \
        DEBIAN_FRONTEND=noninteractive apt-get install -yq python3-dev python3-pip python3-venv libucx0 curl
    COPY +uv-source/uv /bin/uv
    ENV CARGO_BUILD_JOBS=16

    RUN mkdir /opt/dynamo && \
        uv venv /opt/dynamo/venv --python 3.12 && \
        . /opt/dynamo/venv/bin/activate && \
        uv pip install pip

    ENV VIRTUAL_ENV=/opt/dynamo/venv
    ENV PATH="${VIRTUAL_ENV}/bin:${PATH}"

rust-base:
    FROM +dynamo-base
    # Rust build/dev dependencies
    RUN apt update -y && \
        apt install --no-install-recommends -y \
        wget \
        build-essential \
        protobuf-compiler \
        cmake \
        libssl-dev \
71
72
73
        pkg-config \
        libclang-dev \
        git
74

75
76
77
    RUN wget https://developer.download.nvidia.com/compute/cuda/repos/ubuntu2404/x86_64/cuda-keyring_1.1-1_all.deb && \
        apt install -y ./cuda-keyring_1.1-1_all.deb && \
        apt update && \
hhzhang16's avatar
hhzhang16 committed
78
        apt install -y cuda-toolkit-12-8 nvidia-utils-535 nvidia-driver-535 && \
79
80
81
82
83
        rm cuda-keyring_1.1-1_all.deb

    # Set CUDA compute capability explicitly
    ENV CUDA_COMPUTE_CAP=80

hhzhang16's avatar
hhzhang16 committed
84
85
86
87
88
89
    ENV CUDA_HOME=/usr/local/cuda-12.8
    ENV CUDA_ROOT=/usr/local/cuda-12.8
    ENV CUDA_PATH=/usr/local/cuda-12.8
    ENV CUDA_TOOLKIT_ROOT_DIR=/usr/local/cuda-12.8
    ENV PATH=/usr/local/cuda-12.8/bin:$PATH
    ENV LD_LIBRARY_PATH=/usr/local/cuda-12.8/lib64:$LD_LIBRARY_PATH
90

91
92
93
    ENV RUSTUP_HOME=/usr/local/rustup
    ENV CARGO_HOME=/usr/local/cargo
    ENV PATH=/usr/local/cargo/bin:$PATH
94
    ENV RUST_VERSION=1.87.0
95
96
97
98
99
    ENV RUSTARCH=x86_64-unknown-linux-gnu

    RUN wget --tries=3 --waitretry=5 "https://static.rust-lang.org/rustup/archive/1.28.1/x86_64-unknown-linux-gnu/rustup-init" && \
        echo "a3339fb004c3d0bb9862ba0bce001861fe5cbde9c10d16591eb3f39ee6cd3e7f *rustup-init" | sha256sum -c - && \
        chmod +x rustup-init && \
100
        ./rustup-init -y --no-modify-path --profile minimal --default-toolchain 1.87.0 --default-host x86_64-unknown-linux-gnu && \
101
102
103
        rm rustup-init && \
        chmod -R a+w $RUSTUP_HOME $CARGO_HOME

104
dynamo-build:
105
106
    FROM +rust-base
    WORKDIR /workspace
107
108
109
110
111
112
113
    COPY Cargo.toml Cargo.lock ./
    COPY pyproject.toml README.md hatch_build.py ./
    COPY components/ components/
    COPY lib/ lib/
    COPY launch/ launch/
    COPY deploy/ deploy/

114
    ENV CARGO_TARGET_DIR=/workspace/target
115
    RUN cargo build --release --locked --features llamacpp,cuda && \
116
117
118
        cargo doc --no-deps

    # Create symlinks for wheel building
119
    RUN mkdir -p /workspace/deploy/sdk/src/dynamo/sdk/cli/bin/ && \
120
        # Remove existing symlinks
121
        rm -f /workspace/deploy/sdk/src/dynamo/sdk/cli/bin/* && \
122
        # Create new symlinks pointing to the correct location
123
        ln -sf /workspace/target/release/dynamo-run /workspace/deploy/sdk/src/dynamo/sdk/cli/bin/dynamo-run
124
125


126
127
128
129
130
131
132
133
    RUN cd /workspace/lib/bindings/python && \
        uv build --wheel --out-dir /workspace/dist --python 3.12
    RUN cd /workspace && \
        uv build --wheel --out-dir /workspace/dist

    # Save wheels
    SAVE ARTIFACT /workspace/dist/ai_dynamo_runtime*.whl
    SAVE ARTIFACT /workspace/dist/ai_dynamo*.whl
134
135
136

dynamo-base-docker:
    ARG IMAGE=dynamo-base-docker
137
138
    ARG DOCKER_SERVER=my-registry
    ARG IMAGE_TAG=latest
139
140

    FROM ubuntu:24.04
141
    WORKDIR /workspace
142
    COPY container/deps/requirements.txt /tmp/requirements.txt
143

144
145
146
147
148
149
150
151
152
153
154
155
156
157
    # Install Python and other dependencies
    RUN apt-get update && \
        apt-get install -y --no-install-recommends \
        python3.12 \
        curl && \
        rm -rf /var/lib/apt/lists/*

    COPY +uv-source/uv /bin/uv

    # Create and activate virtual environment
    RUN mkdir -p /opt/dynamo && \
        uv venv /opt/dynamo/venv --python 3.12 && \
        . /opt/dynamo/venv/bin/activate && \
        uv pip install pip
158

159
160
161
    ENV VIRTUAL_ENV=/opt/dynamo/venv
    ENV PATH="${VIRTUAL_ENV}/bin:${PATH}"

162
163
    RUN uv pip install -r /tmp/requirements.txt

164
165
166
167
168
169
170
    # Copy and install wheels -- ai-dynamo-runtime first, then ai-dynamo
    COPY +dynamo-build/ai_dynamo_runtime*.whl /tmp/wheels/
    COPY +dynamo-build/ai_dynamo*.whl /tmp/wheels/
    RUN . /opt/dynamo/venv/bin/activate && \
        uv pip install /tmp/wheels/*.whl && \
        rm -rf /tmp/wheels

171
    SAVE IMAGE --push $DOCKER_SERVER/$IMAGE:$IMAGE_TAG
172

173
174
############### ALL TARGETS ##############################
all-test:
175
    BUILD ./deploy/cloud/operator+test
176
177

all-docker:
178
179
    ARG DOCKER_SERVER=my-registry
    ARG IMAGE_TAG=latest
180
    BUILD ./deploy/cloud/operator+docker --DOCKER_SERVER=$DOCKER_SERVER --IMAGE_TAG=$IMAGE_TAG
181
182

all-lint:
183
    BUILD ./deploy/cloud/operator+lint
184
185
186
187
188
189
190
191

all:
    BUILD +all-test
    BUILD +all-docker
    BUILD +all-lint

# For testing
custom:
192
193
    ARG DOCKER_SERVER=my-registry
    ARG IMAGE_TAG=latest
194
    BUILD +all-test