Drupal installieren: Unterschied zwischen den Versionen

Aus Hostsharing Wiki
Zur Navigation springen Zur Suche springen
K (Ansible Playbook Kategorie hinzugefügt)
 
(13 dazwischenliegende Versionen von 3 Benutzern werden nicht angezeigt)
Zeile 2: Zeile 2:
Überprüft auf Installation der V 8.6.7.
Überprüft auf Installation der V 8.6.7.


Aktualisiert auf Basis von drupal 10.3.1 (26.07.2024)
== Vorbereitungen ==
== Vorbereitungen ==


Zeile 8: Zeile 9:
''hsadmin''-Shell starten mit:
''hsadmin''-Shell starten mit:


  hsscript -u xyz00 -i
<syntaxhighlight lang="bash">
  Password: ********
hsscript -u xyz00 -i
Password: ********
</syntaxhighlight>


Dann nacheinander anlegen:
Dann nacheinander anlegen:
Zeile 18: Zeile 21:
* MySQL Datenbank
* MySQL Datenbank


  xyz00@hsadmin> user.add({set:{name:'xyz00-drupal',password:'geheim',shell:'/bin/bash',comment:'Drupal CMS'}})
<syntaxhighlight lang="bash">
  xyz00@hsadmin> domain.add({set:{name:'drupal.hs-example.de',user:'xyz00-drupal'}})
xyz00@hsadmin> user.add({set:{name:'xyz00-drupal',password:'geheim',shell:'/bin/bash',comment:'Drupal CMS'}})
  xyz00@hsadmin> mysqluser.add({set:{name:'xyz00_drupaluser',password:'geheim'}})
xyz00@hsadmin> domain.add({set:{name:'drupal.hs-example.de',user:'xyz00-drupal'}})
  xyz00@hsadmin> mysqldb.add({set:{name:'xyz00_drupaldb',owner:'xyz00_drupaluser'}})
xyz00@hsadmin> mysqluser.add({set:{name:'xyz00_drupaluser',password:'geheim'}})
xyz00@hsadmin> mysqldb.add({set:{name:'xyz00_drupaldb',owner:'xyz00_drupaluser'}})
</syntaxhighlight>
 
drupal 10 braucht mindestens php 8.1
Stand Juli 2024 ist die Version auf den Hives php 8.2.21
das kann überprüft werden mit
<syntaxhighlight lang="bash">
$ php -v
</syntaxhighlight>
Falls das nicht aktuell ist bitte die Seite besuchen:
[[PHP|Aktuelle PHP Version nutzen]]


== Drupal installieren ==
== Drupal installieren ==
Zeile 27: Zeile 41:
Anmelden als Linux-User ''xyz00-drupal'':
Anmelden als Linux-User ''xyz00-drupal'':


  ssh -l xyz00-drupal xyz00.hostsharing.net
<syntaxhighlight lang="bash">
ssh -l xyz00-drupal xyz00.hostsharing.net
</syntaxhighlight>


Und dann Drupal herunterladen und in den Webspace entpacken:
=== Mit Composer ===
 
Stand Juli 2024 ist die Composer Version auf den Hives perfekt für drupal, das kann geprüft werden mit:
  cd doms/drupal.hs-example.de/htdocs
<syntaxhighlight lang="bash">
  wget -O - http://ftp.drupal.org/files/projects/drupal-8.6.7.tar.gz |tar -xz --strip 1
$ composer --version
oder kurz
$ composer -V
</syntaxhighlight>


