-
Notifications
You must be signed in to change notification settings - Fork 59
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: Clayton Parnell <[email protected]> Co-authored-by: SageMaker Distribution Bot <sm-distribution-github-bot[bot]@amazon.com>
- Loading branch information
1 parent
02b93e8
commit 62a8af8
Showing
25 changed files
with
2,094 additions
and
0 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
# Change log: 2.0.1(cpu) | ||
|
||
## Upgrades: | ||
|
||
Package | Previous Version | Current Version | ||
---|---|--- | ||
python|3.11.9|3.11.10 | ||
altair|5.4.0|5.4.1 | ||
boto3|1.34.131|1.34.162 | ||
langchain|0.2.5|0.2.17 | ||
amazon-sagemaker-jupyter-ai-q-developer|1.0.9|1.0.14 | ||
amazon-sagemaker-jupyter-scheduler|3.1.3|3.1.7 | ||
pandas|2.2.2|2.2.3 | ||
amazon_sagemaker_sql_editor|0.1.11|0.1.13 | ||
sentencepiece|0.2.0|0.1.99 | ||
ipywidgets|8.1.3|8.1.5 | ||
aws-glue-sessions|1.0.6|1.0.7 | ||
jupyter-collaboration|2.1.2|2.1.5 | ||
jupyterlab-git|0.50.1|0.50.2 | ||
langchain-aws|0.1.16|0.1.18 | ||
sagemaker-code-editor|1.3.1|1.3.5 | ||
sagemaker-jupyterlab-emr-extension|0.3.2|0.3.4 | ||
sagemaker-kernel-wrapper|0.0.2|0.0.4 |
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,23 @@ | ||
# Change log: 2.0.1(gpu) | ||
|
||
## Upgrades: | ||
|
||
Package | Previous Version | Current Version | ||
---|---|--- | ||
python|3.11.9|3.11.10 | ||
altair|5.4.0|5.4.1 | ||
boto3|1.34.131|1.34.162 | ||
langchain|0.2.5|0.2.17 | ||
amazon-sagemaker-jupyter-ai-q-developer|1.0.9|1.0.14 | ||
amazon-sagemaker-jupyter-scheduler|3.1.3|3.1.7 | ||
pandas|2.2.2|2.2.3 | ||
amazon_sagemaker_sql_editor|0.1.11|0.1.13 | ||
sentencepiece|0.2.0|0.1.99 | ||
ipywidgets|8.1.3|8.1.5 | ||
aws-glue-sessions|1.0.6|1.0.7 | ||
jupyter-collaboration|2.1.2|2.1.5 | ||
jupyterlab-git|0.50.1|0.50.2 | ||
langchain-aws|0.1.16|0.1.18 | ||
sagemaker-code-editor|1.3.1|1.3.5 | ||
sagemaker-jupyterlab-emr-extension|0.3.2|0.3.4 | ||
sagemaker-kernel-wrapper|0.0.2|0.0.4 |
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,183 @@ | ||
ARG TAG_FOR_BASE_MICROMAMBA_IMAGE | ||
FROM mambaorg/micromamba:$TAG_FOR_BASE_MICROMAMBA_IMAGE | ||
|
||
ARG CUDA_MAJOR_MINOR_VERSION='' | ||
ARG ENV_IN_FILENAME | ||
ARG ARG_BASED_ENV_IN_FILENAME | ||
|
||
ARG AMZN_BASE="/opt/amazon/sagemaker" | ||
ARG DB_ROOT_DIR="/opt/db" | ||
ARG DIRECTORY_TREE_STAGE_DIR="${AMZN_BASE}/dir-staging" | ||
|
||
ARG NB_USER="sagemaker-user" | ||
ARG NB_UID=1000 | ||
ARG NB_GID=100 | ||
|
||
# https://www.openssl.org/source/ | ||
ARG FIPS_VALIDATED_SSL=3.0.8 | ||
|
||
ENV SAGEMAKER_LOGGING_DIR="/var/log/sagemaker/" | ||
ENV STUDIO_LOGGING_DIR="/var/log/studio/" | ||
ENV EDITOR="nano" | ||
|
||
USER root | ||
RUN usermod "--login=${NB_USER}" "--home=/home/${NB_USER}" --move-home "-u ${NB_UID}" "${MAMBA_USER}" && \ | ||
groupmod "--new-name=${NB_USER}" --non-unique "-g ${NB_GID}" "${MAMBA_USER}" && \ | ||
# Update the expected value of MAMBA_USER for the | ||
# _entrypoint.sh consistency check. | ||
echo "${NB_USER}" > "/etc/arg_mamba_user" && \ | ||
: | ||
ENV MAMBA_USER=$NB_USER | ||
ENV USER=$NB_USER | ||
|
||
RUN apt-get update && apt-get upgrade -y && \ | ||
apt-get install -y --no-install-recommends sudo gettext-base wget curl unzip git rsync build-essential openssh-client nano cron less mandoc && \ | ||
# We just install tzdata below but leave default time zone as UTC. This helps packages like Pandas to function correctly. | ||
DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends tzdata krb5-user libkrb5-dev libsasl2-dev libsasl2-modules && \ | ||
chmod g+w /etc/passwd && \ | ||
echo "ALL ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers && \ | ||
touch /etc/krb5.conf.lock && chown ${NB_USER}:${MAMBA_USER} /etc/krb5.conf* && \ | ||
# Note that we do NOT run `rm -rf /var/lib/apt/lists/*` here. If we did, anyone building on top of our images will | ||
# not be able to run any `apt-get install` commands and that would hamper customizability of the images. | ||
curl "https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip" -o "awscliv2.zip" && \ | ||
unzip awscliv2.zip && \ | ||
sudo ./aws/install && \ | ||
rm -rf aws awscliv2.zip && \ | ||
: && \ | ||
echo "source /usr/local/bin/_activate_current_env.sh" | tee --append /etc/profile && \ | ||
# CodeEditor - create server, user data dirs | ||
mkdir -p /opt/amazon/sagemaker/sagemaker-code-editor-server-data /opt/amazon/sagemaker/sagemaker-code-editor-user-data \ | ||
&& chown $MAMBA_USER:$MAMBA_USER /opt/amazon/sagemaker/sagemaker-code-editor-server-data /opt/amazon/sagemaker/sagemaker-code-editor-user-data && \ | ||
# create dir to store user data files | ||
mkdir -p /opt/amazon/sagemaker/user-data \ | ||
&& chown $MAMBA_USER:$MAMBA_USER /opt/amazon/sagemaker/user-data && \ | ||
# Merge in OS directory tree contents. | ||
mkdir -p ${DIRECTORY_TREE_STAGE_DIR} | ||
COPY dirs/ ${DIRECTORY_TREE_STAGE_DIR}/ | ||
RUN rsync -a ${DIRECTORY_TREE_STAGE_DIR}/ / && \ | ||
rm -rf ${DIRECTORY_TREE_STAGE_DIR} && \ | ||
# CodeEditor - download the extensions | ||
mkdir -p /etc/code-editor/extensions && \ | ||
while IFS= read -r url || [ -n "$url" ]; do \ | ||
echo "Downloading extension from ${url}..." && \ | ||
wget --no-check-certificate -P /etc/code-editor/extensions "${url}"; \ | ||
done < /etc/code-editor/extensions.txt | ||
|
||
USER $MAMBA_USER | ||
COPY --chown=$MAMBA_USER:$MAMBA_USER $ENV_IN_FILENAME *.in /tmp/ | ||
ARG MAMBA_DOCKERFILE_ACTIVATE=1 | ||
ARG CONDA_OVERRIDE_CUDA=$CUDA_MAJOR_MINOR_VERSION | ||
|
||
# Make sure that $ENV_IN_FILENAME has a newline at the end before the `tee` command runs. Otherwise, nasty things | ||
# will happen. | ||
RUN if [[ -z $ARG_BASED_ENV_IN_FILENAME ]] ; \ | ||
then echo 'No ARG_BASED_ENV_IN_FILENAME passed' ; \ | ||
else envsubst < /tmp/$ARG_BASED_ENV_IN_FILENAME | tee --append /tmp/$ENV_IN_FILENAME ; \ | ||
fi && \ | ||
# Enforce dependencies are all installed from conda-forge | ||
micromamba install -y --name base --file /tmp/$ENV_IN_FILENAME && \ | ||
micromamba clean --all --yes --force-pkgs-dirs && \ | ||
rm -rf /tmp/*.in && \ | ||
sudo ln -s $(which python3) /usr/bin/python && \ | ||
# Update npm version | ||
npm i -g npm && \ | ||
# Enforce to use `conda-forge` as only channel, by removing `defaults` | ||
conda config --remove channels defaults && \ | ||
micromamba config append channels conda-forge --env && \ | ||
# Configure CodeEditor - Install extensions and set preferences | ||
extensionloc=/opt/amazon/sagemaker/sagemaker-code-editor-server-data/extensions && mkdir -p "${extensionloc}" \ | ||
# Loop through all vsix files in /etc/code-editor/extensions and install them | ||
&& for ext in /etc/code-editor/extensions/*.vsix; do \ | ||
echo "Installing extension ${ext}..."; \ | ||
sagemaker-code-editor --install-extension "${ext}" --extensions-dir "${extensionloc}" --server-data-dir /opt/amazon/sagemaker/sagemaker-code-editor-server-data --user-data-dir /opt/amazon/sagemaker/sagemaker-code-editor-user-data; \ | ||
done \ | ||
# Copy the settings | ||
&& cp /etc/code-editor/code_editor_machine_settings.json /opt/amazon/sagemaker/sagemaker-code-editor-server-data/data/Machine/settings.json && \ | ||
# Install glue kernels, and move to shared directory | ||
# Also patching base kernel so Studio background code doesn't start session silently | ||
install-glue-kernels && \ | ||
SITE_PACKAGES=$(pip show aws-glue-sessions | grep Location | awk '{print $2}') && \ | ||
jupyter-kernelspec install $SITE_PACKAGES/aws_glue_interactive_sessions_kernel/glue_pyspark --user && \ | ||
jupyter-kernelspec install $SITE_PACKAGES/aws_glue_interactive_sessions_kernel/glue_spark --user && \ | ||
mv /home/sagemaker-user/.local/share/jupyter/kernels/glue_pyspark /opt/conda/share/jupyter/kernels && \ | ||
mv /home/sagemaker-user/.local/share/jupyter/kernels/glue_spark /opt/conda/share/jupyter/kernels && \ | ||
sed -i '/if not store_history and (/i\ if "sm_analytics_runtime_check" in code:\n return await self._complete_cell()\n' \ | ||
"$SITE_PACKAGES/aws_glue_interactive_sessions_kernel/glue_kernel_base/BaseKernel.py" && \ | ||
# Install FIPS Provider for OpenSSL, on top of existing OpenSSL installation | ||
# v3.0.8 is latest FIPS validated provider, so this is the one we install | ||
# But we need to run tests against the installed version. | ||
# see https://github.com/openssl/openssl/blob/master/README-FIPS.md https://www.openssl.org/source/ | ||
INSTALLED_SSL=$(micromamba list | grep openssl | tr -s ' ' | cut -d ' ' -f 3 | head -n 1) && \ | ||
# download source code for installed, and FIPS validated openssl versions | ||
curl -L https://www.openssl.org/source/openssl-$FIPS_VALIDATED_SSL.tar.gz > openssl-$FIPS_VALIDATED_SSL.tar.gz && \ | ||
curl -L https://www.openssl.org/source/openssl-$INSTALLED_SSL.tar.gz > openssl-$INSTALLED_SSL.tar.gz && \ | ||
tar -xf openssl-$FIPS_VALIDATED_SSL.tar.gz && tar -xf openssl-$INSTALLED_SSL.tar.gz && cd openssl-$FIPS_VALIDATED_SSL && \ | ||
# Configure both versions to enable FIPS and build | ||
./Configure enable-fips --prefix=/opt/conda --openssldir=/opt/conda/ssl && make && \ | ||
cd ../openssl-$INSTALLED_SSL && \ | ||
./Configure enable-fips --prefix=/opt/conda --openssldir=/opt/conda/ssl && make && \ | ||
# Copy validated provider to installed version for testing | ||
cp ../openssl-$FIPS_VALIDATED_SSL/providers/fips.so providers/. && \ | ||
cp ../openssl-$FIPS_VALIDATED_SSL/providers/fipsmodule.cnf providers/. && \ | ||
make tests && cd ../openssl-$FIPS_VALIDATED_SSL && \ | ||
# After tests pass, install FIPS provider and remove source code | ||
make install_fips && cd .. && rm -rf ./openssl-* && \ | ||
# Create new config file with fips-enabled. Then user can override OPENSSL_CONF to enable FIPS | ||
# e.g. export OPENSSL_CONF=/opt/conda/ssl/openssl-fips.cnf | ||
cp /opt/conda/ssl/openssl.cnf /opt/conda/ssl/openssl-fips.cnf && \ | ||
sed -i "s:# .include fipsmodule.cnf:.include /opt/conda/ssl/fipsmodule.cnf:" /opt/conda/ssl/openssl-fips.cnf && \ | ||
sed -i 's:# fips = fips_sect:fips = fips_sect:' /opt/conda/ssl/openssl-fips.cnf && \ | ||
# Install Kerberos. | ||
# Make sure no dependency is added/updated | ||
pip install "krb5>=0.5.1,<0.6" && \ | ||
pip show krb5 | grep Require | xargs -i sh -c '[ $(echo {} | cut -d: -f2 | wc -w) -eq 0 ] ' && \ | ||
# https://stackoverflow.com/questions/122327 | ||
SYSTEM_PYTHON_PATH=$(python3 -c "from __future__ import print_function;import sysconfig; print(sysconfig.get_paths().get('purelib'))") && \ | ||
# Remove SparkRKernel as it's not supported \ | ||
jupyter-kernelspec remove -f -y sparkrkernel && \ | ||
# Patch Sparkmagic lib to support Custom Certificates \ | ||
# https://github.com/jupyter-incubator/sparkmagic/pull/435/files \ | ||
cp -a ${SYSTEM_PYTHON_PATH}/sagemaker_studio_analytics_extension/patches/configuration.py ${SYSTEM_PYTHON_PATH}/sparkmagic/utils/ && \ | ||
cp -a ${SYSTEM_PYTHON_PATH}/sagemaker_studio_analytics_extension/patches/reliablehttpclient.py ${SYSTEM_PYTHON_PATH}/sparkmagic/livyclientlib/reliablehttpclient.py && \ | ||
sed -i 's= "python"= "/opt/conda/bin/python"=g' /opt/conda/share/jupyter/kernels/pysparkkernel/kernel.json /opt/conda/share/jupyter/kernels/sparkkernel/kernel.json && \ | ||
sed -i 's="Spark"="SparkMagic Spark"=g' /opt/conda/share/jupyter/kernels/sparkkernel/kernel.json && \ | ||
sed -i 's="PySpark"="SparkMagic PySpark"=g' /opt/conda/share/jupyter/kernels/pysparkkernel/kernel.json && \ | ||
# Configure RTC - disable jupyter_collaboration by default | ||
jupyter labextension disable @jupyter/collaboration-extension | ||
|
||
# Patch glue kernels to use kernel wrapper | ||
COPY patch_glue_pyspark.json /opt/conda/share/jupyter/kernels/glue_pyspark/kernel.json | ||
COPY patch_glue_spark.json /opt/conda/share/jupyter/kernels/glue_spark/kernel.json | ||
|
||
USER root | ||
|
||
# Create logging directories for supervisor | ||
RUN mkdir -p $SAGEMAKER_LOGGING_DIR && \ | ||
chmod a+rw $SAGEMAKER_LOGGING_DIR && \ | ||
mkdir -p ${STUDIO_LOGGING_DIR} && \ | ||
chown ${NB_USER}:${MAMBA_USER} ${STUDIO_LOGGING_DIR} && \ | ||
|
||
# Clean up CodeEditor artifacts | ||
rm -rf /etc/code-editor && \ | ||
# Create supervisord runtime directory | ||
mkdir -p /var/run/supervisord && \ | ||
chmod a+rw /var/run/supervisord && \ | ||
# Create root directory for DB | ||
# Create logging directories for supervisor | ||
mkdir -p $DB_ROOT_DIR && \ | ||
chmod a+rw $DB_ROOT_DIR && \ | ||
HOME_DIR="/home/${NB_USER}/licenses" \ | ||
&& mkdir -p ${HOME_DIR} \ | ||
&& curl -o ${HOME_DIR}/oss_compliance.zip https://aws-dlinfra-utilities.s3.amazonaws.com/oss_compliance.zip \ | ||
&& unzip ${HOME_DIR}/oss_compliance.zip -d ${HOME_DIR}/ \ | ||
&& cp ${HOME_DIR}/oss_compliance/test/testOSSCompliance /usr/local/bin/testOSSCompliance \ | ||
&& chmod +x /usr/local/bin/testOSSCompliance \ | ||
&& chmod +x ${HOME_DIR}/oss_compliance/generate_oss_compliance.sh \ | ||
&& ${HOME_DIR}/oss_compliance/generate_oss_compliance.sh ${HOME_DIR} python \ | ||
&& rm -rf ${HOME_DIR}/oss_compliance* | ||
|
||
ENV PATH="/opt/conda/bin:/opt/conda/condabin:$PATH" | ||
WORKDIR "/home/${NB_USER}" | ||
ENV SHELL=/bin/bash | ||
ENV OPENSSL_MODULES=/opt/conda/lib64/ossl-modules/ | ||
USER $MAMBA_USER |
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,60 @@ | ||
# Release notes: 2.0.1 | ||
|
||
Package | gpu| cpu | ||
---|---|--- | ||
python|3.11.10|3.11.10 | ||
numpy|1.26.4|1.26.4 | ||
jinja2|3.1.4|3.1.4 | ||
pytorch|2.3.1|2.3.1 | ||
altair|5.4.1|5.4.1 | ||
boto3|1.34.162|1.34.162 | ||
ipython|8.26.0|8.26.0 | ||
jupyter-lsp|2.2.5|2.2.5 | ||
jupyterlab|4.1.8|4.1.8 | ||
amazon-q-developer-jupyterlab-ext|3.2.0|3.2.0 | ||
langchain|0.2.17|0.2.17 | ||
jupyter-ai|2.20.0|2.20.0 | ||
amazon-sagemaker-jupyter-ai-q-developer|1.0.14|1.0.14 | ||
jupyter-scheduler|2.7.1|2.7.1 | ||
amazon-sagemaker-jupyter-scheduler|3.1.7|3.1.7 | ||
pandas|2.2.3|2.2.3 | ||
amazon-sagemaker-sql-magic|0.1.3|0.1.3 | ||
jupyterlab-lsp|5.0.3|5.0.3 | ||
amazon_sagemaker_sql_editor|0.1.13|0.1.13 | ||
scipy|1.12.0|1.12.0 | ||
matplotlib-base|3.9.2|3.9.2 | ||
scikit-learn|1.4.2|1.4.2 | ||
sentencepiece|0.1.99|0.1.99 | ||
pip|24.2|24.2 | ||
torchvision|0.18.1|0.18.1 | ||
autogluon|1.1.1|1.1.1 | ||
ipywidgets|8.1.5|8.1.5 | ||
notebook|7.1.3|7.1.3 | ||
aws-glue-sessions|1.0.7|1.0.7 | ||
conda|24.7.1|24.7.1 | ||
fastapi|0.110.3|0.110.3 | ||
jupyter-activity-monitor-extension|0.3.1|0.3.1 | ||
jupyter-collaboration|2.1.5|2.1.5 | ||
jupyter-dash|0.4.2|0.4.2 | ||
jupyter-server-proxy|4.3.0|4.3.0 | ||
jupyterlab-git|0.50.2|0.50.2 | ||
keras|3.5.0|3.5.0 | ||
langchain-aws|0.1.18|0.1.18 | ||
mlflow|2.15.1|2.15.1 | ||
py-xgboost-gpu|2.0.3| | ||
pyhive|0.7.0|0.7.0 | ||
python-gssapi|1.8.3|1.8.3 | ||
python-lsp-server|1.11.0|1.11.0 | ||
sagemaker-code-editor|1.3.5|1.3.5 | ||
sagemaker-headless-execution-driver|0.0.13|0.0.13 | ||
sagemaker-jupyterlab-emr-extension|0.3.4|0.3.4 | ||
sagemaker-jupyterlab-extension|0.3.2|0.3.2 | ||
sagemaker-kernel-wrapper|0.0.4|0.0.4 | ||
sagemaker-mlflow|0.1.0|0.1.0 | ||
sagemaker-python-sdk|2.227.0|2.227.0 | ||
sagemaker-studio-analytics-extension|0.1.2|0.1.2 | ||
supervisor|4.2.5|4.2.5 | ||
tensorflow|2.17.0|2.17.0 | ||
tf-keras|2.17.0|2.17.0 | ||
uvicorn|0.30.6|0.30.6 | ||
py-xgboost-cpu| |2.0.3 |
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,56 @@ | ||
# This file is auto-generated. | ||
conda-forge::jupyter-activity-monitor-extension[version='>=0.3.1,<0.4.0'] | ||
conda-forge::mlflow[version='>=2.15.1,<2.16.0'] | ||
conda-forge::sagemaker-mlflow[version='>=0.1.0,<0.2.0'] | ||
conda-forge::langchain-aws[version='>=0.1.16,<0.2.0'] | ||
conda-forge::jupyter-collaboration[version='>=2.1.2,<2.2.0'] | ||
conda-forge::sagemaker-code-editor[version='>=1.3.1,<1.4.0'] | ||
conda-forge::amazon_sagemaker_sql_editor[version='>=0.1.11,<0.2.0'] | ||
conda-forge::amazon-sagemaker-sql-magic[version='>=0.1.3,<0.2.0'] | ||
conda-forge::amazon-sagemaker-jupyter-ai-q-developer[version='>=1.0.9,<1.1.0'] | ||
conda-forge::amazon-q-developer-jupyterlab-ext[version='>=3.2.0,<3.3.0'] | ||
conda-forge::langchain[version='>=0.2.5,<0.3.0'] | ||
conda-forge::fastapi[version='>=0.110.3,<0.111.0'] | ||
conda-forge::uvicorn[version='>=0.30.6,<0.31.0'] | ||
conda-forge::pytorch[version='>=2.3.1,<2.4.0'] | ||
conda-forge::tensorflow[version='>=2.17.0,<2.18.0'] | ||
conda-forge::python[version='>=3.11.9,<3.12.0'] | ||
conda-forge::pip[version='>=24.2,<24.3.0'] | ||
conda-forge::torchvision[version='>=0.18.1,<0.19.0'] | ||
conda-forge::numpy[version='>=1.26.4,<1.27.0'] | ||
conda-forge::pandas[version='>=2.2.2,<2.3.0'] | ||
conda-forge::scikit-learn[version='>=1.4.2,<1.5.0'] | ||
conda-forge::jinja2[version='>=3.1.4,<3.2.0'] | ||
conda-forge::matplotlib-base[version='>=3.9.2,<3.10.0'] | ||
conda-forge::sagemaker-headless-execution-driver[version='>=0.0.13,<0.1.0'] | ||
conda-forge::ipython[version='>=8.26.0,<8.27.0'] | ||
conda-forge::scipy[version='>=1.12.0,<1.13.0'] | ||
conda-forge::keras[version='>=3.5.0,<3.6.0'] | ||
conda-forge::py-xgboost-cpu[version='>=2.0.3,<2.1.0'] | ||
conda-forge::jupyterlab[version='>=4.1.8,<4.2.0'] | ||
conda-forge::ipywidgets[version='>=8.1.3,<8.2.0'] | ||
conda-forge::conda[version='>=24.7.1,<24.8.0'] | ||
conda-forge::boto3[version='>=1.34.131,<1.35.0'] | ||
conda-forge::sagemaker-python-sdk[version='>=2.227.0,<2.228.0'] | ||
conda-forge::supervisor[version='>=4.2.5,<4.3.0'] | ||
conda-forge::autogluon[version='>=1.1.1,<1.2.0'] | ||
conda-forge::aws-glue-sessions[version='>=1.0.6,<1.1.0'] | ||
conda-forge::sagemaker-kernel-wrapper[version='>=0.0.2,<0.1.0'] | ||
conda-forge::jupyter-ai[version='>=2.20.0,<2.21.0'] | ||
conda-forge::jupyter-scheduler[version='>=2.7.1,<2.8.0'] | ||
conda-forge::jupyter-lsp[version='>=2.2.5,<2.3.0'] | ||
conda-forge::jupyterlab-lsp[version='>=5.0.3,<5.1.0'] | ||
conda-forge::python-lsp-server[version='>=1.11.0,<1.12.0'] | ||
conda-forge::notebook[version='>=7.1.3,<7.2.0'] | ||
conda-forge::altair[version='>=5.4.0,<5.5.0'] | ||
conda-forge::sagemaker-studio-analytics-extension[version='>=0.1.2,<0.2.0'] | ||
conda-forge::jupyter-dash[version='>=0.4.2,<0.5.0'] | ||
conda-forge::sagemaker-jupyterlab-extension[version='>=0.3.2,<0.4.0'] | ||
conda-forge::sagemaker-jupyterlab-emr-extension[version='>=0.3.2,<0.4.0'] | ||
conda-forge::amazon-sagemaker-jupyter-scheduler[version='>=3.1.3,<3.2.0'] | ||
conda-forge::jupyter-server-proxy[version='>=4.3.0,<4.4.0'] | ||
conda-forge::jupyterlab-git[version='>=0.50.1,<0.51.0'] | ||
conda-forge::pyhive[version='>=0.7.0,<0.8.0'] | ||
conda-forge::python-gssapi[version='>=1.8.3,<1.9.0'] | ||
conda-forge::tf-keras[version='>=2.17.0,<2.18.0'] | ||
conda-forge::sentencepiece[version='<=0.1.99'] |
Oops, something went wrong.