]> git.mxchange.org Git - friendica.git/blob - doc/de/Install.md
c0101f2c20a960f40c95de3ff12f9992f5224564
[friendica.git] / doc / de / Install.md
1 Friendica Installation
2 ==========
3
4 * [Zur Startseite der Hilfe](help)
5
6 Wir haben hart daran gearbeitet, um Friendica auf vorgefertigten Hosting-Plattformen zum Laufen zu bringen - solche, auf denen auch Wordpress Blogs und Drupal-Installationen laufen.
7 Wir bieten eine manuelle und eine automatische Installation an.
8 Aber bedenke, dass Friendica mehr als eine einfache Webanwendung ist.
9 Es handelt sich um ein komplexes Kommunikationssystem, das eher an einen Email-Server erinnert als an einen Webserver.
10 Um die Verfügbarkeit und Performance zu gewährleisten, werden Nachrichten im Hintergrund verschickt und gespeichert, um sie später zu verschicken, wenn eine Webseite gerade nicht erreichbar ist.
11 Diese Funktionalität benötigt ein wenig mehr als die normalen Blogs.
12 Nicht jeder PHP/MySQL-Hosting-Anbieter kann Friendica unterstützen.
13 Viele hingegen können es. Aber **bitte** prüfe die Voraussetzungen deines Servers vor der Installation.
14
15 Wenn dir Fehler während der Installation auffallen, sag uns bitte über [Helper](http://forum.friendi.ca/profile/helpers) oder das [Entwickler Forum](https://forum.friendi.ca/profile/developers) Bescheid oder [erstelle ein Issue](https://github.com/friendica/friendica/issues).
16 Gib uns bitte so viele Infos zu deinem System, wie du kannst, und beschreibe den Fehler mit allen Details und Fehlermeldungen, so dass wir den Fehler zukünftig verhindern können.
17 Aufgrund der großen Anzahl an verschiedenen Betriebssystemen und PHP-Plattformen haben wir nur geringe Kapazitäten, um deine PHP-Installation zu debuggen oder fehlende Module zu ersetzen, aber wir tun unser Bestes, um allgemeine Code-Fehler zu beheben.
18
19 Bevor du anfängst: suche dir einen Domain- oder Subdomainnamen für deinen Server.
20 Dinge verändern sich und einige deiner Freunde haben möglicherweise Probleme, mit dir zu kommunizieren.
21 Wir planen, diese Einschränkung in einer zukünftigen Version zu beheben.
22
23
24 Requirements
25 ---
26
27 * Apache mit einer aktiverten mod-rewrite-Funktion und dem Eintrag "Options All", so dass du die lokale .htaccess-Datei nutzen kannst
28 * PHP  7.2+ (PHP 8 wird noch nicht komplett unterstützt)
29   * PHP *Kommandozeilen*-Zugang mit register_argc_argv auf "true" gesetzt in der php.ini-Datei
30   * Curl, GD, PDO, MySQLi, xml, zip und OpenSSL-Erweiterung
31   * Das POSIX Modul muss aktiviert sein ([CentOS, RHEL](http://www.bigsoft.co.uk/blog/index.php/2014/12/08/posix-php-commands-not-working-under-centos-7http://www.bigsoft.co.uk/blog/index.php/2014/12/08/posix-php-commands-not-working-under-centos-7) haben dies z.B. deaktiviert)
32   * etwas in der Art eines Email-Servers oder eines Gateways wie PHP mail()
33 * Mysql 5.6+ (oder eine äquivalente Alternative: MariaDB, Percona Server etc.)
34 * die Möglichkeit, wiederkehrende Aufgaben mit cron (Linux/Mac) oder "Scheduled Tasks" einzustellen (Windows) [Beachte: andere Optionen sind in Abschnitt 7 dieser Dokumentation zu finden]
35 * Installation in einer Top-Level-Domain oder Subdomain (ohne eine Verzeichnis/Pfad-Komponente in der URL) wird bevorzugt. Verzeichnispfade sind für diesen Zweck nicht so günstig und wurden auch nicht ausführlich getestet.
36
37 Installation
38 ---
39
40 ### Alternative Wege um Friendica zu Installieren
41
42 Diese Anleitung wird dir Schritt-für-Schritt zeigen wie du Friendica auf deinem Server installieren kannst.
43 Falls du an automatischen Möglichkeiten interesse hast, wirf doch einen Blick auf
44
45 * das [Docker image für Friendica](https://github.com/friendica/docker) oder
46 * die [Installation von Friendica auf YunoHost](https://github.com/YunoHost-Apps/friendica_ynh).
47
48 ### Friendica
49
50 Entpacke die Friendica-Daten in das Quellverzeichnis (root) des Dokumentenbereichs deines Webservers.
51 Wenn du die Möglichkeit hierzu hast, empfehlen wir dir "git" zu nutzen, um die Daten direkt von der Quelle zu klonen, statt die gepackte .tar- oder .zip-Datei zu nutzen.
52 Das macht die Aktualisierung wesentlich einfacher.
53 Der Linux-Code, mit dem man die Dateien direkt in ein Verzeichnis wie "meinewebseite" kopiert, ist
54
55     git clone https://github.com/friendica/friendica.git -b stable mywebsite
56     cd mywebsite
57     bin/composer.phar install
58
59 Stelle sicher, dass der Ordner *view/smarty3* existiert and von dem Webserver-Benutzer beschreibbar ist
60
61     mkdir view/smarty3
62     chmod 775 view/smarty3
63
64 Falls Addons installiert werden sollen: Gehe in den Friendica-Ordner
65
66     cd mywebsite
67
68 Und die Addon Repository klonst:
69
70     git clone https://github.com/friendica/friendica-addons.git -b stable addon
71
72 Um das Addon-Verzeichnis aktuell zu halten, solltest du in diesem Pfad ein "git pull"-Befehl eintragen
73
74     cd meinewebseite/addon
75     git pull
76
77 Wenn du den Verzeichnispfad auf deinen Webserver kopierst, dann stelle sicher, dass du auch die .htaccess kopierst, da "Punkt"-Dateien oft versteckt sind und normalerweise nicht direkt kopiert werden.
78
79 Wenn du die Entwickler Version von Friendica verwenden möchtest kannst du auf den develop Branch im git Repository wechseln.
80 Dies tust du mit den folgenden Befehlen
81
82     git checkout develop
83     bin/composer.phar install
84     cd addon
85     git checkout develop
86
87 Die Entwickler Version kann nach einem fehlerhaften Commit vorübergehend Probleme haben oder gar nicht mehr funktionieren.
88 Sollte dir so etwas passieren, lass es uns bitte wissen, damit der Fehler behoben werden kann.
89
90 ### Erstelle eine Datenbank
91
92 Erstelle eine leere Datenbank und notiere alle Zugangsdaten (Adresse der Datenbank, Nutzername, Passwort, Datenbankname).
93
94 Friendica benötigt die Berechtigungen um neue Felder in dieser Datenbank zu ertellen (create) und zu löschen (delete).
95
96 Mit neueren Versionen von MySQL (5.7.17+) musst du den `sql_mode` zu `''` (blank) setzen.
97 Benutze diese Einstellung, wenn der Installer nicht in der Lage ist, die Tabellen aufgrund eines Timestamp-Format Problems zu erstellen.
98 Falls dem so ist, finde den `[mysqld]` Bereich in deiner `my.conf` Datei und füge diese Zeile hinzu:
99
100     sql_mode = ''
101
102 Starte MySQL dann neu und es sollte klappen.
103
104 ### Option A: Der manuelle Installer
105
106 Besuche deine Webseite mit deinem Browser und befolge die Anleitung.
107 Bevor du dies tust, kopiere die Datei `.htaccess-dist` nach `.htaccess`, wenn du den Apache Webserver verwendest.
108 Bitte beachte jeden Fehler und korrigiere diese, bevor du fortfährst.
109
110 Falls du einen Port für die Datenbankverbindung angeben musst, kannst du diesen in der Host-Eingabe Zeile angeben.
111
112 *Wenn* die manuelle Installation aus irgendeinem Grund fehlschlägt, dann prüfe das Folgende:
113 * "config/local.config.php" existiert ... wenn nicht, bearbeite die „config/local-sample.config.php“ und ändere die Systemeinstellungen. Benenne sie um in „config/local.config.php".
114 * die Datenbank beinhaltet Daten. ... wenn nicht, importiere den Inhalt der Datei "database.sql" mit phpmyadmin oder per mysql-Kommandozeile.
115
116 Besuche deine Seite an diesem Punkt wieder und registriere deinen persönlichen Account.
117 Alle Registrierungsprobleme sollten automatisch behebbar sein.
118 Wenn du irgendwelche **kritischen** Fehler zu diesen Zeitpunkt erhalten solltest, deutet das darauf hin, dass die Datenbank nicht korrekt installiert wurde.
119 Du kannst bei Bedarf die Datei config/local.config.php verschieben/umbenennen und die Datenbank leeren (als „Dropping“ bezeichnet), so dass du mit einem sauberen System neu starten kannst.
120
121 ### Option B: Starte das automatische Installationsscript
122
123 Es existieren folgende Varianten zur automatischen Installation von Friendica:
124 -       Eine vorgefertigte Konfigurationsdatei erstellen (z.B. `prepared.config.php`)
125 -       Verwendung von Umgebungsvariablen (z.B. `MYSQL_HOST`)
126 -       Verwendung von Optionen (z.B. `--dbhost <host>`)
127
128 Umgebungsvariablen und Optionen können auch kombiniert werden.
129 Dabei ist jedoch darauf zu achten, dass etwaige Optionen immer die zugehörigen Umgebungsvariablen überschreiben.
130
131 Für mehr Informationen kannst du diese Option verwenden:
132
133     bin/console autoinstall -v
134
135 Falls du alle optionalen Checks ausfürehn lassen möchtest, benutze diese Option:
136
137     bin/console autoinstall -a
138
139 *Wenn* die automatisierte Installation aus irgendeinem Grund fehlschlägt, dann prüfe das Folgende:
140 *       Existiert die `config/local.config.php`? Falls ja, wird die automatisierte Installation nicht gestartet.
141 *       Sind Einstellungen in der `config/local.config.php` korrekt? Falls nicht, bitte bearbeite diese Datei erneut.
142 *       Ist die leere MySQL-Datenbank erstellt? Falls nicht, erstelle diese.
143
144 #### B.1: Konfigurationsdatei
145
146 Für diese Variante muss ein Konfigurationsdatei bereits vor der Installation fertig definiert sein (z.B. [local-sample.config.php](config/local-sample.config.php).
147
148 Gehe im Anschluss in den Friendica-Hauptordner und führe den Kommandozeilen Befehl aus:
149
150     bin/console autoinstall -f <prepared.config.php>
151
152 #### B.2: Umgebungsvariablen
153
154 Es existieren Zwei Arten von Umgebungsvariablen in Friendica:
155 -       Jene, die auch im normalen Betrieb verwendet werden können (derzeit ausschließlich **Datenbank Einstellungen**)
156 -       Jene, die nur während der Installation verwedent werden können (im normalen Betrieb werden sie ignoriert)
157
158 Umgebungsvariablen können auch durch adäquate Optionen (z.B. `--dbhost <hostname>`)übersteuert werden.
159
160 **Datenbank Einstellungen**
161
162 Nur wenn die Option `--savedb` gesetzt ist, werden diese Umgebungsvariablen auch in `config/local.config.php` gespeichert!
163
164 -       `MYSQL_HOST` Der Host der MySQL/MariaDB Datenbank
165 -       `MYSQL_PORT` Der Port der MySQL/MariaDB Datenbank
166 -       `MYSQL_USERNAME` Der Benutzername des MySQL Datenbanklogins (MySql - Variante)
167 -       `MYSQL_USER` Der Benutzername des MariaDB Datenbanklogins (MariaDB-Variante)
168 -       `MYSQL_PASSWORD` Das Passwort der MySQL/MariaDB Datenbanklogins
169 -       `MYSQL_DATABASE` Der Name der MySQL/MariaDB Datenbank
170
171 **Friendica Einstellungen**
172
173 Diese Umgebungsvariablen können nicht während des normalen Friendica Betriebs verwendet werden.
174 Sie werden stattdessen direkt in `config/local.config.php` gespeichert.
175
176 -       `FRIENDICA_PHP_PATH` Der Pfad zur PHP-Datei
177 -       `FRIENDICA_ADMIN_MAIL` Die Admin E-Mail Adresse dieses Friendica Knotens (wird auch für den Admin-Zugang benötigt)
178 -       `FRIENDICA_TZ` Die Zeitzone von Friendica
179 -       `FRIENDICA_LANG` Die Sprache von Friendica
180
181 Gehe im Anschluss in den Friendica-Hauptordner und führe den Kommandozeilen Befehl aus:
182
183     bin/console autoinstall [--savedb]
184     
185 #### B.3: Optionen
186
187 Alle Optionen werden in `config/local.config.php` gespeichert und überschreiben etwaige, zugehörige Umgebungsvariablen.
188
189 -       `-H|--dbhost <host>` Der Host der MySQL/MariaDB Datenbank (env `MYSQL_HOST`)
190 -       `-p|--dbport <port>` Der Port der MySQL/MariaDB Datenbank (env `MYSQL_PORT`)
191 -       `-U|--dbuser <username>` Der Benutzername des MySQL/MariaDB Datenbanklogins (env `MYSQL_USER` or `MYSQL_USERNAME`)
192 -       `-P|--dbpass <password>` Das Passwort der MySQL/MariaDB Datenbanklogins (env `MYSQL_PASSWORD`)
193 -       `-d|--dbdata <database>` Der Name der MySQL/MariaDB Datenbank (env `MYSQL_DATABASE`)
194 -       `-b|--phppath <path>` Der Pfad zur PHP-Datei (env `FRIENDICA_PHP_PATH`)
195 -       `-A|--admin <mail>` Die Admin E-Mail Adresse dieses Friendica Knotens (env `FRIENDICA_ADMIN_MAIL`)
196 -       `-T|--tz <timezone>` Die Zeitzone von Friendica (env `FRIENDICA_TZ`)
197 -       `-L|--lang <language>` Die Sprache von Friendica (env `FRIENDICA_LANG`)
198
199 Gehe in den Friendica-Hauptordner und führe den Kommandozeilen Befehl aus:
200
201     bin/console autoinstall [options]
202
203 ### Einen Worker einrichten
204
205 Erstelle einen Cron job oder einen regelmäßigen Task, um den Poller alle 5-10 Minuten im Hintergrund ablaufen zu lassen.
206 Beispiel:
207
208     cd /base/directory; /path/to/php bin/worker.php
209
210 Ändere "/base/directory" und "/path/to/php" auf deine Systemvorgaben.
211
212 Wenn du einen Linux-Server nutzt, benutze den Befehl "crontab -e" und ergänze eine Zeile wie die Folgende; angepasst an dein System
213
214 `*/10 * * * * cd /home/myname/mywebsite; /usr/bin/php bin/worker.php`
215
216 Du kannst den PHP-Pfad finden, indem du den Befehl „which php“ ausführst.
217 Wenn du Schwierigkeiten mit diesem Schritt hast, kannst du deinen Hosting-Anbieter kontaktieren.
218 Friendica wird nicht korrekt laufen, wenn dieser Schritt nicht erfolgreich abgeschlossen werden kann.
219
220 Falls das Einrichten des cron nicht möglich ist, kannst Du alternativ den "frontend worker" vom Administrationsinterface aus aktivieren.
221
222 ### Erstelle einen Backup Plan
223
224 Es werden schlimme Dinge geschehen.
225 Sei es nun ein Hardwareversagen oder eine kaputte Datenbank.
226 Deshalb solltest du dir, nachdem die Installation deines Friendica Knotens abgeschlossen ist, einen Backup Plan erstellen.
227
228 Die wichtigste Datei ist die `config/local.config.php` im Stammverzeichnis deiner Friendica Installation.
229 Und da alle Daten in der Datenbank gespeichert werden, solltest du einen nicht all zu alten Dump der Friendica Datenbank zur Hand haben, solltest du deinen Knoten wieder herstellen müssen.