from Hacker News

Ask HN: Is Vagrant Dead?

by ingvul on 8/14/21, 1:02 PM with 14 comments

As a solo developer of a tiny Saas, I find Vagrant indispensable in my day-to-day tasks. I use it mainly as a tool to reproduce cloud infrastructure locally. As you can imagine, my cloud infrastructure is really tiny and so it's feasible to reproduce it locally on my laptop. I also use Docker extensively, but I don't think Docker replaces Vagrant at all (at least for my use cases).

While I could use a separate private cloud just for development purposes (and effectively use my laptop as a "dumb" terminal), I find it irritating because:

- It's not free. I have to pay for it

- My laptop is powerful enough to emulate my production infra

- It just feels wrong to me. I like the idea of using my own machine to develop my application and my infrastructure, and spin up/tear down VMs as many times as needed without having to worry about price

Do you still use Vagrant or similar tools to spin up VMs locally?

  • by AkshitGarg on 8/14/21, 4:22 PM

    I just checked their GitHub [0], and they seem to have a release on 27th July, 2021. Also it looks like they are re-writing vagrant 3.0 using go [1]

    [0]: https://github.com/hashicorp/vagrant

    [1]: https://www.hashicorp.com/blog/toward-vagrant-3-0

  • by aranchelk on 8/15/21, 7:29 AM

    For local development I used to use Vagrant, but now I use Docker almost exclusively, primarily because of how fast it starts and stops containers. Also I find the config format easier to work with.

    I still use Vagrant in those rare instances when Docker is not viable. Sometimes I really do need full OS instance, or need to run something other than Linux, or I just want normal bridged network interfaces.

  • by ocdtrekkie on 8/14/21, 1:08 PM

    IMHO Vagrant is "stable". Possibly boring. (A good thing for tools, generally.) But it works well.

    Why would you ask if it's dead?

  • by sergiomattei on 8/14/21, 7:41 PM

    About the point of using a dumb terminal: I tried it with a cheap DO VM, and came to the conclusion that they're woefully underpowered for any serious work compared to the laptop's processor.

    The cost to performance wasn't there: just using my laptop for development was cheaper and more performant than renting a VM monthly for cloud development.

  • by stephenr on 8/14/21, 2:06 PM

    Yes, I still use vagrant, on pretty much every project I work on - both my own/my companies, and client projects.

    I'll give two examples of how I use it:

    I (or technically, my company) produce a number of tools for managing various common aspects of a Linux web application stack.

    For each tool, there's a regular Vagrant VM setup from the root of the repo, which is used for basic testing, building, running tests etc - essentially this is just to achieve a known state, and to abstract the environment from whatever OS it's running on. Some of the tools either specifically require, or support, 'cluster' mode, where some kind of state or configuration is managed across multiple machines. For these tools, there's an additional multi-machine Vagrantfile (generally just in a subdir) which sets up a mini cluster of 2 or 3 nodes, and allows testing of the sync/replication/what have you.

    For a client I work with right now, we again, use it in two ways, achieving two separate goals:

    The primary, day to day use, is providing a completely self-contained local dev environment for the webapp. This setup is used for anyone doing dev on the app - backend, frontend, whatever.

    The less common, but still very necessary use, is similar to what you mentioned, multi-machine infra testing. The infra for this client is all provisioned using a shell script that works on a system of roles and environments. To test this, the repo with the setup has a vagrant config that matches the production environment.

    Additionally, this repo also has a packer config, which builds a custom base box, for the aforementioned "day to day dev" Vagrant env, using the same setup script.

    As mentioned by @ocdtrekkie, Vagrant is relatively stable. It'll be interesting to see where 3.0 takes things, but right now it's a pretty reliable tool, that just gets the job done.

    Edit: typo (anything -> anyone)

  • by cpach on 8/15/21, 1:14 PM

    I prefer Docker. I believe it’s a better and more convenient abstraction model.

    But not all systems are a good fit for Docker. When I need an actual VM, then Vagrant is a godsend.

  • by rthomas6 on 8/14/21, 3:16 PM

    Is this something people use Nix for?
  • by aayala on 8/14/21, 1:27 PM

    Docker