Support Arm64 CPU architectures

This commit is contained in:
Connor Dibble
2021-11-03 22:47:57 +01:00
committed by Erik Sundell
parent f25d35d7a0
commit a91571dd22
3 changed files with 30 additions and 10 deletions

View File

@@ -11,11 +11,15 @@ import tempfile
@pytest.fixture(scope='module') @pytest.fixture(scope='module')
def prefix(): def prefix():
""" """
Provide a temporary directory with a conda environment Provide a temporary directory with a mambaforge conda environment
""" """
# see https://github.com/conda-forge/miniforge/releases
mambaforge_version = '4.10.3-7' mambaforge_version = '4.10.3-7'
if os.uname().machine == 'aarch64':
installer_sha256 = "ac95f137b287b3408e4f67f07a284357b1119ee157373b788b34e770ef2392b2"
elif os.uname().machine == 'x86_64':
installer_sha256 = "fc872522ec427fcab10167a93e802efaf251024b58cc27b084b915a9a73c4474" installer_sha256 = "fc872522ec427fcab10167a93e802efaf251024b58cc27b084b915a9a73c4474"
installer_url = "https://github.com/conda-forge/miniforge/releases/download/{v}/Mambaforge-{v}-Linux-x86_64.sh".format(v=mambaforge_version) installer_url = "https://github.com/conda-forge/miniforge/releases/download/{v}/Mambaforge-{v}-Linux-{arch}.sh".format(v=mambaforge_version, arch=os.uname().machine)
with tempfile.TemporaryDirectory() as tmpdir: with tempfile.TemporaryDirectory() as tmpdir:
with conda.download_miniconda_installer(installer_url, installer_sha256) as installer_path: with conda.download_miniconda_installer(installer_url, installer_sha256) as installer_path:
conda.install_miniconda(installer_path, tmpdir) conda.install_miniconda(installer_path, tmpdir)

View File

@@ -170,7 +170,14 @@ def ensure_user_environment(user_requirements_txt_file):
# Install mambaforge using an installer from # Install mambaforge using an installer from
# https://github.com/conda-forge/miniforge/releases # https://github.com/conda-forge/miniforge/releases
mambaforge_new_version = '4.10.3-7' mambaforge_new_version = '4.10.3-7'
# Check system architecture, set appropriate installer checksum
if os.uname().machine == 'aarch64':
installer_sha256 = "ac95f137b287b3408e4f67f07a284357b1119ee157373b788b34e770ef2392b2"
elif os.uname().machine == 'x86_64':
installer_sha256 = "fc872522ec427fcab10167a93e802efaf251024b58cc27b084b915a9a73c4474" installer_sha256 = "fc872522ec427fcab10167a93e802efaf251024b58cc27b084b915a9a73c4474"
# Check OS, set appropriate string for conda installer path
if os.uname().sysname != 'Linux':
raise OSError("TLJH is only supported on Linux platforms.")
# Then run `mamba --version` to get the conda and mamba versions # Then run `mamba --version` to get the conda and mamba versions
# Keep these in sync with tests/test_conda.py::prefix # Keep these in sync with tests/test_conda.py::prefix
mambaforge_conda_new_version = '4.10.3' mambaforge_conda_new_version = '4.10.3'
@@ -185,7 +192,7 @@ def ensure_user_environment(user_requirements_txt_file):
# If no prior miniconda installation is found, we can install a newer version # If no prior miniconda installation is found, we can install a newer version
else: else:
logger.info('Downloading & setting up user environment...') logger.info('Downloading & setting up user environment...')
installer_url = "https://github.com/conda-forge/miniforge/releases/download/{v}/Mambaforge-{v}-Linux-x86_64.sh".format(v=mambaforge_new_version) installer_url = "https://github.com/conda-forge/miniforge/releases/download/{v}/Mambaforge-{v}-Linux-{arch}.sh".format(v=mambaforge_new_version, arch=os.uname().machine)
with conda.download_miniconda_installer(installer_url, installer_sha256) as installer_path: with conda.download_miniconda_installer(installer_url, installer_sha256) as installer_path:
conda.install_miniconda(installer_path, USER_ENV_PREFIX) conda.install_miniconda(installer_path, USER_ENV_PREFIX)
conda_version = '4.10.3' conda_version = '4.10.3'

View File

@@ -12,13 +12,21 @@ import toml
from .config import CONFIG_DIR from .config import CONFIG_DIR
from tljh.configurer import load_config, _merge_dictionaries from tljh.configurer import load_config, _merge_dictionaries
# FIXME: support more than one platform here # traefik 2.7.x is not supported yet, use v1.7.x for now
plat = "linux-amd64" # see: https://github.com/jupyterhub/traefik-proxy/issues/97
traefik_version = "1.7.18" machine = os.uname().machine
if machine == 'aarch64':
plat = "linux-arm64"
elif machine == 'x86_64':
plat = "linux-amd64"
else:
raise OSError(f"Error. Platform: {os.uname().sysname} / {machine} Not supported.")
traefik_version = "1.7.33"
# record sha256 hashes for supported platforms here # record sha256 hashes for supported platforms here
checksums = { checksums = {
"linux-amd64": "3c2d153d80890b6fc8875af9f8ced32c4d684e1eb5a46d9815337cb343dfd92e" "linux-amd64": "314ffeaa4cd8ed6ab7b779e9b6773987819f79b23c28d7ab60ace4d3683c5935",
"linux-arm64": "0640fa665125efa6b598fc08c100178e24de66c5c6035ce5d75668d3dc3706e1"
} }
def checksum_file(path): def checksum_file(path):
@@ -40,7 +48,7 @@ def fatal_error(e):
giveup=fatal_error giveup=fatal_error
) )
def ensure_traefik_binary(prefix): def ensure_traefik_binary(prefix):
"""Download and install the traefik binary""" """Download and install the traefik binary to a location identified by a prefix path such as '/opt/tljh/hub/'"""
traefik_bin = os.path.join(prefix, "bin", "traefik") traefik_bin = os.path.join(prefix, "bin", "traefik")
if os.path.exists(traefik_bin): if os.path.exists(traefik_bin):
checksum = checksum_file(traefik_bin) checksum = checksum_file(traefik_bin)
@@ -57,6 +65,7 @@ def ensure_traefik_binary(prefix):
"https://github.com/containous/traefik/releases" "https://github.com/containous/traefik/releases"
f"/download/v{traefik_version}/traefik_{plat}" f"/download/v{traefik_version}/traefik_{plat}"
) )
print(f"Downloading traefik {traefik_version}...") print(f"Downloading traefik {traefik_version}...")
# download the file # download the file
response = requests.get(traefik_url) response = requests.get(traefik_url)