cloudvirt
Project description
cloudvirt
cloudvirt creates and destroys cloud-init
powered x86_64 VMs using the libVirt API.
installation
1. stable
pip install cloudvirt
2. dev
git clone --depth=1 https://github.com/gottaeat/cloudvirt
cd cloudvirt/
pip install .
configuration
specification
domains
key | necessity | description |
---|---|---|
dom_name | required | str name of the domain |
dom_mem | required | int amount of memory in megabytes |
dom_vcpu | required | int core count |
net | required | str name of the libVirt network to associate with the VM |
vol_pool | required | str name of the libVirt pool to associate with the VM |
vol_size | required | int disk size in gigabytes |
base_image | optional | str full name of the cloud-init capable cloud image[1] |
ip | check[2] | ipv4 ipv4 address or network to be associated with the primary interface of the VM |
sshpwauth | optional | bool whether to allow ssh authentication via passwords (VM-wide, applies to all users) |
gateway | check[3] | ipv4 the next hop to the default route |
[1] the cloud image specified must be present in the specified volume pool
and be reachable by libVirt before cloudvirt is executed. if none provided,
noble-server-cloudimg-amd64.img
is expected to be present.
[2] if specified without a /
, an attempt at DHCP and DNS reservation will
be made. specifying a gateway
makes providing a value for this key in CIDR
notation necessary.
if there is no /
, this address must be within the DHCP range of the libVirt
network specified.
[3] installed as on-link. specifying this makes an ip
to be supplied in
CIDR notation necessary.
[2+3] these keys must be supplied with a value that abides by the
requirements stated above if the network type for the specified libVirt network
is not one of: router
, nat
users
key | necessity | description |
---|---|---|
name | required | str name of the user |
password_hash | optional | str password hash in shadow compliant crypt() format (like mkuser output) |
ssh_keys | optional | list of str list of ssh keys to append to the authorized_keys of the user |
sudo_god_mode | required | bool toggle for adding the user to the sudo group and allowing it to run sudo without a password |
WARNING: if you do not specify any authentication method in the file
supplied via --users
and if you:
- do not specify an arbitrary
user-data
file via--userdata
, - or, specify a
user-data
but the resulting finalcloud-init
user-data
yaml to be written to the iso ends up having no valid authentication method
program will halt.
examples
--users <userspec.yml>
you can also do cloudvirt mkuser
to interactively generate a userspec.yml
through prompts.
---
userspec:
- name: john
password_hash: '$y$j9T$/gPg8H0fdtuZh8Ja8decf.$f7IzP89gNaToHUsY2bdgaxv2HJsKSRYLyG6mxNZ6AW3'
sudo_god_mode: true
- name: doe
ssh_keys:
- ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAI0000000000000000000000000000000000000000000
<vmspec.yml>
---
vmspec:
dom_name: cloudvirttest
dom_mem: 2048
dom_vcpu: 2
net: cloudvirt
# ip:
# gateway:
vol_pool: cloudvirt
vol_size: 10
# base_image:
# sshpwauth:
<pool.xml>
<pool type="dir">
<name>cloudvirt</name>
<target>
<path>/pools/cloudvirt</path>
</target>
</pool>
<net.xml>
<network>
<name>cloudvirt</name>
<forward mode="nat"/>
<ip address="192.168.253.1" netmask="255.255.255.0">
<dhcp>
<range start="192.168.253.1" end="192.168.253.254"/>
</dhcp>
</ip>
</network>
usage
cloudvirt --help
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file cloudvirt-0.1.2.3.tar.gz
.
File metadata
- Download URL: cloudvirt-0.1.2.3.tar.gz
- Upload date:
- Size: 26.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bc3ee50b763c919e11050051d921b3c703edf9f6605b3941b68e02848080fb38 |
|
MD5 | 06ff2ca90ac07d0917033985b255a7a0 |
|
BLAKE2b-256 | 2da81d3aa46b688a3468980101cd24fc6771208d15a4e489ec14bad112c62a43 |
File details
Details for the file cloudvirt-0.1.2.3-py2.py3-none-any.whl
.
File metadata
- Download URL: cloudvirt-0.1.2.3-py2.py3-none-any.whl
- Upload date:
- Size: 28.4 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 19ab328bec6a8f7254af4e9911ba241ba8958305a37dfff66124e12b847f8b09 |
|
MD5 | 4095773076c7caee764904fb4ddbdfca |
|
BLAKE2b-256 | b26d5b459ce7b05323c78138894d989ba13de7fbf6f46495cf5f0df86b6f89e1 |