VMM_remote-control/README.md

32 lines
1.8 KiB
Markdown
Raw Permalink Normal View History

2022-02-04 13:46:33 +00:00
# VMM_remote-control
2022-02-04 13:52:15 +00:00
## Steuerung von VMs über ein Webskript
Es ist ja immer eine heikle Sache, von außen Prozesse im DSM zu steuern. Besser ist es immer, von innen nach außen zu arbeiten. In diesem Fall wird beides kombiniert. Einzige Vorraussetzung ist die Webstation sowie die [Inotify-tools](https://synocommunity.com/package/inotify-tools).
2022-02-04 16:37:26 +00:00
Über eine URL kann man eine kleine Steuerdatei auf dem Webserver manipulieren. Inotifywait prüft diese Datei permanent auf Änderungen und wertet definierte Parameter aus um ggf. die VM zu starten oder zu stoppen.
2022-02-04 16:45:01 +00:00
Beispiel, um die VM mit Namen `Win10` zu starten (der hinterlegte Key lautet 0815):
`https://example.com/vm_control.php?vmname=Win10&state=on&key=0815`
2022-02-04 16:37:44 +00:00
> Einschränkung:
2022-02-04 16:37:26 +00:00
> VMs, die lediglich angehalten wurden, können so nicht gestartet werden. Dafür hatte ich den passenden Befehl nicht gefunden. Wenn ihn jemand hat: immer her damit 😃
2022-02-04 14:37:58 +00:00
* läuft die Web Station mit PHP und ist von da erreichbar, von wo aus man das Skript starten möchte?
* sind die inotify-tools installiert?
1. lege die Datei `vm_control.php` in ein Webverzeichnis deiner Wahl
2. (optional) Passe den Key nach deinen Wünschen an (Standard: `0815`)
3. lege die Datei `vm_control.sh` in ein nicht öffentliches Verzeichnis ab
4. mache das Skript ausführbar (`chmod +x "/pfad/zum/skrip/vm_control.sh"`)
5. öffne das Skript in einem Texteditor (z.B. den DSM eigenen) und passe den Pfad zu der Datei `vm_control.php` an.
2022-02-04 14:45:53 +00:00
6. Jetzt muss nur noch die Überwachung der automatisch erstellten Datei `vm_state.php` gestartet oder gestoppt werden. Am einfachsten geht das im DSM-Aufgabenplaner. Wichtig: der User `root` muss genutzt werden, da nur er die VM starten kann.
```
/pfad/zu/vm_control.sh start
2022-02-04 14:45:02 +00:00
# oder
2022-02-04 14:45:53 +00:00
/pfad/zu/vm_control.sh stop
```