build_trtllm_base_image.sh 1.61 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#!/bin/bash -e
# SPDX-FileCopyrightText: Copyright (c) 2024-2025 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
# SPDX-License-Identifier: Apache-2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

# Build the TRT-LLM base image.

# This script builds the TRT-LLM base image for Dynamo with TensorRT-LLM.
20
TRTLLM_COMMIT=dfbcb543
21
22
23
24
25
26
27
28

while getopts "c:" opt; do
  case ${opt} in
    c) TRTLLM_COMMIT=$OPTARG ;;
    *) echo "Invalid option" ;;
  esac
done

29
30
31
32
33
python3 -m venv /tmp/squash-env

source /tmp/squash-env/bin/activate
pip3 install docker-squash

34
35
36
(cd /tmp && \
# Clone the TensorRT-LLM repository.
if [ ! -d "TensorRT-LLM" ]; then
37
  git clone --single-branch --branch main https://github.com/NVIDIA/TensorRT-LLM.git
38
39
40
41
42
fi

cd TensorRT-LLM

# Checkout the specified commit.
43
44
45
# Switch to the main branch to pull the latest changes.
git checkout main
git pull
46
47
48
49
50
51
52
53
git checkout $TRTLLM_COMMIT

# Update the submodules.
git submodule update --init --recursive
git lfs pull

# Build the TRT-LLM base image.
make -C docker release_build)
54
55
56
57
58

pip3 install docker-squash
docker-squash -t tensorrt_llm/release:latest_squashed tensorrt_llm/release:latest

deactivate