Skip to content
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

local: virtualize all the things #45

Open
bacongobbler opened this issue Jun 14, 2022 · 5 comments
Open

local: virtualize all the things #45

bacongobbler opened this issue Jun 14, 2022 · 5 comments

Comments

@bacongobbler
Copy link
Member

bacongobbler commented Jun 14, 2022

A number of issues have cropped up using the local installer, mostly related to local system setup, permissions-based issues, and zombie processes causing indeterminate behaviour on future demo runs.

A short summary of these issues can be found here:

Additionally, some engineers have questioned whether "tire kickers" would be comfortable installing a large number of tools on their system just to run a demo.

These issues have led to a very frustrating experience. In comparison, the aws installer is a breeze to debug and clean up because it all runs on a single EC2 instance. When the EC2 instance is torn down, the entire demo is cleaned up. Re-running the demo spins up a new EC2 instance. Orphaned processes from previous demo runs never collide.

IMO these class of issues would be moot if we virtualized the local installer. Users would only require the VM driver (xhyve for MacOS, WSl 2 for Windows, and QEMU for linux) and the spin CLI. When the VM is torn down, the entire demo is cleaned up, ready for a fresh run.

@bacongobbler
Copy link
Member Author

@adamreese pointed to https://github.com/linuxkit/linuxkit/blob/master/docs/platform-hyperkit.md which may be a good jump-off point to spike this idea.

@itowlson
Copy link
Contributor

Could we Dockerise it? Or do we need a higher degree of virtualisation?

@bacongobbler
Copy link
Member Author

I recall someone mentioning nomad doesn’t run well in Docker. Whether it’s because of Docker-in-Docker issues or something else, I don’t know. But it’s worth exploring further.

@itowlson
Copy link
Contributor

That sounds plausible. This chap (https://github.com/vancluever/docker-nomad) claims to have got it working but it seems to come with lengthy instructions and caveats - Hashi not releasing an official image might be a hint that it's not optimal...

@SamiKouatli
Copy link

SamiKouatli commented Oct 4, 2022

Hello all,

I have tried to do something similar with Vagrant (with VMware on Windows) and some modifications of the local installer script + port forwarding.

So far, with a simple "vagrant up" command (and few command lines, because I have not finished yet) I can :

  • Install Rust / Spin / Traefik / Consul / Nomad / Bindle / Hippo / Fermyon
  • Launch Fermyon
  • Access Consul, Nomad and Traefik on my host computer on 127.0.0.1 with different ports

But I have some issues on :

  • Bindle server access, the URL is not accessible from my host machine.
  • Hippo is accessible but HTTP requests (like sign-up, login...) fail with error 404.

I chose Vagrant to have a full VM, this way I can have a full dev/testing environment (with local DB and other local software interacting with my Spin project) which I can kill and re-deploy very quickly between several computers and with no further setup.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants