From 710e6136554ec437e3c3a9d812346fcfdd3569d4 Mon Sep 17 00:00:00 2001 From: Tian Xia Date: Sun, 26 Nov 2023 09:52:23 -0800 Subject: [PATCH] [SkyServe] New method to install cloud dependencies (#2822) * change dependency installation * dependency * fix bugs * grep pip list first --- sky/execution.py | 3 -- sky/serve/core.py | 3 -- sky/setup_files/setup.py | 3 +- sky/templates/sky-serve-controller.yaml.j2 | 10 +++--- sky/templates/spot-controller.yaml.j2 | 18 +++------- sky/utils/controller_utils.py | 41 ++++++++++++++++++++-- 6 files changed, 50 insertions(+), 28 deletions(-) diff --git a/sky/execution.py b/sky/execution.py index affe3c1e90d..b473df4a95b 100644 --- a/sky/execution.py +++ b/sky/execution.py @@ -20,7 +20,6 @@ from sky import spot from sky import task as task_lib from sky.backends import backend_utils -from sky.clouds import gcp from sky.skylet import constants from sky.usage import usage_lib from sky.utils import common_utils @@ -688,8 +687,6 @@ def spot_launch( 'spot_controller': controller_name, # Note: actual spot cluster name will be - 'dag_name': dag.name, - 'google_sdk_installation_commands': - gcp.GOOGLE_SDK_INSTALLATION_COMMAND, 'retry_until_up': retry_until_up, **extra_vars, } diff --git a/sky/serve/core.py b/sky/serve/core.py index 44ae04c4c02..d1c9e1914fc 100644 --- a/sky/serve/core.py +++ b/sky/serve/core.py @@ -14,7 +14,6 @@ from sky import status_lib from sky import task as task_lib from sky.backends import backend_utils -from sky.clouds import gcp from sky.serve import constants as serve_constants from sky.serve import serve_utils from sky.skylet import constants @@ -103,8 +102,6 @@ def up( vars_to_fill = { 'remote_task_yaml_path': remote_tmp_task_yaml_path, 'local_task_yaml_path': service_file.name, - 'google_sdk_installation_commands': - gcp.GOOGLE_SDK_INSTALLATION_COMMAND, 'service_name': service_name, 'controller_log_file': controller_log_file, **extra_vars, diff --git a/sky/setup_files/setup.py b/sky/setup_files/setup.py index 2bf615fd1d2..5cbc801b2e8 100644 --- a/sky/setup_files/setup.py +++ b/sky/setup_files/setup.py @@ -230,11 +230,10 @@ def parse_readme(readme: str) -> str: 'docker': ['docker'] + local_ray, 'lambda': local_ray, 'cloudflare': aws_dependencies, - 'scp': [] + local_ray, + 'scp': local_ray, 'oci': ['oci'] + local_ray, 'kubernetes': ['kubernetes'] + local_ray, 'remote': remote, - 'serve': ['uvicorn', 'fastapi'], } extras_require['all'] = sum(extras_require.values(), []) diff --git a/sky/templates/sky-serve-controller.yaml.j2 b/sky/templates/sky-serve-controller.yaml.j2 index 0c3378afc56..362bd4a93da 100644 --- a/sky/templates/sky-serve-controller.yaml.j2 +++ b/sky/templates/sky-serve-controller.yaml.j2 @@ -6,11 +6,13 @@ setup: | # Install all cloud dependencies. # This is for multicloud support. To allow controller launch on all clouds, # we need to install all cloud dependencies. - # This also includes all serve dependencies. - pip install skypilot[all] > /dev/null 2>&1 + {%- for cmd in cloud_dependencies_installation_commands %} + {{cmd}} + {%- endfor %} - # Install gcloud CLI. - {{google_sdk_installation_commands}} + # Install serve dependencies. + pip list | grep uvicorn > /dev/null 2>&1 || pip install uvicorn > /dev/null 2>&1 + pip list | grep fastapi > /dev/null 2>&1 || pip install fastapi > /dev/null 2>&1 file_mounts: {{remote_task_yaml_path}}: {{local_task_yaml_path}} diff --git a/sky/templates/spot-controller.yaml.j2 b/sky/templates/spot-controller.yaml.j2 index 746322fd956..ee9d863e83f 100644 --- a/sky/templates/spot-controller.yaml.j2 +++ b/sky/templates/spot-controller.yaml.j2 @@ -9,22 +9,12 @@ file_mounts: {% endif %} setup: | - # Install cli dependencies - # Not using SkyPilot wheels because the wheel can be cleaned up by another process. - # TODO(zhwu): Keep the dependencies align with the ones in setup.py - (pip list | grep boto3 > /dev/null 2>&1 && \ - pip list | grep google-api-python-client > /dev/null 2>&1 ) || \ - pip install boto3 awscli pycryptodome==3.12.0 google-api-python-client google-cloud-storage 2>&1 > /dev/null + {%- for cmd in cloud_dependencies_installation_commands %} + {{cmd}} + {%- endfor %} - # We do not install azure dependencies for now since our subscription does not support spot instances. - # pip list | grep azure-cli > /dev/null 2>&1 || \ - # pip3 install azure-cli==2.31.0 azure-core - {{google_sdk_installation_commands}} - - pip list | grep oci > /dev/null 2>&1 || pip install oci 2>&1 > /dev/null - - # Internal: disable logging for manually logging into the spot controller for debugging. {% if is_dev %} + # Internal: disable logging for manually logging into the spot controller for debugging. echo 'export SKYPILOT_DEV=1' >> ~/.bashrc {% endif %} diff --git a/sky/utils/controller_utils.py b/sky/utils/controller_utils.py index 4cc74ede590..00f39e3756a 100644 --- a/sky/utils/controller_utils.py +++ b/sky/utils/controller_utils.py @@ -6,13 +6,14 @@ import os import tempfile import typing -from typing import Any, Dict, Optional, Tuple +from typing import Any, Dict, List, Optional, Tuple import colorama from sky import exceptions from sky import sky_logging from sky import skypilot_config +from sky.clouds import gcp from sky.data import data_utils from sky.data import storage as storage_lib from sky.serve import serve_utils @@ -122,6 +123,39 @@ def from_name(cls, name: Optional[str]) -> Optional['Controllers']: return None +# Install cli dependencies. Not using SkyPilot wheels because the wheel +# can be cleaned up by another process. +# TODO(zhwu): Keep the dependencies align with the ones in setup.py +def _get_cloud_dependencies_installation_commands( + controller_type: str) -> List[str]: + commands = [ + # aws + 'pip list | grep boto3 > /dev/null 2>&1 || ' + 'pip install "urllib3<2" awscli>=1.27.10 botocore>=1.29.10 ' + 'boto3>=1.26.1 > /dev/null 2>&1', + # gcp + 'pip list | grep google-api-python-client > /dev/null 2>&1 || ' + 'pip install google-api-python-client>=2.69.0 google-cloud-storage ' + '> /dev/null 2>&1', + f'{gcp.GOOGLE_SDK_INSTALLATION_COMMAND}', + ] + # k8s and ibm doesn't support open port and spot instance yet, so we don't + # install them for either controller. + if controller_type == 'spot': + # oci doesn't support open port yet, so we don't install oci + # dependencies for sky serve controller. + commands.append('pip list | grep oci > /dev/null 2>&1 || ' + 'pip install oci > /dev/null 2>&1') + else: + # We do not install azure dependencies for spot controller since our + # subscription does not support spot instances. + commands.append( + 'pip list | grep azure-cli > /dev/null 2>&1 || ' + 'pip install azure-cli>=2.31.0 azure-core azure-identity>=1.13.0 ' + 'azure-mgmt-network > /dev/null 2>&1') + return commands + + def check_cluster_name_not_controller( cluster_name: Optional[str], operation_str: Optional[str] = None) -> None: @@ -214,7 +248,10 @@ def skypilot_config_setup( The controller_resources_config is the resources config that will be used to launch the controller. """ - vars_to_fill: Dict[str, Any] = {} + vars_to_fill: Dict[str, Any] = { + 'cloud_dependencies_installation_commands': + _get_cloud_dependencies_installation_commands(controller_type) + } controller_envs = _shared_controller_env_vars() controller_resources_config_copied: Dict[str, Any] = copy.copy( controller_resources_config)