-
Notifications
You must be signed in to change notification settings - Fork 139
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[CI] update CI docker to ubuntu20.04
- Simplify the CI pipeline by removing some unnecessary testing items. - Fix the hiredis dependency to tag v1.1.0
- Loading branch information
Showing
15 changed files
with
150 additions
and
54 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -23,7 +23,7 @@ env: | |
jobs: | ||
test-with-bazel: | ||
name: Test with bazel | ||
runs-on: ubuntu-18.04 | ||
runs-on: ubuntu-20.04 | ||
steps: | ||
- uses: actions/checkout@v2 | ||
- uses: actions/setup-python@v1 | ||
|
@@ -44,12 +44,12 @@ jobs: | |
strategy: | ||
matrix: | ||
# TODO: add back 'windows-latest' when it can be compiled. | ||
os: ['macos-12', 'ubuntu-18.04'] | ||
os: ['macos-12', 'ubuntu-20.04'] | ||
py-version: ['3.7', '3.8', '3.9'] | ||
tf-version: ['2.6.3', '2.8.3'] | ||
tf-need-cuda: ['1', '0'] | ||
tf-cuda-version: ['10.0', '11.2'] | ||
tf-cudnn-version: ['7.6', '8.1'] | ||
tf-cuda-version: ['11.2'] | ||
tf-cudnn-version: ['8.1'] | ||
cpu: ['x86'] | ||
# TODO(poinwater): add macOS CI once GitHub supports macOS 12.0.0 + | ||
# include: | ||
|
@@ -62,23 +62,6 @@ jobs: | |
# excludes cuda on macOS | ||
- os: 'macos-12' | ||
tf-need-cuda: '1' | ||
# excludes TF2.6.3 with cuda 10.0 | ||
- tf-version: '2.6.3' | ||
tf-cuda-version: '10.0' | ||
# excludes TF2.8.3 with cuda 10.0 | ||
- tf-version: '2.8.3' | ||
tf-cuda-version: '10.0' | ||
# excludes cudnn 8 with cuda 10.0 | ||
- tf-cuda-version: '11.2' | ||
tf-cudnn-version: '7.6' | ||
# excludes cudnn 7 with cuda 11.0 | ||
- tf-cuda-version: '10.0' | ||
tf-cudnn-version: '8.1' | ||
# excludes some unnecessary step on no cuda | ||
- tf-need-cuda: '0' | ||
tf-cuda-version: '10.0' | ||
- tf-need-cuda: '0' | ||
tf-cudnn-version: '7.6' | ||
fail-fast: false | ||
steps: | ||
- uses: actions/[email protected] | ||
|
@@ -97,7 +80,7 @@ jobs: | |
python-version: ${{ matrix.py-version }} | ||
- name: Setup Bazel | ||
# Ubuntu bazel is run inside of the docker image | ||
if: matrix.os != 'ubuntu-18.04' | ||
if: matrix.os != 'ubuntu-20.04' | ||
run: bash tools/install_deps/install_bazelisk.sh ./ | ||
- name: Build wheels | ||
env: | ||
|
@@ -124,7 +107,7 @@ jobs: | |
upload-wheels: | ||
name: Publish wheels to PyPi | ||
needs: [release-wheel, test-with-bazel] | ||
runs-on: ubuntu-18.04 | ||
runs-on: ubuntu-20.04 | ||
strategy: | ||
matrix: | ||
# TODO: add back 'Windows' when it can be compiled. | ||
|
@@ -168,7 +151,7 @@ jobs: | |
upload-dev-container: | ||
name: Upload dev container to DockerHub | ||
needs: [release-wheel, test-with-bazel] | ||
runs-on: ubuntu-18.04 | ||
runs-on: ubuntu-20.04 | ||
strategy: | ||
matrix: | ||
py-version: ['3.7', '3.8', '3.9'] | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
115 changes: 115 additions & 0 deletions
115
tools/docker/cuda11.2.1-cudnn8-ubuntu20.04-manylinux2014-multipython.Dockerfile
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,115 @@ | ||
# Dockerfile to build a manylinux 2010 compliant cross-compiler. | ||
# | ||
# Builds a devtoolset gcc/libstdc++ that targets manylinux 2010 compatible | ||
# glibc (2.12) and system libstdc++ (4.4). | ||
# | ||
# To push a new version, run: | ||
# $ docker build -f cuda11.2.1-cudnn8-ubuntu20.04-manylinux2014-multipython.Dockerfile . \ | ||
# --tag "tfra/nosla-cuda11.2.1-cudnn8-ubuntu20.04-manylinux2014-multipython" | ||
# $ docker push tfra/nosla-cuda11.2.1-cudnn8-ubuntu20.04-manylinux2014-multipython | ||
|
||
FROM nvidia/cuda:11.2.1-cudnn8-devel-ubuntu20.04 as devtoolset | ||
|
||
RUN chmod 777 /tmp/ | ||
ENV DEBIAN_FRONTEND=noninteractive | ||
RUN apt-get update && apt-get install -y \ | ||
cpio \ | ||
file \ | ||
flex \ | ||
g++ \ | ||
make \ | ||
patch \ | ||
rpm2cpio \ | ||
unar \ | ||
wget \ | ||
xz-utils \ | ||
libjpeg-dev \ | ||
zlib1g-dev \ | ||
libgflags-dev \ | ||
libsnappy-dev \ | ||
libbz2-dev \ | ||
liblz4-dev \ | ||
libzstd-dev \ | ||
openssh-client \ | ||
&& \ | ||
rm -rf /var/lib/apt/lists/* | ||
|
||
ADD devtoolset/fixlinks.sh fixlinks.sh | ||
ADD devtoolset/build_devtoolset.sh build_devtoolset.sh | ||
ADD devtoolset/rpm-patch.sh rpm-patch.sh | ||
|
||
# Set up a sysroot for glibc 2.12 / libstdc++ 4.4 / devtoolset-7 in /dt7. | ||
RUN /build_devtoolset.sh devtoolset-7 /dt7 | ||
# Set up a sysroot for glibc 2.12 / libstdc++ 4.4 / devtoolset-8 in /dt8. | ||
RUN /build_devtoolset.sh devtoolset-8 /dt8 | ||
|
||
# TODO(klimek): Split up into two different docker images. | ||
FROM nvidia/cuda:11.2.1-cudnn8-devel-ubuntu20.04 | ||
COPY --from=devtoolset /dt7 /dt7 | ||
COPY --from=devtoolset /dt8 /dt8 | ||
|
||
# Install TensorRT. | ||
RUN echo \ | ||
deb https://developer.download.nvidia.com/compute/machine-learning/repos/ubuntu1804/x86_64 / \ | ||
> /etc/apt/sources.list.d/nvidia-ml.list \ | ||
&& \ | ||
apt-key adv --keyserver keyserver.ubuntu.com --recv-keys F60F4B3D7FA2AF80 && \ | ||
apt-get update && \ | ||
rm -rf /var/lib/apt/lists/* | ||
|
||
# Copy and run the install scripts. | ||
ARG DEBIAN_FRONTEND=noninteractive | ||
|
||
COPY install/install_bootstrap_deb_packages.sh /install/ | ||
RUN /install/install_bootstrap_deb_packages.sh | ||
|
||
COPY install/install_deb_packages.sh /install/ | ||
RUN /install/install_deb_packages.sh | ||
|
||
# Install additional packages needed for this image: | ||
# - dependencies to build Python from source | ||
# - patchelf, as it is required by auditwheel | ||
RUN apt-get update && apt-get install -y \ | ||
libbz2-dev \ | ||
libffi-dev \ | ||
libgdbm-dev \ | ||
libncurses5-dev \ | ||
libnss3-dev \ | ||
libreadline-dev \ | ||
patchelf \ | ||
gcc-multilib \ | ||
&& \ | ||
rm -rf /var/lib/apt/lists/* | ||
|
||
RUN chmod 777 /tmp/ | ||
WORKDIR /tmp/ | ||
|
||
COPY install/install_nccl.sh /install/ | ||
RUN /install/install_nccl.sh "2.8.4-1+cuda11.2" | ||
|
||
COPY install/install_rocksdb.sh /install/ | ||
RUN /install/install_rocksdb.sh "6.22.1" | ||
|
||
COPY install/install_bazel.sh /install/ | ||
RUN /install/install_bazel.sh "5.1.1" | ||
|
||
COPY install/build_and_install_python.sh /install/ | ||
RUN /install/build_and_install_python.sh "3.7.7" | ||
RUN /install/build_and_install_python.sh "3.8.2" | ||
RUN /install/build_and_install_python.sh "3.9.7" | ||
RUN /install/build_and_install_python.sh "3.10.6" | ||
|
||
COPY install/install_pip_packages_by_version.sh /install/ | ||
RUN /install/install_pip_packages_by_version.sh "/usr/local/bin/pip3.10" | ||
RUN /install/install_pip_packages_by_version.sh "/usr/local/bin/pip3.9" | ||
RUN /install/install_pip_packages_by_version.sh "/usr/local/bin/pip3.8" | ||
RUN /install/install_pip_packages_by_version.sh "/usr/local/bin/pip3.7" | ||
|
||
COPY install/use_devtoolset_7.sh /install/ | ||
RUN /install/use_devtoolset_7.sh | ||
|
||
COPY install/install_openmpi.sh /install/ | ||
RUN /install/install_openmpi.sh "4.1.1" | ||
|
||
# clean | ||
RUN rm -rf /tmp/* |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters