ownCloud
ownCloud ermöglicht es dir über WebDAV sowie über ein Webinterface Dateien in deiner persönlichen Cloud zu speichern. Diese sind, wenn der Server von überall erreichbar ist, auch von überall zugänglich. Das Verzeichnis kann über WebDAV lokal eingebunden werden und somit zur Synchronisation von Dateien dienen. Außerdem verfügt ownCloud über die Möglichkeiten, Kalender und Adressbücher zu synchronisieren, sowie über einen Musikplayer, der ebenfalls lokal verwendet werden kann.
Softwarevoraussetzungen: Paketverwaltung | LAMP | phpMyAdmin (optional) | Apache Webserver (optional Informationen zum Verständnis) | siehe weiter unten
Schwierigkeitsgrad: Mittel
Ausgetestet mit folgenden Betriebssystemen: Ubuntu | Debian | teilweise auch andere Distributionen
Achtung! sudo:
In dieser Anleitung verdeutlicht der Befehl sudo, dass die folgende Codezeile mit Root-Rechten ausgeführt werden muss.
In normalen Ubuntu Installationen (Root-/VServer siehe Debian) kann dies durch den Befehl sudo erreicht werden.
Bei Debian wird bei der Installation ein Passwort für den Root-Benutzer festgelegt, so kann man sich entweder direkt als Root oder als „normaler“ Benutzer mit Eingabe von su als Root einloggen (Root-Passwort benötigt) → sudo bleibt dann überflüssig!
Diese Anleitung richtet sich immer nach der jeweils aktuellen Version von ownCloud (in diesem Fall 5.0.6). Wenn du eine Anleitung für die veraltete ownCloud Version 1.2 suchst, wirst du im Archiv dieser Anleitung fündig:
Voraussetzungen & Hinweise
- In meinem Test lies sich ownCloud nicht im PHP-Safemode mit aktivierter Sandbox installieren. In einer Standardinstallation dürften diese Einstellungen zum Glück nicht vorhanden sein. Falls du sie trotzdem aktiviert hast, deaktiviere sie für die Dauer der Installation und überprüfe danach, ob ownCloud auch mit diesen Einstellungen funktioniert.
- Eine extra HTTP-Authentifizierung durch Apache ist überflüssig. Wenn die Benutzername von ownCloud nicht mit denen der HTTP-Authentifizierung übereinstimmt, ist ein lokales Einbinden des WebDAVs nicht möglich!
Installation der benötigten Pakete
Laut der offiziellen Anleitung müssen folgende Abhängigkeiten erfüllt sein:
- php5 (>= 5.3)
- php5-gd
- php-xml-parser
- php5-intl
Da in dieser Anleitung ein LAMP bereits vorrausgesetzt wird, müssen nur noch die zusätzlichen PHP-Module installiert werden. Dies geschieht wie folgt:
user@server:~$ sudo apt-get install php5-gd php-xml-parser php5-intl
Hinweis: In älteren Versionen wurden noch weitere Module vorausgesetzt: php5-json php-pear php-xml-parser
Optionale Pakete
Für einige Apps werden die Pakete curl, libcurl3 und php5-curl benötigt (in älteren ownCloud-Versionen zusätzlich libcurl3-dev ):
user@server:~$ sudo apt-get install curl libcurl3 php5-curl
Sollen später SMB Netzwerkfreigeben eingebunden werden, wird das Paket smbclient benötigt:
user@server:~$ sudo apt-get install smbclient
In älteren ownCloud-Versionen musste man, um mehrere Dateien downloaden zu können (als Archiv) zusätzlich zip installieren:
user@server:~$ sudo apt-get install zip
Für ein besseres Scannen der Musikdateien (ebenfalls nur für ältere ownCloud-Versionen), kann das Paket mp3info installiert werden:
user@server:~$ sudo apt-get install mp3info
SQLite
Soll nachher statt MySQL oder PostgreSQL SQLite verwendet werden, müssen die Pakete sqlite und php5-sqlite installiert sein:
user@server:~$ sudo apt-get install sqlite php5-sqlite
Dies erspart später etwas Konfigurationsaufwand. Anschließend sollte Apache neu gestartet werden:
user@server:~$ sudo /etc/init.d/apache2 restart
Installation der Webanwendung
Auch hier gehe ich davon aus, dass du den Standard-V-Host von Apache verwendest. Demnach läge das Webroot direkt in /var/www. Sollte dies bei dir nicht der Fall sein, musst du in den folgenden Befehlen /var/www auf dein Webroot anpassen.
Download der Webanwendung
In diesem Schritt lädst du dir die aktuelle Version von ownCloud (im Moment: 5.0.6) herunter und verschiebst den Inhalt in das Webroot:
user@server:~$ cd /tmp user@server:/tmp$ wget http://owncloud.org/go/owncloud-download #Die aktuelle stable downloaden user@server:/tmp$ tar xf owncloud-download #Das Paket entpacken. Evtl muss noch "bzip2" installiert werden user@server:/tmp$ sudo mv owncloud /var/www #Das heruntergeladene Verzeichnis ins Webroot verschieben user@server:/tmp$ sudo chown -R www-data:www-data /var/www/owncloud #Anpassen der Rechte im Webroot
Sollte der obige Link nicht funktionieren, kannst du wie folgt Version 5.0.6 downloaden:
user@server:~$ cd /tmp user@server:/tmp$ wget http://download.owncloud.org/community/owncloud-5.0.6.tar.bz2 #Version 5.0.6 downloaden user@server:/tmp$ tar xf owncloud-5.0.6.tar.bz2 #Das Paket entpacken. Evtl muss noch "bzip2" installiert werden user@server:/tmp$ sudo mv owncloud /var/www #Das heruntergeladene Verzeichnis ins Webroot verschieben user@server:/tmp$ sudo chown -R www-data:www-data /var/www/owncloud #Anpassen der Rechte im Webroot
Falls du lieber Version 4.5.11 verwenden möchtest, kannst du jene wie folgt downloaden:
user@server:~$ cd /tmp user@server:/tmp$ wget http://download.owncloud.org/community/owncloud-4.5.11.tar.bz2 #Version 4.5.11 downloaden user@server:/tmp$ tar xf owncloud-4.5.11.tar.bz2 #Das Paket entpacken. Evtl muss noch "bzip2" installiert werden user@server:/tmp$ sudo mv owncloud /var/www #Das heruntergeladene Verzeichnis ins Webroot verschieben user@server:/tmp$ sudo chown -R www-data:www-data /var/www/owncloud #Anpassen der Rechte im Webroot
Wenn du stattdessen die Entwicklerversion von ownCloud (siehe auch: ownCloud Seite) verwenden willst, musst du wie folgt vorgehen:
user@server:~$ sudo apt-get install git-core #Installation von git user@server:~$ cd /var/www user@server:/var/www$ sudo git clone https://github.com/owncloud/core ./owncloud #Mittels git die neuste Version "besorgen" user@server:/var/www$ sudo git clone https://github.com/owncloud/apps user@server:/var/www$ sudo git clone https://github.com/owncloud/3rdparty user@server:/var/www$ sudo chown -R www-data:www-data owncloud apps 3rdparty #Anpassen der Rechte im Webroot
Konfiguration von Apache
Damit die .htaccess von ownCloud von Apache akzeptiert wird, muss die AllowOverride Direktive des jeweiligen V-Hosts (mehr zu V-Hosts) auf All gesetzt werden. Normalerweise ist dies schon der Fall. Hier ein Beispiel:
<Directory /var/www/> Options Indexes FollowSymLinks MultiViews AllowOverride All Order allow,deny allow from all </Directory>
Wenn du die Funktion „AllowOverride“ nur in einem Ordner erlauben willst dann lege ein „Alias“ in default an.
Alias /owncloud "/var/www/owncloud/" <Directory "/var/www/owncloud/"> Options Indexes FollowSymLinks MultiViews AllowOverride All Order allow,deny allow from all </Directory>
Dieses Code-Beispiel ist natürlich nicht bindend, es ist nur wichtig, dass folgende Einstellung für das verwendete Verzeichnis gilt:
AllowOverride All
Die Konfigurationsdatei für den default V-Host findet sich normalerweise in /etc/apache2/sites-available/default und kann folglich so bearbeitet werden:
user@server:~$ sudo nano /etc/apache2/sites-available/default
Falls Mod Rewrite noch nicht aktiviert ist, muss dies nun erledigt werden:
user@server:~$ sudo a2enmod rewrite #Mod Rewrite aktivieren user@server:~$ sudo /etc/init.d/apache2 restart #Apache neu starten
Ausführen des Assistenten
Besuchen des Webinterfaces
Hierzu besucht man die die Adresse des V-Hosts mit einem Webbrowser, an die man hinter einem / den Pfad owncloud anhängt:
http://Adresse_des_V-Hosts/owncloud #Syntax http://server.tld/owncloud #Beispiel https://server.tld/owncloud #Beispiel mit HTTPS http://192.168.5.10/owncloud #Beispiel mit IP
Sollte man statt dem Konfigurationsassistenten einen 500er („Internal Server Error“) bekommen, muss überprüft werden ob die AllowOverride Direktive des V-Hosts auf All gesetzt und Mod Rewrite wirklich aktiviert wurde.
Administrativer Benutzer
Im ersten Abschnitt Admin-Konto anlegen. der Konfiguration, werden die Zugangsdaten für den Admin Account festgelegt. Diese können beliebig gewählt werden.
Datenbankeinstellungen
Mit einem Klick auf Erweitert können u.a. Datenbankeinstellungen vorgenommen werden. Die einfachste Möglichkeit ist die Verwendung von SQLite. Alternativ kann auch MySQL oder PostgreSQL verwendet werden.
SQLite
Es muss sichergestellt werden, dass die Pakete sqlite und php5-sqlite installiert sind (siehe Installation der benötigten Pakete, SQLite. Sollte dies der Fall sein dürfte SQLite automatisch von ownCloud ausgewählt worden sein. Die Verwendung von SQLite ist wesentlich Aufwands ärmer als die von MySQL und sollte deshalb wenn möglich präferiert werden.
MySQL
Sollte aus irgendwelchen Gründen SQLite auf dem System nicht vorhanden sein oder soll aus anderen GründenMySQL bevorzugt werden, so kann selbstverständlich auch MySQL verwendet werden.
Anlegen der MySQL-Datenbank
Diese muss hier von Hand oder über phpMyAdmin angelegt werden. Hier eine Schritt-für-Schritt Anleitung mit installiertem phpMyAdmin:
- Aufrufen von phpMyAdmin im Webbrowser (siehe phpMyAdmin)
- Einloggen als root
- Oben in der Toolbar
Rechtewählen - Unten auf
Neuen Benutzer hinzufügenklicken - Das Formular wie folgt ausfüllen:
- Anmeldeinformationen
- Benutzername:
owncloud - Host: leer lassen (sollte der neu angelegten mySQL-User nachher nicht funktionieren, hier
localhosteintragen) - Passwort: bei
Passwort generieren:aufGenerierenklicken und generiertes Passwort notieren
- Datenbank für Benutzer
- Haken bei
Erstelle eine Datenbank mit gleichem Namen und gewähre alle Rechte
- Auf
OKklicken
Einstellungen für MySQL
Im ownCloud Installationsassistenten im Abschnitt Erweitert → Datenbank einrichten müssen nach einem Klick auf MySQL nun die Benutzerdaten für den vorher via phpMyAdmin angelegten Benutzer eingegeben werden:
- Datenbankbenutzer:
owncloud - Datenbankpasswort: in phpMyAdmin generiertes Passwort
- Datenbankname:
owncloud - Host:
localhost
Speichern & Erster Login
Mit einem Klick auf Installation abschließen werden die Datenbanken angelegt und die Konfiguration gesichert. Wurden alle oberen Einstellungen richtig vorgenommen, erscheint anschließend die Weboberfläche von ownCloud
Konfiguration
Die Grundeinstellungen sind nach dem Login im Webinterface durch einen Klick auf Einstellungen (Zahnrad unten links) möglich. Hier lohnt es sich die einzelnen Reiter nach interessanten Funktionen zu durchforsten.
Uploadgröße
In ownCloud ist die maximale Uploadgröße bei genutzter .htaccess bereits auf 512MB angehoben, wer diese - aus welchem Grund auch immer - anheben oder senken möchte, kann dies zum einen über das Webinterface erledigen oder diese Einstellung manuell vornehmen, indem die .htaccess bearbeitet wird und die Werte für php_value upload_max_filesize und php_value post_max_size verändert wrerden. Die .htaccess befindet sich im ownCloud Ordner im Webroot. Mit nano könnte man jene so öffnen:
user@server:~$ sudo nano /var/www/owncloud/.htaccess
Die von ownCloud generierte .htaccess sieht nun etwa so aus:
ErrorDocument 403 /core/templates/403.php ErrorDocument 404 /core/templates/404.php <IfModule mod_php5.c> php_value upload_max_filesize 513M php_value post_max_size 513M php_value memory_limit 512M <IfModule env_module> (...)
Wie in den Kommentaren erklärt müssen nun die Werte für php_value upload_max_filesize und php_value post_max_size verändert werden - hier ein Ausschnitt mit 700MB:
(...) php_value upload_max_filesize 700M #hier php_value post_max_size 700M #und hier wurden die Werte verändert (...)
ownCloud nutzen
ownCloud kann wie ein normales WebDAV-Verzeichnis eingebunden werden. Der Pfad hierzu lautet:
#Mit ownCloud im Webroot: webdav://server.tld/owncloud/files/webdav.php #ohne SSL (Vorgabe) webdavs://server.tld/owncloud/files/webdav.php #mit SSL
Nautilus (Gnome & Unity)
Über die Adressleiste
Um diese Freigabe in Nautilus einzubinden muss web weggelassen werden:
#Mit ownCloud im Webroot: dav://server.tld/owncloud/files/webdav.php #ohne SSL (Vorgabe) davs://server.tld/owncloud/files/webdav.php #mit SSL
Diese Adresse kann direkt in die Adressleiste von Nautilus, die über [STRG] + L erreichbar ist, eingegeben werden und muss nur noch mit der [Eingabetaste] bestätigt werden. Anschließend wird man nach einem Benutzernamen und dem dazugehörigen Passwort gefragt, dazu nimmt man die Logindaten für das ownCloud-Webinterface.
Über "Mit Server verbinden"
Den Assistenten für Serververbindungen findet man unter Datei → Mit Server verbinden. Der Inhalt der Maske muss wie folgt ausgefüllt werden:
- Dienste-Typ: ohne SSL (Vorgabe) →
WebDAV (HTTP); mit SSL →Sicheres WebDAV (HTTPS) - Port: kann leer gelassen werden
- Ordner: in unserem Beispiel →
/owncloud/files/webdav.php - Benutzername: der ownCloud Benutzer
- Lesezeichen: optional
Weitere Clients
Hierfür finden sich Anleitungen auf der offiziellen Seite von ownCloud:
Viele weiteren Betriebssysteme unterstützen WebDAV hierzu muss unter anderem die Dokumentation der jew. Distribution/ des jew. OSes herangezogen werden. Der Pfad zum WebDAV der ownCloud Installation kann wie bereits erwähnt dem Webinterface in der Fußzeile entnommen werden.
Kalender, Kontakte und Musik
Kalender via CalDAV (siehe auch in der offiziele Dokumentation):
#Mit ownCloud im Ordner owncloud im Webroot: http://server.tld/owncloud/remote.php/caldav #ohne SSL (Vorgabe) https://server.tld/owncloud/remote.php/caldav #mit SSL http://server.tld/owncloud/remote.php/caldav/principals/username/ #Spezialfall Apple iCal http://server.tld/owncloud/remote.php/caldav/calendars/USERNAME/CALENDARNAME #Spezialfall Mozilla Lightning
Adressbuch via CardDAV (siehe auch in der offiziele Dokumentation):
#Mit ownCloud im Ordner owncloud im Webroot: http://server.tld/owncloud/remote.php/carddav #ohne SSL (Vorgabe) https://server.tld/owncloud/remote.php/carddav #mit SSL
Musik via Ampache-URL (siehe auch in der offiziele Dokumentation:
#Mit ownCloud im Ordner owncloud im Webroot: http://server.tld/owncloud/apps/media/ #ohne SSL (Vorgabe) https://server.tld/owncloud/apps/media/ #mit SSL
Diese URLs kann man sich auch unter Einstellungen → Persönlich anzeigen lassen.
— chrisge 2013/03/14 22:12
Diskussion
[14.03.2013] Änderungen:
Super - ein grosses Danke für diese Anleitung!
Keine Ursache
Hallo chris, ich habe Owncloud 5.0 unter Gentoo in Virtualbox installiert und kann von meinem (ebenfalls) Gentoo-Host darauf zugreifen. Sieht alles sehr gut aus. Sync Adressen und Kalender über Akonadi mit KDE und auch mit Thunderbird. Bilder die ich hochgeladen habe werden mir wie erwarte auch unter Bilder angezeigt. Aber:Musik bekomme ich aber nur unter Dateien zu Gesicht?? apps/Music ist leer. Ich habe jeweils eine mp3, wav und ogg Datei hochgeladen. Irgendeine Idee?
Muß ich Ampache installiert haben damit ich die Songs in der Sammlung zu Gesicht bekomme?
Ampache musst du nicht installieren, ownCloud ist ja nur Ampache kompatibel. Hast du die Dateien mal durchsuchen lassen (unter Music → Rescan Collection)?
Ja, schon mehrmals
Mhh, das ist dann tatsächlich äußerst seltsam. Ist das Paket
mp3infoinstalliert (müsste es unter Gentoo auch geben)?Ansonsten habe ich leider keine Ahnung, woran das liegen könnte
mp3info war nicht installiert, habe ich gerade gemacht, hat aber nichts geändert, was mich aber auch nicht wundert, da auch flac, ogg und wav-Dateien nicht angezeigt werden. Du hast mich aber auf eine Idee gebracht: Ich hatte nur grob ein nicht-graphisches Grundsystem installiert - ohne Alsa und andere Soundkomponenten… Ich versuche es weiter und gebe dir Bescheid wenn ich es gelöst habe. Danke erstmals für deine Hilfe
Ich habe unter Ubuntu 12.04 (Server) ebenfalls in einer VM genau das gleiche Problem. Hast du mal das error.log des WebServers geprüft. Dort habe ich eben bei mir die Meldung
gefunden. Sagt das jemanden etwas?
Dazu existiert dann tatsächlich schon ein Bug Report. Dort wird unter anderem folgendes vorgeschlagen:
in
/3rdparty/getid3/getid3.php(Zeile 101)apps/media/lib/extractor.phpin Zeile 46:$data = @$this->getID3->analyze('oc://' . $file);oc://durch den Data Ordner (z.B./var/www/data/) ersetzen:$data = @$this->getID3->analyze('/var/www/data/' . $file);Außerdem kann es helfen den Browsercache zu leeren oder einen anderen Browser auszuprobieren.
Ich habe deine und Danilos Meldungen gerade gelesen und werde sie noch heute ausprobieren
Die Änderung in der getid3.php hat es gebracht. MP3s werden mir jetzt angezeigt
Danke und Tschüss
weis jemand welche Version mit
installiert wird? Ich habe den Eindruck das es noch eine „4er“-Version ist….
Danke
Auf der ownCloud Seite wird auf das Rep auf GitHub verwiesen. Hab das mal geändert, jetzt müsstest du per git die Entwicklerversion clonen können. Vielen Dank für den Hinweis!
Hallo,
erstmal vielen dank für das Tutorial, ich hab nur ein kleines Problem. Ich habe Owncloud am laufen und auch ampache installiert. In Owncloud unter dem Reiter Musik taucht aber NIE meine Msuik auf, damit ich sie abspielen kann, kann mir hier vielleicht emand weiterhelfen????
Danke
Ach ja, hab die ganzen änderungen wie oben beschrieben durchgeführt, hat leider keinen erfolg gebracht :/
ownCloud benötigt kein Ampache, ownCloud ist nur Ampache-kompatibel, d.h. du kannst dich mit einem Musikplayer, der zur Ampache-API kompatibel ist, zu ownCloud verbinden und die Musik, die dort liegt abspielen.
Damit deine Musik im Reiter
Musikauftaucht, musst du diese in ownCloud hochladen und dort die Musiksammlung durchsuchen lassen.genau das hab ich getan….funktioniert aber nicht :/
Das ist dann wirklich seltsam. Im Moment fällt mir da leider auch nicht mehr ein. Ich kann dir nur empfehlen diesen Bug Report (und die Kommentare, siehe auch hier und hier) durchzulesen und mal alles was dort erwähnt wird auszuprobieren.
Wow, OwnCloud ist echt abgefahren …
… simpel. Hab meine persoenlichen Sachen mal importiert, sind knappe 200 GB schaetze ich, mal sehen wie lange OwnCloud noch braucht um alle zu indexieren. :D
Beste Gruesse
Moin, vielen Dank für den Support hier! :) Frage: Läuft soweit alles, doch wenn ich bei MAC OS per http://youraddress.com/owncloud/files/webdav.php eine Verbindung über webDAV erstelle, ist das extrem langsam und bei Kopiervorgängen kommt es zu Fehlern. Über das Webinterface klappt alles. Hat jemand eine Idee?
Es kann durchaus sein, dass die lokale Einbindung via webDAV langsamer als das Webinterface ist. Evl. kann es helfen statt SQLite MySQL zu verwenden.
[14.05.2013] Änderungen: