llama-server-intel.Dockerfile 999 B

12345678910111213141516171819202122232425262728293031323334
  1. ARG ONEAPI_VERSION=2024.1.1-devel-ubuntu22.04
  2. FROM intel/oneapi-basekit:$ONEAPI_VERSION AS build
  3. ARG GGML_SYCL_F16=OFF
  4. RUN apt-get update && \
  5. apt-get install -y git libcurl4-openssl-dev
  6. WORKDIR /app
  7. COPY . .
  8. RUN if [ "${GGML_SYCL_F16}" = "ON" ]; then \
  9. echo "GGML_SYCL_F16 is set" && \
  10. export OPT_SYCL_F16="-DGGML_SYCL_F16=ON"; \
  11. fi && \
  12. echo "Building with dynamic libs" && \
  13. cmake -B build -DGGML_SYCL=ON -DCMAKE_C_COMPILER=icx -DCMAKE_CXX_COMPILER=icpx -DLLAMA_CURL=ON ${OPT_SYCL_F16} && \
  14. cmake --build build --config Release --target llama-server
  15. FROM intel/oneapi-basekit:$ONEAPI_VERSION AS runtime
  16. RUN apt-get update && \
  17. apt-get install -y libcurl4-openssl-dev curl
  18. COPY --from=build /app/build/bin/llama-server /llama-server
  19. ENV LC_ALL=C.utf8
  20. # Must be set to 0.0.0.0 so it can listen to requests from host machine
  21. ENV LLAMA_ARG_HOST=0.0.0.0
  22. HEALTHCHECK CMD [ "curl", "-f", "http://localhost:8080/health" ]
  23. ENTRYPOINT [ "/llama-server" ]