-
Notifications
You must be signed in to change notification settings - Fork 548
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[perf] use uv for venv creation and pip install (#4414)
* Revert "remove `uv` from runtime setup due to azure installation issue (#4401)" This reverts commit 0b20d56. * on azure, use --prerelease=allow to install azure-cli * use uv venv --seed * fix backwards compatibility * really fix backwards compatibility * use uv to set up controller dependencies * fix python 3.8 * lint * add missing file * update comment * split out azure-cli dep * fix lint for dependencies * use runpy.run_path rather than modifying sys.path * fix cloud dependency installation commands * lint * Update sky/utils/controller_utils.py Co-authored-by: Zhanghao Wu <[email protected]> --------- Co-authored-by: Zhanghao Wu <[email protected]>
- Loading branch information
1 parent
2157f01
commit de561c2
Showing
5 changed files
with
239 additions
and
232 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,141 @@ | ||
"""Dependencies for SkyPilot. | ||
This file is imported by setup.py, so: | ||
- It may not be able to import other skypilot modules, since sys.path may not be | ||
correct. | ||
- It should not import any dependencies, as they may not be installed yet. | ||
""" | ||
from typing import Dict, List | ||
|
||
install_requires = [ | ||
'wheel', | ||
'cachetools', | ||
# NOTE: ray requires click>=7.0. | ||
'click >= 7.0', | ||
'colorama', | ||
'cryptography', | ||
# Jinja has a bug in older versions because of the lack of pinning | ||
# the version of the underlying markupsafe package. See: | ||
# https://github.com/pallets/jinja/issues/1585 | ||
'jinja2 >= 3.0', | ||
'jsonschema', | ||
'networkx', | ||
'pandas>=1.3.0', | ||
'pendulum', | ||
# PrettyTable with version >=2.0.0 is required for the support of | ||
# `add_rows` method. | ||
'PrettyTable >= 2.0.0', | ||
'python-dotenv', | ||
'rich', | ||
'tabulate', | ||
# Light weight requirement, can be replaced with "typing" once | ||
# we deprecate Python 3.7 (this will take a while). | ||
'typing_extensions', | ||
'filelock >= 3.6.0', | ||
'packaging', | ||
'psutil', | ||
'pulp', | ||
# Cython 3.0 release breaks PyYAML 5.4.* | ||
# (https://github.com/yaml/pyyaml/issues/601) | ||
# <= 3.13 may encounter https://github.com/ultralytics/yolov5/issues/414 | ||
'pyyaml > 3.13, != 5.4.*', | ||
'requests', | ||
] | ||
|
||
local_ray = [ | ||
# Lower version of ray will cause dependency conflict for | ||
# click/grpcio/protobuf. | ||
# Excluded 2.6.0 as it has a bug in the cluster launcher: | ||
# https://github.com/ray-project/ray/releases/tag/ray-2.6.1 | ||
'ray[default] >= 2.2.0, != 2.6.0', | ||
] | ||
|
||
remote = [ | ||
# Adopted from ray's setup.py: | ||
# https://github.com/ray-project/ray/blob/ray-2.4.0/python/setup.py | ||
# SkyPilot: != 1.48.0 is required to avoid the error where ray dashboard | ||
# fails to start when ray start is called (#2054). | ||
# Tracking issue: https://github.com/ray-project/ray/issues/30984 | ||
'grpcio >= 1.32.0, <= 1.49.1, != 1.48.0; python_version < \'3.10\' and sys_platform == \'darwin\'', # noqa:E501 pylint: disable=line-too-long | ||
'grpcio >= 1.42.0, <= 1.49.1, != 1.48.0; python_version >= \'3.10\' and sys_platform == \'darwin\'', # noqa:E501 pylint: disable=line-too-long | ||
# Original issue: https://github.com/ray-project/ray/issues/33833 | ||
'grpcio >= 1.32.0, <= 1.51.3, != 1.48.0; python_version < \'3.10\' and sys_platform != \'darwin\'', # noqa:E501 pylint: disable=line-too-long | ||
'grpcio >= 1.42.0, <= 1.51.3, != 1.48.0; python_version >= \'3.10\' and sys_platform != \'darwin\'', # noqa:E501 pylint: disable=line-too-long | ||
# Adopted from ray's setup.py: | ||
# https://github.com/ray-project/ray/blob/ray-2.9.3/python/setup.py#L343 | ||
'protobuf >= 3.15.3, != 3.19.5', | ||
# Some pydantic versions are not compatible with ray. Adopted from ray's | ||
# setup.py: | ||
# https://github.com/ray-project/ray/blob/ray-2.9.3/python/setup.py#L254 | ||
'pydantic!=2.0.*,!=2.1.*,!=2.2.*,!=2.3.*,!=2.4.*,<3', | ||
] | ||
|
||
# NOTE: Change the templates/jobs-controller.yaml.j2 file if any of the | ||
# following packages dependencies are changed. | ||
aws_dependencies = [ | ||
# botocore does not work with urllib3>=2.0.0, according to | ||
# https://github.com/boto/botocore/issues/2926 | ||
# We have to explicitly pin the version to optimize the time for | ||
# poetry install. See https://github.com/orgs/python-poetry/discussions/7937 | ||
'urllib3<2', | ||
# NOTE: this installs CLI V1. To use AWS SSO (e.g., `aws sso login`), users | ||
# should instead use CLI V2 which is not pip-installable. See | ||
# https://docs.aws.amazon.com/cli/latest/userguide/getting-started-install.html. | ||
'awscli>=1.27.10', | ||
'botocore>=1.29.10', | ||
'boto3>=1.26.1', | ||
# NOTE: required by awscli. To avoid ray automatically installing | ||
# the latest version. | ||
'colorama < 0.4.5', | ||
] | ||
|
||
# azure-cli cannot be installed normally by uv, so we need to work around it in | ||
# a few places. | ||
AZURE_CLI = 'azure-cli>=2.65.0' | ||
|
||
extras_require: Dict[str, List[str]] = { | ||
'aws': aws_dependencies, | ||
# TODO(zongheng): azure-cli is huge and takes a long time to install. | ||
# Tracked in: https://github.com/Azure/azure-cli/issues/7387 | ||
# azure-identity is needed in node_provider. | ||
# We need azure-identity>=1.13.0 to enable the customization of the | ||
# timeout of AzureCliCredential. | ||
'azure': [ | ||
AZURE_CLI, | ||
'azure-core>=1.31.0', | ||
'azure-identity>=1.19.0', | ||
'azure-mgmt-network>=27.0.0', | ||
'azure-mgmt-compute>=33.0.0', | ||
'azure-storage-blob>=12.23.1', | ||
'msgraph-sdk', | ||
] + local_ray, | ||
# We need google-api-python-client>=2.69.0 to enable 'discardLocalSsd' | ||
# parameter for stopping instances. Reference: | ||
# https://github.com/googleapis/google-api-python-client/commit/f6e9d3869ed605b06f7cbf2e8cf2db25108506e6 | ||
'gcp': ['google-api-python-client>=2.69.0', 'google-cloud-storage'], | ||
'ibm': [ | ||
'ibm-cloud-sdk-core', 'ibm-vpc', 'ibm-platform-services', 'ibm-cos-sdk' | ||
] + local_ray, | ||
'docker': ['docker'] + local_ray, | ||
'lambda': local_ray, | ||
'cloudflare': aws_dependencies, | ||
'scp': local_ray, | ||
'oci': ['oci'] + local_ray, | ||
'kubernetes': ['kubernetes>=20.0.0'], | ||
'remote': remote, | ||
'runpod': ['runpod>=1.5.1'], | ||
'fluidstack': [], # No dependencies needed for fluidstack | ||
'cudo': ['cudo-compute>=0.1.10'], | ||
'paperspace': [], # No dependencies needed for paperspace | ||
'vsphere': [ | ||
'pyvmomi==8.0.1.0.2', | ||
# vsphere-automation-sdk is also required, but it does not have | ||
# pypi release, which cause failure of our pypi release. | ||
# https://peps.python.org/pep-0440/#direct-references | ||
# We have the instruction for its installation in our | ||
# docs instead. | ||
# 'vsphere-automation-sdk @ git+https://github.com/vmware/[email protected]' pylint: disable=line-too-long | ||
], | ||
} | ||
|
||
extras_require['all'] = sum(extras_require.values(), []) |
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 |
---|---|---|
|
@@ -18,19 +18,28 @@ | |
import os | ||
import platform | ||
import re | ||
import runpy | ||
import subprocess | ||
import sys | ||
from typing import Dict, List | ||
|
||
import setuptools | ||
|
||
# __file__ is setup.py at the root of the repo. We shouldn't assume it's a | ||
# symlink - e.g. in the sdist it's resolved to a normal file. | ||
ROOT_DIR = os.path.dirname(__file__) | ||
DEPENDENCIES_FILE_PATH = os.path.join(ROOT_DIR, 'sky', 'setup_files', | ||
'dependencies.py') | ||
INIT_FILE_PATH = os.path.join(ROOT_DIR, 'sky', '__init__.py') | ||
_COMMIT_FAILURE_MESSAGE = ( | ||
'WARNING: SkyPilot fail to {verb} the commit hash in ' | ||
f'{INIT_FILE_PATH!r} (SkyPilot can still be normally used): ' | ||
'{error}') | ||
|
||
# setuptools does not include the script dir on the search path, so we can't | ||
# just do `import dependencies`. Instead, use runpy to manually load it. Note: | ||
# dependencies here is a dict, not a module, so we access it by subscripting. | ||
dependencies = runpy.run_path(DEPENDENCIES_FILE_PATH) | ||
|
||
original_init_content = None | ||
|
||
system = platform.system() | ||
|
@@ -130,127 +139,6 @@ def parse_readme(readme: str) -> str: | |
return readme | ||
|
||
|
||
install_requires = [ | ||
'wheel', | ||
'cachetools', | ||
# NOTE: ray requires click>=7.0. | ||
'click >= 7.0', | ||
'colorama', | ||
'cryptography', | ||
# Jinja has a bug in older versions because of the lack of pinning | ||
# the version of the underlying markupsafe package. See: | ||
# https://github.com/pallets/jinja/issues/1585 | ||
'jinja2 >= 3.0', | ||
'jsonschema', | ||
'networkx', | ||
'pandas>=1.3.0', | ||
'pendulum', | ||
# PrettyTable with version >=2.0.0 is required for the support of | ||
# `add_rows` method. | ||
'PrettyTable >= 2.0.0', | ||
'python-dotenv', | ||
'rich', | ||
'tabulate', | ||
# Light weight requirement, can be replaced with "typing" once | ||
# we deprecate Python 3.7 (this will take a while). | ||
'typing_extensions', | ||
'filelock >= 3.6.0', | ||
'packaging', | ||
'psutil', | ||
'pulp', | ||
# Cython 3.0 release breaks PyYAML 5.4.* (https://github.com/yaml/pyyaml/issues/601) | ||
# <= 3.13 may encounter https://github.com/ultralytics/yolov5/issues/414 | ||
'pyyaml > 3.13, != 5.4.*', | ||
'requests', | ||
] | ||
|
||
local_ray = [ | ||
# Lower version of ray will cause dependency conflict for | ||
# click/grpcio/protobuf. | ||
# Excluded 2.6.0 as it has a bug in the cluster launcher: | ||
# https://github.com/ray-project/ray/releases/tag/ray-2.6.1 | ||
'ray[default] >= 2.2.0, != 2.6.0', | ||
] | ||
|
||
remote = [ | ||
# Adopted from ray's setup.py: https://github.com/ray-project/ray/blob/ray-2.4.0/python/setup.py | ||
# SkyPilot: != 1.48.0 is required to avoid the error where ray dashboard fails to start when | ||
# ray start is called (#2054). | ||
# Tracking issue: https://github.com/ray-project/ray/issues/30984 | ||
"grpcio >= 1.32.0, <= 1.49.1, != 1.48.0; python_version < '3.10' and sys_platform == 'darwin'", # noqa:E501 | ||
"grpcio >= 1.42.0, <= 1.49.1, != 1.48.0; python_version >= '3.10' and sys_platform == 'darwin'", # noqa:E501 | ||
# Original issue: https://github.com/ray-project/ray/issues/33833 | ||
"grpcio >= 1.32.0, <= 1.51.3, != 1.48.0; python_version < '3.10' and sys_platform != 'darwin'", # noqa:E501 | ||
"grpcio >= 1.42.0, <= 1.51.3, != 1.48.0; python_version >= '3.10' and sys_platform != 'darwin'", # noqa:E501 | ||
# Adopted from ray's setup.py: | ||
# https://github.com/ray-project/ray/blob/ray-2.9.3/python/setup.py#L343 | ||
'protobuf >= 3.15.3, != 3.19.5', | ||
# Some pydantic versions are not compatible with ray. Adopted from ray's | ||
# setup.py: https://github.com/ray-project/ray/blob/ray-2.9.3/python/setup.py#L254 | ||
'pydantic!=2.0.*,!=2.1.*,!=2.2.*,!=2.3.*,!=2.4.*,<3', | ||
] | ||
|
||
# NOTE: Change the templates/jobs-controller.yaml.j2 file if any of the | ||
# following packages dependencies are changed. | ||
aws_dependencies = [ | ||
# botocore does not work with urllib3>=2.0.0, according to https://github.com/boto/botocore/issues/2926 | ||
# We have to explicitly pin the version to optimize the time for | ||
# poetry install. See https://github.com/orgs/python-poetry/discussions/7937 | ||
'urllib3<2', | ||
# NOTE: this installs CLI V1. To use AWS SSO (e.g., `aws sso login`), users | ||
# should instead use CLI V2 which is not pip-installable. See | ||
# https://docs.aws.amazon.com/cli/latest/userguide/getting-started-install.html. | ||
'awscli>=1.27.10', | ||
'botocore>=1.29.10', | ||
'boto3>=1.26.1', | ||
# NOTE: required by awscli. To avoid ray automatically installing | ||
# the latest version. | ||
'colorama < 0.4.5', | ||
] | ||
|
||
extras_require: Dict[str, List[str]] = { | ||
'aws': aws_dependencies, | ||
# TODO(zongheng): azure-cli is huge and takes a long time to install. | ||
# Tracked in: https://github.com/Azure/azure-cli/issues/7387 | ||
# azure-identity is needed in node_provider. | ||
# We need azure-identity>=1.13.0 to enable the customization of the | ||
# timeout of AzureCliCredential. | ||
'azure': [ | ||
'azure-cli>=2.65.0', 'azure-core>=1.31.0', 'azure-identity>=1.19.0', | ||
'azure-mgmt-network>=27.0.0', 'azure-mgmt-compute>=33.0.0', | ||
'azure-storage-blob>=12.23.1', 'msgraph-sdk' | ||
] + local_ray, | ||
# We need google-api-python-client>=2.69.0 to enable 'discardLocalSsd' | ||
# parameter for stopping instances. | ||
# Reference: https://github.com/googleapis/google-api-python-client/commit/f6e9d3869ed605b06f7cbf2e8cf2db25108506e6 | ||
'gcp': ['google-api-python-client>=2.69.0', 'google-cloud-storage'], | ||
'ibm': [ | ||
'ibm-cloud-sdk-core', 'ibm-vpc', 'ibm-platform-services', 'ibm-cos-sdk' | ||
] + local_ray, | ||
'docker': ['docker'] + local_ray, | ||
'lambda': local_ray, | ||
'cloudflare': aws_dependencies, | ||
'scp': local_ray, | ||
'oci': ['oci'] + local_ray, | ||
'kubernetes': ['kubernetes>=20.0.0'], | ||
'remote': remote, | ||
'runpod': ['runpod>=1.5.1'], | ||
'fluidstack': [], # No dependencies needed for fluidstack | ||
'cudo': ['cudo-compute>=0.1.10'], | ||
'paperspace': [], # No dependencies needed for paperspace | ||
'vsphere': [ | ||
'pyvmomi==8.0.1.0.2', | ||
# vsphere-automation-sdk is also required, but it does not have | ||
# pypi release, which cause failure of our pypi release. | ||
# https://peps.python.org/pep-0440/#direct-references | ||
# We have the instruction for its installation in our | ||
# docs instead. | ||
# 'vsphere-automation-sdk @ git+https://github.com/vmware/[email protected]' | ||
], | ||
} | ||
|
||
extras_require['all'] = sum(extras_require.values(), []) | ||
|
||
long_description = '' | ||
readme_filepath = 'README.md' | ||
# When sky/backends/wheel_utils.py builds wheels, it will not contain the | ||
|
@@ -277,8 +165,8 @@ def parse_readme(readme: str) -> str: | |
long_description_content_type='text/markdown', | ||
setup_requires=['wheel'], | ||
requires_python='>=3.7', | ||
install_requires=install_requires, | ||
extras_require=extras_require, | ||
install_requires=dependencies['install_requires'], | ||
extras_require=dependencies['extras_require'], | ||
entry_points={ | ||
'console_scripts': ['sky = sky.cli:cli'], | ||
}, | ||
|
Oops, something went wrong.