-
Notifications
You must be signed in to change notification settings - Fork 550
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Serve] Enable multiple ports in SkyServe replicas #4356
base: master
Are you sure you want to change the base?
Conversation
Hi @cblmemo ! Would you like to have a look at this? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for adding this feature @Conless ! Mostly LGTM. Left a discussion.
Also we might want to update related documents for this :))
Can we also update the PR description? |
Also, it will be great if we can test on some real world usage (e.g. deploy an LLM service and expose metric port in vLLM or dashboard in ray |
@Conless Lets change the API to: service:
ports: xxx So in the future, this can be extended to: service:
ports:
- 8000,9000 # Indicating there will be one LB for all IP + Port pairs, if Port == 8000 or 9000
- 10000-10100,7888 # if port in [10000,10100] or port == 7888
- 7000 # Indicating a LB for all IP:7000 Could you help make this API change? Also, it will be great to add a smoke test, update the related doc page and resolve the merge conflict. After that this should be ready to go! |
Sure! Let me checkout to this version and add the tests |
task.service.set_port(service_port) | ||
else: | ||
port_set = set() | ||
for requested_resources in list(task.resources): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
lets assert service port is in every request resources;s ports field?
'Must only specify one port in resources. Each replica ' | ||
'will use the port specified as application ingress port.') | ||
service_port_str = requested_resources.ports[0] | ||
if not service_port_str.isdigit(): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
pls double check if we need this
assert task_resources.ports is not None | ||
return task_resources.ports[0] | ||
# Already checked all ports are valid in sky.serve.core.up | ||
assert len(task.resources) >= 1, task |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
assert len(task.resources) >= 1, task | |
assert task.resources, task |
@@ -25,6 +25,7 @@ def __init__( | |||
readiness_timeout_seconds: int, | |||
min_replicas: int, | |||
max_replicas: Optional[int] = None, | |||
port: Optional[int] = None, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
port: Optional[int] = None, | |
ports: Optional[str] = None, |
change name to ports
for future compatibiility?
@@ -388,6 +388,9 @@ def get_service_schema(): | |||
}, | |||
} | |||
}, | |||
'port': { | |||
'type': 'integer', |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
'type': 'integer', | |
'type': 'str', |
'echo "Accessing endpoints $endpoint, $endpoint_alt"; ' | ||
'curl $endpoint | grep "Hi, SkyPilot here"; ' | ||
'curl $endpoint_alt | grep "Hi, SkyPilot here"', | ||
], |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
lets also curl the load balancer endpoint?
Current implementation of SkyServe only allows the replicas to expose one port. In some cases, services may need to expose multiple ports for custom controller, GUI interface, etc. This PR adds support for it by allowing multiple ports, but requiring user to specify one as the main port in the service section, if multiple ports are provided.
The output of
sky serve status
will look like:while the other ports (8001, 3000) are still accessible.
Tested (run the relevant ones):
bash format.sh
sky serve up
,sky serve status
and accessing the service with config:pytest tests/test_smoke.py
pytest tests/test_smoke.py::test_fill_in_the_name
conda deactivate; bash -i tests/backward_compatibility_tests.sh