|
|
FROM nvidia/cuda:12.4.1-cudnn-devel-ubuntu22.04 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ARG CUDA_ARCHITECTURES="8.0;8.6" |
|
|
|
|
|
ENV DEBIAN_FRONTEND=noninteractive |
|
|
|
|
|
|
|
|
RUN apt update && \ |
|
|
apt install -y \ |
|
|
python3 python3-pip git wget curl cmake ninja-build \ |
|
|
libgl1 libglib2.0-0 ffmpeg && \ |
|
|
apt clean |
|
|
|
|
|
WORKDIR /workspace |
|
|
|
|
|
COPY requirements.txt . |
|
|
|
|
|
|
|
|
RUN pip install --upgrade pip setuptools wheel |
|
|
|
|
|
|
|
|
RUN pip install -r requirements.txt |
|
|
|
|
|
|
|
|
RUN pip install --extra-index-url https://download.pytorch.org/whl/cu124 \ |
|
|
torch==2.6.0+cu124 torchvision==0.21.0+cu124 |
|
|
|
|
|
|
|
|
ENV TORCH_CUDA_ARCH_LIST="${CUDA_ARCHITECTURES}" |
|
|
ENV FORCE_CUDA="1" |
|
|
ENV MAX_JOBS="1" |
|
|
|
|
|
COPY <<EOF /tmp/patch_setup.py |
|
|
import os |
|
|
with open('setup.py', 'r') as f: |
|
|
content = f.read() |
|
|
|
|
|
|
|
|
arch_list = os.environ.get('TORCH_CUDA_ARCH_LIST') |
|
|
arch_set = '{' + ', '.join([f'"{arch}"' for arch in arch_list.split(';')]) + '}' |
|
|
|
|
|
|
|
|
old_section = '''compute_capabilities = set() |
|
|
device_count = torch.cuda.device_count() |
|
|
for i in range(device_count): |
|
|
major, minor = torch.cuda.get_device_capability(i) |
|
|
if major < 8: |
|
|
warnings.warn(f"skipping GPU {i} with compute capability {major}.{minor}") |
|
|
continue |
|
|
compute_capabilities.add(f"{major}.{minor}")''' |
|
|
|
|
|
new_section = 'compute_capabilities = ' + arch_set + ''' |
|
|
print(f"Manually set compute capabilities: {compute_capabilities}")''' |
|
|
|
|
|
content = content.replace(old_section, new_section) |
|
|
|
|
|
with open('setup.py', 'w') as f: |
|
|
f.write(content) |
|
|
EOF |
|
|
|
|
|
RUN git clone https://github.com/thu-ml/SageAttention.git /tmp/sageattention && \ |
|
|
cd /tmp/sageattention && \ |
|
|
python3 /tmp/patch_setup.py && \ |
|
|
pip install --no-build-isolation . |
|
|
|
|
|
RUN useradd -u 1000 -ms /bin/bash user |
|
|
|
|
|
RUN chown -R user:user /workspace |
|
|
|
|
|
RUN mkdir /home/user/.cache && \ |
|
|
chown -R user:user /home/user/.cache |
|
|
|
|
|
COPY entrypoint.sh /workspace/entrypoint.sh |
|
|
|
|
|
ENTRYPOINT ["/workspace/entrypoint.sh"] |
|
|
|