ollama/Dockerfile

32 lines
959 B
Text
Raw Normal View History

2023-09-22 11:57:31 -07:00
ARG CUDA_VERSION=12.2.0
2023-09-06 14:14:20 -07:00
2023-09-22 11:57:31 -07:00
FROM nvidia/cuda:$CUDA_VERSION-devel-ubuntu22.04
ARG TARGETARCH
2023-09-08 13:41:49 -07:00
ARG VERSION=0.0.0
2023-07-03 18:56:17 -04:00
WORKDIR /go/src/github.com/jmorganca/ollama
2023-09-22 11:57:31 -07:00
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
2023-09-06 14:14:20 -07:00
2023-07-03 18:56:17 -04:00
COPY . .
2023-09-22 11:57:31 -07:00
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" .
2023-07-03 18:56:17 -04:00
2023-09-22 11:57:31 -07:00
FROM ubuntu:22.04
2023-09-06 14:14:20 -07:00
ENV OLLAMA_HOST 0.0.0.0
2023-09-22 11:57:31 -07:00
RUN apt-get update && apt-get install -y ca-certificates
2023-09-06 14:14:20 -07:00
2023-07-03 18:56:17 -04:00
ARG USER=ollama
ARG GROUP=ollama
2023-09-22 11:57:31 -07:00
RUN groupadd $GROUP && useradd -m -g $GROUP $USER
2023-09-06 14:14:20 -07:00
COPY --from=0 /go/src/github.com/jmorganca/ollama/ollama /bin/ollama
2023-07-03 18:56:17 -04:00
USER $USER:$GROUP
ENTRYPOINT ["/bin/ollama"]
2023-07-06 16:34:14 -04:00
CMD ["serve"]