Dockerfile.cuda 959 Bytes
Newer Older
Michael Yang's avatar
Michael Yang committed
1
2
3
ARG CUDA_VERSION=12.2.0

FROM nvidia/cuda:$CUDA_VERSION-devel-ubuntu22.04
4

Michael Yang's avatar
Michael Yang committed
5
6
7
ARG TARGETARCH
ARG VERSION=0.0.0

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

COPY . .
Michael Yang's avatar
Michael Yang committed
14
15
16
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" .
17

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

Michael Yang's avatar
Michael Yang committed
21
22
RUN apt-get update && apt-get install -y ca-certificates

23
24
25
26
27
28
29
30
31
ARG USER=ollama
ARG GROUP=ollama
RUN groupadd $GROUP && useradd -m -g $GROUP $USER

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

USER $USER:$GROUP
ENTRYPOINT ["/bin/ollama"]
CMD ["serve"]