No description
db | ||
tools | ||
.gitignore | ||
config.ini.dist | ||
grid.py | ||
ioconfig.py | ||
LICENSE.md | ||
nginx-vhost-ssl.txt | ||
nginx-vhost.txt | ||
novnc.py | ||
plugin.py | ||
proxmaster.py | ||
proxmaster.service | ||
README.md | ||
requirements.txt | ||
runwebsockify.py | ||
start.sh | ||
utils.py |
#Proxmaster Python RESTful API for managing a grid of vm slaves
##Installation instructions:
1. virtualenv -p python3 appserver
2. source appserver/bin/activate
3. cd appserver
4. git clone https://deflax@bitbucket.org/deflax/proxmaster.git
5. cd proxmaster
6. pip3 install -r requirements.txt
7. create nginx vhost and configuration file via the provided template files:
- config.ini.dist
- nginx_example_vhost.txt
8. make sure this iptables rule is included:
iptables -A tcp_inbound -p TCP --match multiport --dports 7000:9999 -j ACCEPT #vnc range
9. apt install letsencrypt
10. generate letsencrypt cert using letsencrypt tool and add
00 00 1 * * root /etc/init.d/nginx stop && letsencrypt renew && /etc/init.d/nginx start
to /etc/crontab
11. chmod 705 /etc/letsencrypt/archive ; chmod 705 /etc/letsencrypt/live
start:
1. crontab -e
2. @ reboot /usr/bin/screen -dmS proxmaster /home/master/proxmaster/start.sh
##Proxmox slave install instructions:
- Datacenter -> Permissions -> Add -> User Permission
- Path: / User: masteradmin@pve / Role: Administrator
- $IPT -A tcp_inbound -p TCP -s $PROXIP -j ACCEPT #enable proxmaster
- Datacenter -> Storage -> Add -> LVM
- ID: lvm / Volume Group: vm / Content: Disk image, Container
- Datacenter -> Storage -> Add -> NFS
- ID: skyblue / Server: 1.2.3.5 / Export: /srv/proxmox/slavename / Content: ISO Image, VZDump backup site
- echo 1 > /proc/sys/kernel/dmesg_restrict