Dockerfile 2.19 KB
Newer Older
Ying Sheng's avatar
Ying Sheng committed
1
ARG CUDA_VERSION=12.1.1
2
FROM nvidia/cuda:${CUDA_VERSION}-devel-ubuntu20.04
Yineng Zhang's avatar
Yineng Zhang committed
3
ARG BUILD_TYPE=all
Ying Sheng's avatar
Ying Sheng committed
4
5
6
7
ENV DEBIAN_FRONTEND=noninteractive

RUN echo 'tzdata tzdata/Areas select America' | debconf-set-selections \
    && echo 'tzdata tzdata/Zones/America select Los_Angeles' | debconf-set-selections \
Yineng Zhang's avatar
Yineng Zhang committed
8
9
10
    && apt update -y \
    && apt install software-properties-common -y \
    && add-apt-repository ppa:deadsnakes/ppa -y && apt update \
11
    && apt install python3.10 python3.10-dev -y \
Yineng Zhang's avatar
Yineng Zhang committed
12
13
    && update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.8 1 && update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.10 2 \
    && update-alternatives --set python3 /usr/bin/python3.10 && apt install python3.10-distutils -y \
14
    && apt install curl git sudo libibverbs-dev -y \
Yineng Zhang's avatar
Yineng Zhang committed
15
    && curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py && python3 get-pip.py \
Ying Sheng's avatar
Ying Sheng committed
16
    && python3 --version \
Liangsheng Yin's avatar
Liangsheng Yin committed
17
18
    && python3 -m pip --version \
    && rm -rf /var/lib/apt/lists/* \
Yineng Zhang's avatar
Yineng Zhang committed
19
    && apt clean
Ying Sheng's avatar
Ying Sheng committed
20
21
22

WORKDIR /sgl-workspace

Yineng Zhang's avatar
Yineng Zhang committed
23
RUN python3 -m pip install --upgrade pip setuptools wheel html5lib six \
24
25
    && git clone --depth=1 https://github.com/sgl-project/sglang.git \
    && cd sglang \
Yineng Zhang's avatar
Yineng Zhang committed
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
    && if [ "$BUILD_TYPE" = "srt" ]; then \
         python3 -m pip --no-cache-dir install -e "python[srt]"; \
       else \
         python3 -m pip --no-cache-dir install -e "python[all]"; \
       fi

ARG CUDA_VERSION
RUN if [ "$CUDA_VERSION" = "12.1.1" ]; then \
        export CUDA_IDENTIFIER=cu121 && \
        python3 -m pip --no-cache-dir install flashinfer -i https://flashinfer.ai/whl/cu121/torch2.4/; \
    elif [ "$CUDA_VERSION" = "12.4.1" ]; then \
        export CUDA_IDENTIFIER=cu124 && \
        python3 -m pip --no-cache-dir install flashinfer -i https://flashinfer.ai/whl/cu124/torch2.4/; \
    elif [ "$CUDA_VERSION" = "11.8.0" ]; then \
        export CUDA_IDENTIFIER=cu118 && \
        python3 -m pip install torch==2.4.0 --index-url https://download.pytorch.org/whl/cu118 && \
        python3 -m pip --no-cache-dir install flashinfer -i https://flashinfer.ai/whl/cu118/torch2.4/; \
    else \
        echo "Unsupported CUDA version: $CUDA_VERSION" && exit 1; \
    fi

RUN python3 -m pip cache purge
Ying Sheng's avatar
Ying Sheng committed
48

49

Ying Sheng's avatar
Ying Sheng committed
50
ENV DEBIAN_FRONTEND=interactive