NodeJS

Aus Hostsharing Wiki
Zur Navigation springen Zur Suche springen

Eigene NodeJS Installation

Die JavaScript-Umgebung NodeJS für das Ausführen von JavaScript auf dem Server unterliegt noch einer rasanten Entwicklung. Daher ist die Debian-Version, die bei Hostsharing vorinstalliert ist, oft zu alt für aktuelle Software.

Ein kurze Anleitung für die eigene NodeJS-Installation für einen User.

Installation von nvm

Heute ist die Version v0.35.0 aktuell, siehe auch https://github.com/creationix/nvm/releases

   $ touch ~/.profile
   $ chmod u+x ~/.profile
   $ cd /tmp
   $ wget https://raw.githubusercontent.com/creationix/nvm/v0.35.0/install.sh
   $ chmod u+x install.sh 
   $ ./install.sh 

An dieser Stelle ab- und wieder anmelden oder die Befehle ausführen:

   $ export NVM_DIR="/home/pacs/xyz00/users/example/.nvm"
   $ [ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh"

Bitte auf die bei der Installation ausgegebenen Zeilen am Ende achten, denn neuere nvm-Versionen benötigen ggf. etwas andere Schritte zur sofortigen Aktivierung.

Installation von NodeJS

Zunächst prüfen, ob ein 32bit oder 64bit Linux auf dem jeweiligen Hostsharing-Host installiert ist:

   dpkg --print-architecture

Binärinstallation

Diese Variante funktioniert bei Hostsharing nur auf amd64 Systemen (64bit Linux auf 64bit CPU).

   $ nvm install 4
   $ nvm alias default 4

installiert (zum Beispiel) sehr einfach NodeJS in der Version 4.8.6 (27.11.2017).

analog für die Version 6.x:

   $ nvm install 6
   $ nvm alias default 6

Hinweis: Auf i386 Systemen würde von nvn immer ein 64bit Node installiert werden, das führt dann zu der Fehlermeldung: "libstdc++.so.6: cannot open shared object file".

Soucecode-basierte Installation auf einem 32bit Linux

Diese Variante funktioniert sowohl auf amd64 als auch auf i386 Systemen (32bit Linux auf 64bit CPU).

   $ nvm install -s 8.9.1 --dest-cpu=ia32
   $ nvm alias default 8.9.1

Die Sourcecode-basierte Installation benötigt temporär sehr viel Speicherplatz und bis zu 1 Stunde für Downloads und Kompilation. Der Speicherplatz kann nach Fertigstellung wieder freigegeben werden, z.B.:

   $ rm -r ~/.node  ~/.nvm/.cache/src/node-v8.9.1

Überprüfung der Installation

Der Befehl

   $ node -v

gibt die Version des aktiven NodeJS aus.

NodeJS Web-Applikation

Zur Integration der eigenen NodeJS-Installation in den Apache erfolgt über das Apache-Modul "Passenger". Vor der Nutzung dieses Moduls bitte unbedingt die Hinweise zur Nutzung beachten.

Den Pfad zum node-Binärprogramm konfiguriert man in einer ".htaccess"-Datei im Verzeichnis der Domain "/home/pacs/xyz00/users/example/doms/example.com/.htaccess":

 PassengerNodejs /home/pacs/xyz00/users/example/.nvm/versions/node/v4.8.6/bin/node

bzw.

 PassengerNodejs /home/pacs/xyz00/users/example/.nvm/versions/node/v6.12.0/bin/node

Für's Debugging ist die zusätzlich Option

 PassengerFriendlyErrorPages On

hilfreich.

Zum Testen kann man eine "app.js" ins Verzeichnis "/home/pacs/xyz00/users/example/doms/example.com/app-ssl/" ablegen.

Eine minimale "app.js" zur Anzeige der NodeJS Version:

   var http = require("http");
   http.createServer(function (request, response) {
      response.writeHead(200, {'Content-Type': 'text/plain'});
      response.write('node version ' + process.version + '\n');
      response.end();
   }).listen(3000);

Um diese App zu deaktivieren, muss die Datei gelöscht werden. Es reicht nicht aus, eine etwaige Konfiguration aus der .htaccess zu entfernen.

Weitere Installationen

Mit dem "Node Package Manager" npm läßt sich weitere Software in die Node-Umgebung installieren:

   $ npm install -g gulp