Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ssbostan/vboxpower
VirtualBox Power Driver for MAAS
https://github.com/ssbostan/vboxpower
driver maas provisioning ubuntu virtualbox
Last synced: about 1 month ago
JSON representation
VirtualBox Power Driver for MAAS
- Host: GitHub
- URL: https://github.com/ssbostan/vboxpower
- Owner: ssbostan
- License: apache-2.0
- Created: 2021-07-28T10:04:10.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2023-10-12T09:23:34.000Z (about 1 year ago)
- Last Synced: 2023-10-13T03:17:37.473Z (about 1 year ago)
- Topics: driver, maas, provisioning, ubuntu, virtualbox
- Language: Python
- Homepage:
- Size: 1.87 MB
- Stars: 139
- Watchers: 2
- Forks: 18
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# vboxpower
[![GitHub license](https://img.shields.io/github/license/ssbostan/vboxpower)](https://github.com/ssbostan/vboxpower/blob/master/LICENSE)
[![GitHub stars](https://img.shields.io/github/stars/ssbostan/vboxpower)](https://github.com/ssbostan/vboxpower/stargazers)
![Twitter Follow](https://img.shields.io/twitter/follow/saeidbostan?style=social)
![LinkedIn Follow](https://shields.io/badge/style-ssbostan-black?logo=linkedin&label=LinkedIn&link=https://www.linkedin.com/in/ssbostan)Stargaze ![GitHub Repo stars](https://img.shields.io/github/stars/ssbostan/vboxpower?style=social) if you find it useful.
VirtualBox Power Driver for MAAS (Metal as a Service)
A way to manage the power of VirtualBox virtual machines via the MAAS webhook driver.
## What is MAAS?
MAAS (Metal as a Service) is a tool to turns real servers into bare-metal cloud. With MAAS, you can automate server provisioning and installing OS remotely on both physical and virtual servers. [MAAS.io](https://maas.io/) for more information.
## What is vboxpower?
`vboxpower` is a wrapper to enabling MAAS to manage VirtualBox virtual machines power directly. As you know, MAAS does not natively support VirtualBox power management. Before vboxpower, you had to use `manual` power type for VirtualBox machines, the process of starting/stopping virtual machines did manually but with vboxpower this process is done automatically. So to speak, the prophecy of the vboxpower is translating power commands between VirtualBox and MAAS.
## How to install vboxpower:
Both MAAS and vboxpower are written in Python language. So, you don't need another language to run vboxpower.
### Prerequisites:
1. VirtualBox 6+ installed and running.
2. VirtualBox SDK https://www.virtualbox.org/wiki/Downloads
3. VirtualBox Extension Pack to support PXE boot.### VirtualBox SDK installation tips:
Download and extract VirtualBox SDK and run the following command.
```bash
sudo VBOX_INSTALL_PATH=/usr/lib/virtualbox python3 vboxapisetup.py install
```### Get started:
To deploy vboxpower, you need `python3-pip` to install the required packages.
The deploy script creates systemd service and copies `vboxpower.py` to `/opt/maas/vboxpower` directory.
After deployment, the deploy script starts the vboxpower service.
```bash
sudo apt update && sudo apt install -y python3-pip python3
sudo ./deploy
```### Test vboxpower:
The vboxpower is listening on port 5241/tcp on all interfaces.
You should be able to see the list of available VirtualBox virtual machines with `curl` command.
```bash
curl 192.168.56.1:5241
{
"machines": [
{
"links": {
"off": "/pfsense/off",
"on": "/pfsense/on",
"status": "/pfsense/status"
},
"name": "pfsense",
"status": "running"
},
{
"links": {
"off": "/maas/off",
"on": "/maas/on",
"status": "/maas/status"
},
"name": "maas",
"status": "running"
}
]
}
```### Integration with MAAS:
Each virtual machine exposes three endpoints that are used for vm power management.
- http://**HOST_IP**:5241/**VM_NAME**/on
- http://**HOST_IP**:5241/**VM_NAME**/off
- http://**HOST_IP**:5241/**VM_NAME**/statusUse these endpoints on MAAS Webhook power URI, respectively.
I have tested the process on Ubuntu 20.04, MAAS 3.0, and VirtualBox 6.1.16 completely.
Other versions should be work without problem.
![demo](https://raw.githubusercontent.com/ssbostan/vboxpower/master/demo.gif)
## Recommended Architecture
If you want to deploy MAAS inside a virtual machine as well, I recommend you to make an environment like the following architecture. In this architecture, you need two virtual machines to create the MAAS stack. The former is a firewall which I suggest use pfSense, OpenWrt, Ubuntu (MASQUERADE), and the latter is a virtual machine that the MAAS is deployed on that. In addition to these essential virtual machines, create target virtual machines, the machines that you want to be deployed by the MAAS platform.
The ![PURPLE](https://via.placeholder.com/15/9673A6/000000?text=+) path shows the path of the way the MAAS machine accesses the internet.
The ![RED](https://via.placeholder.com/15/B85450/000000?text=+) path shows the path of power management of the target machine.
The ![GREEN](https://via.placeholder.com/15/82B366/000000?text=+) path shows the path of how the MAAS deploys the target machine.
The ![YELLOW](https://via.placeholder.com/15/D6B656/000000?text=+) path shows the path of the way the target machine accesses the internet.
## How to contribute:
All contributions are welcomed. If you find any bugs, please file an issue.
Copyright 2021 Saeid Bostandoust