Dockerfile 1001 Bytes
Newer Older
1
FROM nvidia/cuda:11.8.0-devel-ubuntu22.04
Michael Yang's avatar
Michael Yang committed
2
3

ARG TARGETARCH
Michael Yang's avatar
Michael Yang committed
4
ARG GOFLAGS="'-ldflags=-w -s'"
Michael Yang's avatar
Michael Yang committed
5

Jeffrey Morgan's avatar
Jeffrey Morgan committed
6
WORKDIR /go/src/github.com/jmorganca/ollama
Michael Yang's avatar
Michael Yang committed
7
RUN apt-get update && apt-get install -y git build-essential cmake
8
9
ADD https://dl.google.com/go/go1.21.3.linux-$TARGETARCH.tar.gz /tmp/go1.21.3.tar.gz
RUN mkdir -p /usr/local && tar xz -C /usr/local </tmp/go1.21.3.tar.gz
Michael Yang's avatar
Michael Yang committed
10

Jeffrey Morgan's avatar
Jeffrey Morgan committed
11
COPY . .
Michael Yang's avatar
Michael Yang committed
12
ENV GOARCH=$TARGETARCH
13
ENV GOFLAGS=$GOFLAGS
Michael Yang's avatar
Michael Yang committed
14
RUN /usr/local/go/bin/go generate ./... \
Michael Yang's avatar
Michael Yang committed
15
    && /usr/local/go/bin/go build .
Jeffrey Morgan's avatar
Jeffrey Morgan committed
16

Michael Yang's avatar
Michael Yang committed
17
18
FROM ubuntu:22.04
RUN apt-get update && apt-get install -y ca-certificates
Michael Yang's avatar
Michael Yang committed
19
COPY --from=0 /go/src/github.com/jmorganca/ollama/ollama /bin/ollama
20
21
EXPOSE 11434
ENV OLLAMA_HOST 0.0.0.0
22
23
24
25
26
27

# set some environment variable for better NVIDIA compatibility
ENV PATH=/usr/local/nvidia/bin:/usr/local/cuda/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
ENV LD_LIBRARY_PATH=/usr/local/nvidia/lib:/usr/local/nvidia/lib64
ENV NVIDIA_DRIVER_CAPABILITIES=compute,utility

Jeffrey Morgan's avatar
Jeffrey Morgan committed
28
ENTRYPOINT ["/bin/ollama"]
Jeffrey Morgan's avatar
Jeffrey Morgan committed
29
CMD ["serve"]