Benutzer-Werkzeuge

Webseiten-Werkzeuge


howto:installation_auf_webhoster_2

Dies ist eine alte Version des Dokuments!


Volkszaehler bei einem Webhoster installieren (2)

Motivation

Nicht jeder hat vielleicht einen eigenen 24/7 Server für den Volkszähler zu Verfügung oder es nervt die Performance eines low-cost LAMP Ansatzes (z.B. auf RaspberryPi). Wer bei einer Monatsanzeige schon mal gefühlte Stunden gewartet hat, sehnt sich nach mehr Leistung. Ein Lösungsansatz kann eine Webhoster Implementierung sein. Für einen erträglichen Monatsbetrag (geht so ab 1,99€/Monat los) bekommt man eine eigene Domain und ein paar GigaByte Webspace. Diese preiswerten Angebote bieten allerdings keinen root Zugang und somit ist die Einrichtung des Volkszählers nicht über den Standardweg zu erledigen. Mit ein paar Handmodifikationen läßt sich das aber in Griff kriegen.

Voraussetzungen

Für unsere Installation auf dem Webhoster gelten die gleichen Bedingungen für den VZ wie für jeden anderen Server. Auf die folgenden Punkte sollte man bei der Auswahl des Hosters achten:

  • PHP 5.3 (ganz wichtig!, die PHP Version kann zum Glück bei einigen Webhoster frei ausgewählt werden)
  • MySQL (mindestens eine Datenbank muss erlaubt sein)
  • phpmyadmin (Vereinfacht das eventuelle Eingreifen in die DB)
  • PHP Skript Memory Limit min. 32M (sonst gibt es bei Monats- oder Jahresüberblicken eine PHP Fehlermeldung)

Meine Wahl fiel auf Hosteurope, da ich da schon Webspace habe und nutze. Die folgenden Schritte beschreiben die Installation dort ist aber sicher auch für andere WebHoster gültig.

Vorbereitungen

Falls man nicht schon ein lauffähiges System am Start hat, sollte man z.B. über eine virtuelle Maschine den VZ gemäss der Anleitung installation aufsetzen. Schließlich haben wir auf dem Webhoster keinen root Zugang. Läuft alles wie erwarten kann der Umzug losgehen.

Umzug der Daten

Vorab: Sollte das System noch nicht laufen, kann man den Export mit Standardeinstellungen machen. Sollten aber schon Daten in die lokale DB geloggt werden empfiehlt sich folgendes:

Zunächst einmal legt man sich eine Datenbank über das Backend des Webhosters an, ggf. nutzt man die einzig vorhandene. Mit den zugehörigen Daten loggt man sich in das PHPMyAdmin des Hosters (oder das selbst auf dem Webspace installierte) ein, um die Schemata einzuspielen. Am einfachsten geht dies, indem man mit dem phpMyAdmim folgende Schritte durchführt:

  • Datenbank auswählen
  • Reiter „Exportieren“
  • Tabellen „aggregate“ und „data“ auswählen
  • Haken bei Struktur setzen (bzw. lassen)
  • Haken bei Daten wegnehmen (dazu gleich mehr)
  • Am besten eine Kompression auswählen
  • Und OK

Das ganze dann noch einmal für die restlichen Tabellen, hier allerdings den Haken bei „Daten“ setzen!

Im phpMyAdmin des Hosters werden diese beiden Dateien dann importiert.

Umzug der Skripte

Vorbedingung ist hier ein entsprechendes angelegtes Verzeichnis: /was/auch/immer/vz.domain.tld

und die darauf zeigende Subdomain http://vz.domain.tld/ → /was/auch/immer/vz.domain.tld

(Anmerkung: /was/auch/immer/ ist nicht notwendigerweise ein absoluter Pfad, sondern in der Regel relativ zum Root-Pfad des Webspace)

Hier machen wir es uns ganz einfach:

Variante eins: Wir kopieren per ftp-Befehl den gesamten Inhalt von /var/www/volkszaehler.org/ in ein Verzeichnis unserer Wahl beim Hoster (z.B. /was/auch/immer/vz.domain.tld/)

Variante zwei: Wir packen das Zeug per tar czf vz.tgz /var/www/volkszaehler.org/*, laden diese Datei hoch und basteln uns eine zweite (PHP-)Datei (uncompress.php), die per System Call das ganze wieder auspackt:

<?php
echo '<pre>';
system('tar xvzf vz.tgz', $retval);
echo '</pre>';
echo '<br/>';
echo '<br/>';
echo '<pre>';
echo 'Absoluter Pfad:';
echo '<br/>';
system('pwd', $retval);
echo '</pre>';
?>

Die können wir dann mit einem einfachen Browseraufruf http://vz.domain.tld/uncompress.php aufrufen.

Anpassungen

Nun ist ein bisschen Tipp-Arbeit an den Skripten erforderlich.

''/vz.domain.tld/etc/volkszaehler.conf.php''
...
// Benutzername (wird vom Webhoster vergeben)
$config['db']['user'] = 'webxxx';
...
// zugehöriges Password
$config['db']['password'] = 'password';
...
// Name der Datenbank (auch vom Webhoster beim Anlegen vergeben)
$config['db']['dbname'] = 'usr_webxxx_1'; 
...
// das gleiche noch mal für Admin
$config['db']['admin']['user'] = 'webxxx';
$config['db']['admin']['password'] = 'password';
...
''/vz.domain.tld/etc/volkszaehler.conf''

Hierfür muss man den absoluten Pfad kennen: Entweder aus oben genanntem Skript(aufruf), oder direkt vom Hoster beziehen (Bei Hosteurope im KIS unter „Allgemeines, Allgemeine Informationen, Pfad“)

// Old: Alias /volkszaehler.org /usr/share/volkszaehler.org/htdocs
Alias /volkszaehler.org /absoluter/pfad/nach/was/auch/immer/vz.domain.tld/

// Old: <Directory /usr/share/volkszaehler.org>
<Directory /absoluter/pfad/nach/was/auch/immer/vz.domain.tld/>
...

Ergebnis

Das Ergebnis ist dann über

http://vz.domain.tld/

erreichbar.

Nachwehen

Fertig sind wir aber natürlich noch nicht. Jetzt folgt die Anpassung (bzw. Erstellung) der 'vzlogger.conf' auf dem System, das die Daten senden soll.

Falls der vzlogger schon brav seinen Dienst verrichtet, braucht man lediglich in der Konfigdatei den Middlewarepfad auf http://vz.domain.tld/middleware.php anpassen, den Prozess stoppen und neu starten (Pros haben ja schon längst ein Skript in /etc/init.d dafür liegen…).

Ansonsten muss die ganz normale Einrichtung gemacht werden: Kanäle in der Middleware anlegen, UUIDs kopieren, in die Konfig eintragen, etc…

Was ist aber nun mit den alten Daten vom alten System? Nun: Hier bringt phpMyAdmin eine Nettigkeit mit: Klickt im phpMyAdmin auf den Home-Button, dann auf den Reiter Gleiche ab, wählt als Zieldatenbank Aktueller Server und gebt bei Quell-Datenbank die Daten der alten Datenbank an: Voraussetzung ist natürlich ein (temporäres) Port-Forwarding von Port 3306 auf den alten Server, sofern der im Heimnetz steht…

Viel Spaß!

howto/installation_auf_webhoster_2.1395393546.txt.gz · Zuletzt geändert: 2014/03/21 10:19 von comdoxx