Dockerfile 895 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
5
ARG VERSION=0.0.0

Jeffrey Morgan's avatar
Jeffrey Morgan committed
6
WORKDIR /go/src/github.com/jmorganca/ollama
Michael Yang's avatar
Michael Yang committed
7
8
9
RUN apt-get update && apt-get install -y git build-essential cmake
ADD https://dl.google.com/go/go1.21.1.linux-$TARGETARCH.tar.gz /tmp/go1.21.1.tar.gz
RUN mkdir -p /usr/local && tar xz -C /usr/local </tmp/go1.21.1.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
13
14
ENV GOARCH=$TARGETARCH
RUN /usr/local/go/bin/go generate ./... \
    && /usr/local/go/bin/go build -ldflags "-linkmode=external -extldflags='-static' -X=github.com/jmorganca/ollama/version.Version=$VERSION -X=github.com/jmorganca/ollama/server.mode=release" .
Jeffrey Morgan's avatar
Jeffrey Morgan committed
15

Michael Yang's avatar
Michael Yang committed
16
FROM ubuntu:22.04
Michael Yang's avatar
Michael Yang committed
17
ENV OLLAMA_HOST 0.0.0.0
Michael Yang's avatar
Michael Yang committed
18
19

RUN apt-get update && apt-get install -y ca-certificates
20
RUN groupadd ollama && useradd -m -g ollama ollama
Michael Yang's avatar
Michael Yang committed
21
22
23

COPY --from=0 /go/src/github.com/jmorganca/ollama/ollama /bin/ollama

24
USER ollama:ollama
Jeffrey Morgan's avatar
Jeffrey Morgan committed
25
ENTRYPOINT ["/bin/ollama"]
Jeffrey Morgan's avatar
Jeffrey Morgan committed
26
CMD ["serve"]