-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDockerfile
114 lines (99 loc) · 4.42 KB
/
Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
FROM nvidia/cuda:11.8.0-devel-ubuntu22.04
ENV TZ=Europe/Madrid
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
RUN mkdir /projects
WORKDIR /projects
ADD projects /projects
ENV CUDA_INSTALL_PATH=/usr/local/cuda-11.8
ENV PATH=$CUDA_INSTALL_PATH/bin:$PATH
RUN apt-get update && apt-get install -y \
software-properties-common
RUN apt-get update && apt-get install -y \
python3.10 \
python3-pip \
wget \
git \
vim \
screen
RUN pip install matplotlib pandas
################################# Prepare environments #################################
ENV TORCH_CUDA_ARCH_LIST="8.6 8.0"
# Install miniconda
RUN mkdir -p ~/miniconda3
RUN wget https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh -O ~/miniconda3/miniconda.sh
RUN bash ~/miniconda3/miniconda.sh -b -u -p ~/miniconda3
RUN rm -rf ~/miniconda3/miniconda.sh
RUN ~/miniconda3/bin/conda init bash
ENV PATH=/root/miniconda3/bin:$PATH
# Install MARLIN
RUN conda create -y --name marlin python=3.10 -y
SHELL ["conda", "run", "-n", "marlin", "/bin/bash", "-c"]
RUN pip install torch==2.1.0+cu118 --index-url https://download.pytorch.org/whl/cu118/
RUN conda install nvidia/label/cuda-11.8.0::cuda-nvcc
RUN conda install nvidia/label/cuda-11.8.0::cuda-toolkit
RUN conda env config vars set CUDA_HOME="/root/miniconda3/envs/marlin"
RUN conda env config vars set CUDA_TOOLKIT_ROOT_DIR=$CUDA_HOME
RUN conda env config vars set LD_LIBRARY_PATH="$CUDA_HOME/lib:$LD_LIBRARY_PATH"
RUN conda env config vars set LIBRARY_PATH=$CUDA_HOME/lib:$LIBRARY_PATH
RUN conda env config vars set LD_LIBRARY_PATH=$CUDA_HOME/lib:$LD_LIBRARY_PATH
RUN conda env config vars set CPATH=/root/miniconda3/envs/marlin/targets/x86_64-linux/include/:$CPATH
RUN conda env config vars set LD_LIBRARY_PATH=/root/miniconda3/envs/marlin/targets/x86_64-linux/lib:$LD_LIBRARY_PATH
RUN conda env config vars set PATH=$CUDA_HOME/bin:$PATH
RUN source deactivate
SHELL ["conda", "run", "-n", "marlin", "/bin/bash", "-c"]
RUN python3 -m pip install "numpy<2" matplotlib
RUN pip install .
RUN source deactivate
# Install llm-awq
RUN conda create -y --name awq python=3.10 -y
SHELL ["conda", "run", "-n", "awq", "/bin/bash", "-c"]
RUN conda install nvidia/label/cuda-12.4.1::cuda
RUN pip install --upgrade pip
WORKDIR /projects/baselines/llm-awq
RUN pip install -e .
WORKDIR /projects/baselines/llm-awq/awq/kernels
RUN python3 setup.py install
RUN source deactivate
# Install exllamav2
RUN conda create -y --name exllamav2 python=3.9 -y
SHELL ["conda", "run", "-n", "exllamav2", "/bin/bash", "-c"]
WORKDIR /projects/baselines/exllamav2
RUN conda install nvidia/label/cuda-12.1.0::cuda-nvcc
RUN conda install nvidia/label/cuda-12.1.0::cuda-toolkit
RUN pip install -r requirements.txt
RUN conda env config vars set CUDA_HOME="/root/miniconda3/envs/exllamav2"
RUN conda env config vars set CUDA_TOOLKIT_ROOT_DIR=$CUDA_HOME
RUN conda env config vars set LD_LIBRARY_PATH="$CUDA_HOME/lib:$LD_LIBRARY_PATH"
RUN conda env config vars set LIBRARY_PATH=$CUDA_HOME/lib:$LIBRARY_PATH
RUN conda env config vars set LD_LIBRARY_PATH=$CUDA_HOME/lib:$LD_LIBRARY_PATH
RUN conda env config vars set CPATH=/root/miniconda3/envs/exllamav2/targets/x86_64-linux/include/:$CPATH
RUN conda env config vars set LD_LIBRARY_PATH=/root/miniconda3/envs/exllamav2/targets/x86_64-linux/lib:$LD_LIBRARY_PATH
RUN conda env config vars set PATH=$CUDA_HOME/bin:$PATH
RUN source deactivate
# Install bitsandbytes
RUN conda create -y --name bitsandbytes python=3.10 -y
SHELL ["conda", "run", "-n", "bitsandbytes", "/bin/bash", "-c"]
WORKDIR /projects/baselines/bitsandbytes
RUN pip install -r requirements-dev.txt
RUN conda install cmake
RUN cmake -DCOMPUTE_BACKEND=cuda -S .
RUN make CUDA_VERSION=118
RUN pip install -e .
RUN python -m pip install torch==2.1.0+cu118 --index-url https://download.pytorch.org/whl/cu118/
RUN python3 -m pip install "numpy<2"
RUN source deactivate
# Install torch-nightly
WORKDIR /projects/baselines/ao
RUN conda create -y --name torchao python=3.10 -y
SHELL ["conda", "run", "-n", "torchao", "/bin/bash", "-c"]
RUN pip install --pre torchao --index-url https://download.pytorch.org/whl/nightly/cu121
RUN pip install hqq pandas
RUN conda env config vars set PYTORCH_CUDA_ALLOC_CONF=expandable_segments:True
RUN source deactivate
# Install vLLM
WORKDIR /projects/e2e
RUN conda create -y --name vllm python=3.12 -y
SHELL ["conda", "run", "-n", "vllm", "/bin/bash", "-c"]
RUN pip install vllm==0.6.4.post1
RUN source deactivate
WORKDIR /projects