=== Mit Composer ===
Die auf den Hives vorhandene Version von Composer kann veraltet sein, daher ist es sinnvoll eine eigene Version zu installieren von: https://getcomposer.org/download/  
Drupal mit Composer ist deutlich größer in der Installation durch Composer (148Mb vs 83Mb als Download von [https://www.drupal.org/download-latest/tar.gz] in version 8.7.5)
Siehe auch https://www.drupal.org/docs/develop/using-composer und insbesondere https://www.drupal.org/docs/develop/using-composer/using-composer-to-install-drupal-and-manage-dependencies
(ggf mit aktuellem lokalen Composer, siehe https://getcomposer.org/download/ )
siehe auch https://www.drupal.org/docs/develop/using-composer und insbesondere https://www.drupal.org/docs/develop/using-composer/using-composer-to-install-drupal-and-manage-dependencies
  cd doms/drupal.hs-example.de
  composer create-project drupal-composer/drupal-project:8.x-dev var/drupal-8-composer-installationsverzeichnis --no-interaction
alternativ geht auch mit einer lokalen (und aktuellen Version von Composer)
../lokales-Composer-Verzeichnis/composer.phar  create-project drupal-composer/drupal-project:8.x-dev var/drupal-8-composer-installationsverzeichnis --no-interaction


Nun entsteht in dem Ordner var/drupal-8-composer-installationsverzeichnis/web die neue Drupal Site, die dann noch in das entsprechende Verzeichnis (ich nutze nur noch htdocs-ssl) verlinken:
<syntaxhighlight lang="bash">
rmdir htdocs-ssl
cd doms/drupal.hs-example.de/var/
ln -s var/drupal-8-composer-installationsverzeichnis/web htdocs-ssl
composer create-projekt drupal/recommended-project drupal10
</syntaxhighlight>


Nun geht es genau wie mit der manuellen Installation weiter.
Nun entsteht in dem Ordner var/drupal10/web die neue Drupal Site.
Diese dann noch in das entsprechende Verzeichnis (z.B.: subs-ssl/www) verlinken:
<syntaxhighlight lang="bash">
rmdir subs-ssl/www
ln -s var/drupal-installationsverzeichnis/web subs-ssl/www
</syntaxhighlight>


== Drupal für HS anpassen ==
== Drupal für HS anpassen ==


doms/drupal.hs-example.de/htdocs
cd doms/drupal.hs-example.de/subs-ssl/www
 
<syntaxhighlight lang="apache">
  vi .htaccess
# vi .htaccess
 
# If your site is running in a VirtualDocumentRoot at http://example.com/,
  # If your site is running in a VirtualDocumentRoot at http://example.com/,
# uncomment the following line:
  # uncomment the following line:
# RewriteBase /
  # RewriteBase /
</syntaxhighlight>


wird zu
wird zu
 
<syntaxhighlight lang="apache">
  # If your site is running in a VirtualDocumentRoot at http://example.com/,
# If your site is running in a VirtualDocumentRoot at http://example.com/,
  # uncomment the following line:
# uncomment the following line:
  RewriteBase /
RewriteBase /
</syntaxhighlight>


== Drupal konfigurieren ==
== Drupal konfigurieren ==
Zeile 86: Zeile 106:
== Drupal template default für HS konfigurieren ==
== Drupal template default für HS konfigurieren ==


  cd sites/default/files/php/twig
<syntaxhighlight lang="bash">
  chmod 644 .htaccess
cd sites/default/files/php/twig
  edit .htaccess
chmod 644 .htaccess
edit .htaccess
</syntaxhighlight>


In der Zeile 11 den Eintrag "-ExecCGI" und  "-Includes" löschen, mit diesem Ergebnis:
In der Zeile 11 den Eintrag "-ExecCGI" und  "-Includes" löschen, mit diesem Ergebnis:


  Options -Indexes -MultiViews
<syntaxhighlight lang="apache">
Options -Indexes -MultiViews
</syntaxhighlight>


und dann noch eine .htaccess  
und dann noch eine .htaccess  


  cd ../..
<syntaxhighlight lang="bash">
cd ../..


  chmod 644 .htaccess
chmod 644 .htaccess
  edit .htaccess
edit .htaccess
</syntaxhighlight>


In der Zeile 2 den Eintrag "-ExecCGI" und  "-Includes" löschen, mit diesem Ergebnis:
In der Zeile 2 den Eintrag "-ExecCGI" und  "-Includes" löschen, mit diesem Ergebnis:


  Options -Indexes -MultiViews
<syntaxhighlight lang="apache">
 
Options -Indexes -MultiViews
</syntaxhighlight>


Danach die Seite im Browser neu laden.
Danach die Seite im Browser neu laden.
Zeile 114: Zeile 141:
Es gibt ein Ansible Skript, das die Installationsschritte für Drupal automatisiert durchführt.
Es gibt ein Ansible Skript, das die Installationsschritte für Drupal automatisiert durchführt.


Die Quellen für das Ansible Skript können hier eingesehen werden: https://github.com/tpokorra/Hostsharing-Ansible-Drupal/
Die Quellen für das Ansible Skript können hier eingesehen werden: https://codeberg.org/tpokorra/hs.ansible/src/branch/main/playbooks/drupal


Es wird die aktuelle Version 9 von Drupal installiert.
Es wird die aktuelle Version 10 von Drupal installiert.


Es wird die Installationsvariante mit Composer gewählt, weil sich damit Updates am leichtesten durchführen lassen.
Es wird die Installationsvariante mit Composer gewählt, weil sich damit Updates am leichtesten durchführen lassen.


== Installation ==
== Installation ==
Folgende Schritte sind im Benutzer xyz00 auszuführen:
$ touch .hsadmin.properties
$ chmod 600 .hsadmin.properties
$ vi .hsadmin.properties
Es muss in diese Datei das Passwort des Paketadministrators, also von xyz00, eingetragen werden. Das ist das gleiche Passwort, das auf https://admin.hostsharing.net funktioniert.
xyz00.passWord=insertpkgadminpasswordhere


Folgende Schritte sind auf dem lokalen Rechner auszuführen, um Drupal mit Hilfe des Ansible Skripts in den eigenen Hostsharing Benutzer zu installieren:
Folgende Schritte sind auf dem lokalen Rechner auszuführen, um Drupal mit Hilfe des Ansible Skripts in den eigenen Hostsharing Benutzer zu installieren:
Zeile 136: Zeile 153:
Klonen des Repositories:
Klonen des Repositories:


  $ git clone https://github.com/tpokorra/Hostsharing-Ansible-Drupal.git
  $ git clone https://codeberg.org/tpokorra/hs.ansible.git


Dann muss die Datei inventory kopiert werden, und entsprechend angepasst werden:
Dann muss die Datei inventory-sample.yml kopiert werden, und entsprechend angepasst werden:


$ cd Hostsharing-Ansible-Drupal
<syntaxhighlight lang="bash">
$ cp inventory my.inventory
cd hs.ansible
$ vi my.inventory
cp playbooks/drupal/inventory-sample.yml inventories/my.drupal.yml
vi inventories/my.drupal.yml
</syntaxhighlight>


In der my.inventory müssen die entsprechenden Werte eingerichtet werden.
In der my.drupal.yml müssen die entsprechenden Werte eingerichtet werden.


Eine Fehlerquelle sind zu lange Namen für user, denn dann kommt die Datenbankverwaltung von hsadmin aus dem Tritt. Bei einem Namen mit 13 Zeichen treten zumindest Fehler auf...
Eine Fehlerquelle sind zu lange Namen für user, denn dann kommt die Datenbankverwaltung von hsadmin aus dem Tritt. Bei einem Namen mit 13 Zeichen treten zumindest Fehler auf...
Zeile 152: Zeile 171:
Dann kann die Installation vom lokalen Rechner aus gestartet werden:
Dann kann die Installation vom lokalen Rechner aus gestartet werden:


$ ansible-playbook -i my.inventory playbook-drupal.yml -k -K
<syntaxhighlight lang="bash">
 
ansible-playbook -i inventories/my.drupal.yml init.yml
Es kann auch die Option -k weggelassen werden, wenn man sich über einen SSH Key mit xyz00@xyz00.hostsharing.net verbindet.
ansible-playbook -i inventories/my.drupal.yml playbooks/drupal/install.yml
</syntaxhighlight>


== Einrichtung ==
== Einrichtung ==
Zeile 162: Zeile 182:
Bitte mit dem Benutzer und dem Passwort anmelden, die in der Datei my.inventory angegeben wurden.
Bitte mit dem Benutzer und dem Passwort anmelden, die in der Datei my.inventory angegeben wurden.


== Links ==
* [https://www.drupal.org/ Englische Webseite vom Drupal Projekt]
* [https://www.drupal.de/ Deutsche Webseite, bereitgestellt vom Drupal e.V.]
* [https://codeberg.org/tpokorra/hs.ansible/src/branch/main/playbooks/drupal Ansible Playbook für Hostsharing]


----
----

Aktuelle Version vom 26. Juli 2024, 18:39 Uhr

Drupal bei HS

Überprüft auf Installation der V 8.6.7.

Aktualisiert auf Basis von drupal 10.3.1 (26.07.2024)

Vorbereitungen

In hsadmin, zum Beispiel mit hsscript:

hsadmin-Shell starten mit:

hsscript -u xyz00 -i
Password: ********

Dann nacheinander anlegen:

  • Linux User als Domain-Administrator
  • Subdomain drupal.hs-example.de
  • MySQL-User
  • MySQL Datenbank
xyz00@hsadmin> user.add({set:{name:'xyz00-drupal',password:'geheim',shell:'/bin/bash',comment:'Drupal CMS'}})
xyz00@hsadmin> domain.add({set:{name:'drupal.hs-example.de',user:'xyz00-drupal'}})
xyz00@hsadmin> mysqluser.add({set:{name:'xyz00_drupaluser',password:'geheim'}})
xyz00@hsadmin> mysqldb.add({set:{name:'xyz00_drupaldb',owner:'xyz00_drupaluser'}})

drupal 10 braucht mindestens php 8.1 Stand Juli 2024 ist die Version auf den Hives php 8.2.21 das kann überprüft werden mit

$ php -v

Falls das nicht aktuell ist bitte die Seite besuchen:

Aktuelle PHP Version nutzen

Drupal installieren

Anmelden als Linux-User xyz00-drupal:

ssh -l xyz00-drupal xyz00.hostsharing.net

Mit Composer

Stand Juli 2024 ist die Composer Version auf den Hives perfekt für drupal, das kann geprüft werden mit:

$ composer --version
oder kurz 
$ composer -V

Die auf den Hives vorhandene Version von Composer kann veraltet sein, daher ist es sinnvoll eine eigene Version zu installieren von: https://getcomposer.org/download/ Siehe auch https://www.drupal.org/docs/develop/using-composer und insbesondere https://www.drupal.org/docs/develop/using-composer/using-composer-to-install-drupal-and-manage-dependencies

cd doms/drupal.hs-example.de/var/
composer create-projekt drupal/recommended-project drupal10

Nun entsteht in dem Ordner var/drupal10/web die neue Drupal Site. Diese dann noch in das entsprechende Verzeichnis (z.B.: subs-ssl/www) verlinken:

rmdir subs-ssl/www
ln -s var/drupal-installationsverzeichnis/web subs-ssl/www

Drupal für HS anpassen

cd doms/drupal.hs-example.de/subs-ssl/www

# vi .htaccess
# If your site is running in a VirtualDocumentRoot at http://example.com/,
# uncomment the following line:
# RewriteBase /

wird zu

# If your site is running in a VirtualDocumentRoot at http://example.com/,
# uncomment the following line:
RewriteBase /

Drupal konfigurieren

Im Browser auf die Seite http://drupal.hs-example.de gehen und den Anweisungen folgen.

Drupal1.jpg

Drupal2.jpg

Drupal3.jpg

Drupal4.jpg

Drupal5.jpg

Drupal6.jpg

Drupal7.jpg

Drupal template default für HS konfigurieren

cd sites/default/files/php/twig
chmod 644 .htaccess
edit .htaccess

In der Zeile 11 den Eintrag "-ExecCGI" und "-Includes" löschen, mit diesem Ergebnis:

Options -Indexes -MultiViews

und dann noch eine .htaccess

cd ../..

chmod 644 .htaccess
edit .htaccess

In der Zeile 2 den Eintrag "-ExecCGI" und "-Includes" löschen, mit diesem Ergebnis:

Options -Indexes -MultiViews

Danach die Seite im Browser neu laden.

Mit Ansible bei HS installieren

Technische Details

Es gibt ein Ansible Skript, das die Installationsschritte für Drupal automatisiert durchführt.

Die Quellen für das Ansible Skript können hier eingesehen werden: https://codeberg.org/tpokorra/hs.ansible/src/branch/main/playbooks/drupal

Es wird die aktuelle Version 10 von Drupal installiert.

Es wird die Installationsvariante mit Composer gewählt, weil sich damit Updates am leichtesten durchführen lassen.

Installation

Folgende Schritte sind auf dem lokalen Rechner auszuführen, um Drupal mit Hilfe des Ansible Skripts in den eigenen Hostsharing Benutzer zu installieren:

Klonen des Repositories:

$ git clone https://codeberg.org/tpokorra/hs.ansible.git

Dann muss die Datei inventory-sample.yml kopiert werden, und entsprechend angepasst werden:

cd hs.ansible
cp playbooks/drupal/inventory-sample.yml inventories/my.drupal.yml
vi inventories/my.drupal.yml

In der my.drupal.yml müssen die entsprechenden Werte eingerichtet werden.

Eine Fehlerquelle sind zu lange Namen für user, denn dann kommt die Datenbankverwaltung von hsadmin aus dem Tritt. Bei einem Namen mit 13 Zeichen treten zumindest Fehler auf...

Es wird vorausgesetzt, dass auf dem lokalen Rechner Ansible installiert ist.

Dann kann die Installation vom lokalen Rechner aus gestartet werden:

ansible-playbook -i inventories/my.drupal.yml init.yml
ansible-playbook -i inventories/my.drupal.yml playbooks/drupal/install.yml

Einrichtung

Nach der Installation kann die Seite hier erreicht werden: https://drupal.example.org

Bitte mit dem Benutzer und dem Passwort anmelden, die in der Datei my.inventory angegeben wurden.

Links