Multiple backends per project
Now, `dstack run` leverages price data from multiple configured cloud providers and regions to automatically suggest the most cost-effective options.
<img src="https://github.com/dstackai/dstack/assets/54148038/1b7eacff-fa99-4ac7-9145-d6ab0602eaf6" width="700"/>
To implement this change, we have modified the way projects are configured. You can now configure multiple clouds and regions within a single project.
<img src="https://github.com/dstackai/dstack/assets/54148038/a7eca63e-a360-41a7-b8f2-0195e1204981" width="700"/>
Custom domains and HTTPS
Also, it is now possible to deploy services using [HTTPS](https://dstack.ai/docs/guides/services/#configure-a-domain-and-enable-https-optional). All you need to do is configure a wildcard domain (e.g., `*.mydomain.com`), point it to the gateway IP address, and then pass the subdomain you want to use (e.g., `myservice.mydomain.com`) to the gateway property in YAML (instead of the gateway IP address).
Other changes
`.dstack/profiles.yml`
- The `project` property is no longer supported.
- You can now use `max_price` to set the maximum price per hour in dollars.
`dstack run`
- Using the `dstack run` command, you are now able to utilize options such as `--gpu`, `--memory`, `--env`, `--max-price`, and several [other arguments](https://dstack.ai/docs/reference/cli/run/) to override the profile settings.
Lastly, the local backend is no longer supported. Now, you can run everything using only a cloud backend.
The [documentation](https://dstack.ai/docs/) is updated to reflect the changes in the release.
Migration
The `dstack` version 0.11 update brings significant changes that break backward compatibility. If you used prior `dstack` versions, after updating to `dstack==0.11`, you'll need to log in to the UI and reconfigure clouds. We apologize for any inconvenience and aim to ensure future updates maintain backward compatibility.