llama-server-intel.Dockerfile 900 Bytes
Newer Older
wangkx1's avatar
init  
wangkx1 committed
1
2
ARG ONEAPI_VERSION=2024.1.1-devel-ubuntu22.04

wangkx1's avatar
wangkx1 committed
3
FROM intel/oneapi-basekit:$ONEAPI_VERSION AS build
wangkx1's avatar
init  
wangkx1 committed
4

wangkx1's avatar
wangkx1 committed
5
ARG GGML_SYCL_F16=OFF
wangkx1's avatar
init  
wangkx1 committed
6
7
8
9
10
11
12
RUN apt-get update && \
    apt-get install -y git libcurl4-openssl-dev

WORKDIR /app

COPY . .

wangkx1's avatar
wangkx1 committed
13
14
15
RUN if [ "${GGML_SYCL_F16}" = "ON" ]; then \
        echo "GGML_SYCL_F16 is set" && \
        export OPT_SYCL_F16="-DGGML_SYCL_F16=ON"; \
wangkx1's avatar
init  
wangkx1 committed
16
    fi && \
wangkx1's avatar
wangkx1 committed
17
18
    echo "Building with dynamic libs" && \
    cmake -B build -DGGML_SYCL=ON -DCMAKE_C_COMPILER=icx -DCMAKE_CXX_COMPILER=icpx -DLLAMA_CURL=ON ${OPT_SYCL_F16} && \
wangkx1's avatar
init  
wangkx1 committed
19
20
    cmake --build build --config Release --target llama-server

wangkx1's avatar
wangkx1 committed
21
FROM intel/oneapi-basekit:$ONEAPI_VERSION AS runtime
wangkx1's avatar
init  
wangkx1 committed
22
23

RUN apt-get update && \
wangkx1's avatar
wangkx1 committed
24
    apt-get install -y libcurl4-openssl-dev curl
wangkx1's avatar
init  
wangkx1 committed
25
26
27
28
29

COPY --from=build /app/build/bin/llama-server /llama-server

ENV LC_ALL=C.utf8

wangkx1's avatar
wangkx1 committed
30
31
HEALTHCHECK CMD [ "curl", "-f", "http://localhost:8080/health" ]

wangkx1's avatar
init  
wangkx1 committed
32
ENTRYPOINT [ "/llama-server" ]