2 |kontakt = {{Benutzer|53c70r}}
6 |usage = <!-- optional -->
9 Acolyte ist ein im Space lokaler VM-Host, welcher nach Bedarf angeschaltet werden kann, um z.B. Dinge zu bauen.
13 Virtualisierung: QEMU/KVM Libvirt
14 Speicherplatz: 4 Platten als mdadm RAID6 (/dev/md0 ist LUKS encrypted)
16 MAC: 00:19:99:da:6a:0e
17 Das Management der VM's erfolgt durch die Nutzung von virt-manager, sowohl für die user, als auch für die admins.<br />
18 Unprivilegierte user Zugriffe sind limitiert und bieten keine Möglichkeit Einstellungen der jeweiligen VM zu manipulieren oder andere VM's zu sehen.<br />
19 Mittels SELinux und Polkit werden neue unprivilegierte Nutzer hinzugefügt, denen man dann VM's zuweisen kann.<br />
20 Ein Beispiel für das Hinzufügen vom user "test":
21 [root@acolyte ~]# useradd test
22 [root@acolyte ~]# semanage login -s user_u -a test
23 [root@acolyte ~]# vim /etc/security/limits.conf
24 nun in limits.conf am Ende folgendes hinzufügen:
26 test hard memlock 102400
28 Nun den user public SSH-Key hinzufügen (nur RSA ist erlaubt):
29 [root@acolyte ~]# su test
30 [test@acolyte ~]$ cd ~
31 [test@acolyte ~]$ umask 022
32 [test@acolyte ~]$ mkdir .ssh
33 [test@acolyte ~]$ echo "ssh-rsa AAAAB3NzaC..." > .ssh/authorized_keys
34 "test" sollte nun in der Lage sein sich auf dem Server einzuloggen.<br />
35 Nun downloaden wir als admin die gewünschte iso für die VM:
36 [user@acolyte ~]$ wget -O iso/debian-10.1.0-amd64-netinst.iso https://cdimage.debian.org/debian-cd/current/amd64/iso-cd/debian-10.1.0-amd64-netinst.iso
37 Als Nächstes kümmern wir uns um das Aufsetzen der VM von "test".<br />
38 Dazu verbinden wir uns als admin mittels virt-manager auf den Server und fügen die VM hinzu.<br />
39 Als "Network selection" sollte "Host device enp6s0: macvtap", "Source mode: Bridge" gewählt werden.<br />
40 Nun geben wir noch dem user "test" die Freigabe sich auf die VM verbinden zu können:
41 [root@acolyte ~]# vim /etc/polkit-1/rules.d/51-libvirt.rules
42 Wir fügen nun zwei Java Script Zeilen in 51-libvirt.rules hinzu;<br />
43 im zweiten Funktionsblock:
44 if (subject.user == "test") return polkit.Result.YES;
45 und im ersten Funktionsblock:
46 if (a.lookup("domain_uuid") == "cdf9d60b-8cf7-496b-88d4-3ae489969c8f" && s.user == "test") return true;
47 Die domain_uuid ist als admin unter VM Einstellungen zu sehen.<br />
48 Der user "test" sollte nun in der Lage sein seine domain zu konfigurieren.
51 Ein in Sachen CPUs, RAM und SSD etwas aufgerüsteter Server auf Basis des Servers aus der Hardwarespende von Alexander.
52 Server Fujitsu Primergy TX200 S6
53 CPUs: 2* [https://ark.intel.com/content/www/us/en/ark/products/48768/intel-xeon-processor-e5645-12m-cache-2-40-ghz-5-86-gt-s-intel-qpi.html Intel Xeon E5645] (6 Cores pro CPU, 2 Threads pro Core)
54 RAM: je CPU 4*4 GB 10600PC3 Samsung DDR3 ECC
55 Mainboard: D2799-N10 GS4
56 SSD: 120GB Patriot Burst
57 HDDs: 4* 500GB WD RE4 von 2012 WD5003ABYX