-
Notifications
You must be signed in to change notification settings - Fork 1
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
How to handle networking #71
Comments
On this, PAWS (our pipeline orgistrator) would need to talk to a docker socket (or the k8s api), and so that's a somewhat interesting setup for the second case. |
First part, basic networking. Yep, there are plans to add support for this directly in the ExecutionBroker data model. Probably around 80% of the use cases will just need an external network port that can be accessed from the public internet. For a HTTP web service:
Or a webtop desktop application:
|
For communication between executables (e.g. running some analysis with a database sidecar), we could extend the ExecutionBroker model to handle this. However it might be better to delegate a lot of the complexity to an orchestration system like Docker Compose or Kubernetes. For example, if the application and database sidecar could be described in a Docker Compose file, then that would become the executable. See #72.
The compose file would contain details of the application and database sidecar, along with the internal filesystem and network connecting them. This would provide access to all of the Docker Compose tools for orchestrating inter-container filesystem and networking, without us having to re-invent any wheels. For a more complex deployment, we could do something similar using Kubernetes. Where the application developer wraps the deployment in a Heml chart, and that becomes the executable. See #73.
Here the user is asking the platform for space on a Kubernetes cluster to run a Helm chart. The Helm chart would include all the details of how to maps storage volumes to PersistentVolumes and PersistentVolumeClaims, and Services to LoadBalancers and network ports. |
Looking at the latest draft, there's nothing about networking yet (I'm guessing @Zarquan that only because you've not had time to push what you've got).
My feeling is this can be summarised into two groups:
I think the former is easy to specify in abstract terms, but the latter to me feels a bit system specific (if the state of k8s networking is any guide)?
The text was updated successfully, but these errors were encountered: