Earthfile 5.44 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
24
25
26
# 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:
    FROM golang:1.23
    RUN apt-get update && apt-get install -y git && apt-get clean && rm -rf /var/lib/apt/lists/* && curl -sSfL https://github.com/golangci/golangci-lint/releases/download/v1.61.0/golangci-lint-1.61.0-linux-amd64.tar.gz | tar -xzv && mv golangci-lint-1.61.0-linux-amd64/golangci-lint /usr/local/bin/

27
28
29
30
31
operator-src:
    FROM +golang-base
    COPY ./deploy/dynamo/operator /artifacts/operator
    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

    ENV RUSTUP_HOME=/usr/local/rustup
    ENV CARGO_HOME=/usr/local/cargo
    ENV PATH=/usr/local/cargo/bin:$PATH
78
    ENV RUST_VERSION=1.86.0
79
80
81
82
83
    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 && \
84
        ./rustup-init -y --no-modify-path --profile minimal --default-toolchain 1.86.0 --default-host x86_64-unknown-linux-gnu && \
85
86
87
        rm rustup-init && \
        chmod -R a+w $RUSTUP_HOME $CARGO_HOME

88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
dynamo-builder:
    FROM +rust-base
    WORKDIR /workspace
    COPY . /workspace/
    ENV CARGO_TARGET_DIR=/workspace/target

    RUN cargo build --release --locked --features mistralrs,sglang,vllm,python && \
        strip target/release/dynamo-run && \
        strip target/release/http && \
        strip target/release/llmctl && \
        strip target/release/metrics && \
        strip target/release/mock_worker

    SAVE ARTIFACT target/release/dynamo-run /dynamo-run
    SAVE ARTIFACT target/release/http /http
    SAVE ARTIFACT target/release/llmctl /llmctl
    SAVE ARTIFACT target/release/metrics /metrics
    SAVE ARTIFACT target/release/mock_worker /mock_worker
106
107
108
109
110

dynamo-base-docker:
    ARG IMAGE=dynamo-base-docker
    ARG CI_REGISTRY_IMAGE=my-registry
    ARG CI_COMMIT_SHA=latest
111
    FROM +dynamo-base
112
113
114
    WORKDIR /workspace
    COPY . /workspace/

115
116
117
118
119
120
121
122
123
124
125
126
    # Copy built binaries from builder target
    COPY +dynamo-builder/dynamo-run /usr/local/bin/dynamo-run
    COPY +dynamo-builder/http /usr/local/bin/http
    COPY +dynamo-builder/llmctl /usr/local/bin/llmctl
    COPY +dynamo-builder/metrics /usr/local/bin/metrics
    COPY +dynamo-builder/mock_worker /usr/local/bin/mock_worker

    COPY +dynamo-builder/dynamo-run /workspace/target/release/dynamo-run
    COPY +dynamo-builder/http /workspace/target/release/http
    COPY +dynamo-builder/llmctl /workspace/target/release/llmctl
    COPY +dynamo-builder/metrics /workspace/target/release/metrics
    COPY +dynamo-builder/mock_worker /workspace/target/release/mock_worker
127
128
129
130
131
132
133

    RUN uv build --wheel --out-dir /workspace/dist && \
        uv pip install /workspace/dist/ai_dynamo*any.whl
    SAVE IMAGE --push $CI_REGISTRY_IMAGE/$IMAGE:$CI_COMMIT_SHA



134
135
############### ALL TARGETS ##############################
all-test:
136
    BUILD ./deploy/dynamo/operator+test
137
138
139
140

all-docker:
    ARG CI_REGISTRY_IMAGE=my-registry
    ARG CI_COMMIT_SHA=latest
141
    BUILD ./deploy/dynamo/operator+docker --CI_REGISTRY_IMAGE=$CI_REGISTRY_IMAGE --CI_COMMIT_SHA=$CI_COMMIT_SHA
142
    BUILD ./deploy/dynamo/api-store+docker --CI_REGISTRY_IMAGE=$CI_REGISTRY_IMAGE --CI_COMMIT_SHA=$CI_COMMIT_SHA
143
144

all-lint:
145
    BUILD ./deploy/dynamo/operator+lint
146
147
148
149
150
151
152
153
154
155
156

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

# For testing
custom:
    ARG CI_REGISTRY_IMAGE=my-registry
    ARG CI_COMMIT_SHA=latest
    BUILD +all-test