| ARG GCC_VERSION=15.2.0
|
| ARG UBUNTU_VERSION=24.04
|
|
|
|
|
| FROM gcc:${GCC_VERSION} AS build
|
|
|
| RUN --mount=type=cache,target=/var/cache/apt,sharing=locked \
|
| --mount=type=cache,target=/var/lib/apt/lists,sharing=locked \
|
| apt update -y && \
|
| apt upgrade -y && \
|
| apt install -y --no-install-recommends \
|
| git cmake ccache ninja-build \
|
|
|
| libopenblas-dev libssl-dev && \
|
| rm -rf /var/lib/apt/lists/*
|
|
|
| WORKDIR /app
|
| COPY . .
|
|
|
| RUN --mount=type=cache,target=/root/.ccache \
|
| --mount=type=cache,target=/app/build \
|
| cmake -S . -B build -G Ninja \
|
| -DCMAKE_BUILD_TYPE=Release \
|
| -DCMAKE_C_COMPILER_LAUNCHER=ccache \
|
| -DCMAKE_CXX_COMPILER_LAUNCHER=ccache \
|
| -DLLAMA_BUILD_TESTS=OFF \
|
| -DGGML_NATIVE=OFF \
|
| -DGGML_BACKEND_DL=ON \
|
| -DGGML_CPU_ALL_VARIANTS=ON \
|
| -DGGML_BLAS=ON \
|
| -DGGML_BLAS_VENDOR=OpenBLAS && \
|
| cmake --build build --config Release -j $(nproc) && \
|
| cmake --install build --prefix /opt/llama.cpp
|
|
|
| COPY *.py /opt/llama.cpp/bin
|
| COPY .devops/tools.sh /opt/llama.cpp/bin
|
|
|
| COPY gguf-py /opt/llama.cpp/gguf-py
|
| COPY requirements.txt /opt/llama.cpp/gguf-py
|
| COPY requirements /opt/llama.cpp/gguf-py/requirements
|
|
|
|
|
|
|
| FROM scratch AS collector
|
|
|
|
|
| COPY --from=build /opt/llama.cpp/bin /llama.cpp/bin
|
| COPY --from=build /opt/llama.cpp/lib /llama.cpp/lib
|
| COPY --from=build /opt/llama.cpp/gguf-py /llama.cpp/gguf-py
|
|
|
|
|
|
|
| FROM ubuntu:${UBUNTU_VERSION} AS base
|
|
|
| RUN --mount=type=cache,target=/var/cache/apt,sharing=locked \
|
| --mount=type=cache,target=/var/lib/apt/lists,sharing=locked \
|
| apt update -y && \
|
| apt install -y --no-install-recommends \
|
|
|
|
|
| curl libgomp1 libopenblas-dev && \
|
| apt autoremove -y && \
|
| apt clean -y && \
|
| rm -rf /tmp/* /var/tmp/* && \
|
| find /var/cache/apt/archives /var/lib/apt/lists -not -name lock -type f -delete && \
|
| find /var/cache -type f -delete
|
|
|
|
|
| COPY --from=collector /llama.cpp/lib /usr/lib/s390x-linux-gnu
|
|
|
|
|
|
|
| FROM base AS full
|
|
|
| ENV PATH="/root/.cargo/bin:${PATH}"
|
| WORKDIR /app
|
|
|
| RUN --mount=type=cache,target=/var/cache/apt,sharing=locked \
|
| --mount=type=cache,target=/var/lib/apt/lists,sharing=locked \
|
| apt update -y && \
|
| apt install -y \
|
| git cmake libjpeg-dev \
|
| python3 python3-pip python3-dev && \
|
| apt autoremove -y && \
|
| apt clean -y && \
|
| rm -rf /tmp/* /var/tmp/* && \
|
| find /var/cache/apt/archives /var/lib/apt/lists -not -name lock -type f -delete && \
|
| find /var/cache -type f -delete
|
|
|
| RUN curl https://sh.rustup.rs -sSf | bash -s -- -y
|
|
|
| COPY --from=collector /llama.cpp/bin /app
|
| COPY --from=collector /llama.cpp/gguf-py /app/gguf-py
|
|
|
| RUN pip install --no-cache-dir --break-system-packages \
|
| -r /app/gguf-py/requirements.txt
|
|
|
| ENTRYPOINT [ "/app/tools.sh" ]
|
|
|
|
|
|
|
| FROM base AS light
|
|
|
| WORKDIR /llama.cpp/bin
|
|
|
|
|
| COPY --from=collector /llama.cpp/bin/*.so /llama.cpp/bin
|
| COPY --from=collector /llama.cpp/bin/llama-cli /llama.cpp/bin/llama-completion /llama.cpp/bin
|
|
|
| ENTRYPOINT [ "/llama.cpp/bin/llama-cli" ]
|
|
|
|
|
|
|
| FROM base AS server
|
|
|
| ENV LLAMA_ARG_HOST=0.0.0.0
|
|
|
| WORKDIR /llama.cpp/bin
|
|
|
|
|
| COPY --from=collector /llama.cpp/bin/*.so /llama.cpp/bin
|
| COPY --from=collector /llama.cpp/bin/llama-server /llama.cpp/bin
|
|
|
| EXPOSE 8080
|
|
|
| ENTRYPOINT [ "/llama.cpp/bin/llama-server" ]
|
|
|