Node.js: Różnice pomiędzy wersjami
Linia 20: | Linia 20: | ||
* v8.9.1 - binarki <code>node8</code> i <code>npm8</code> | * v8.9.1 - binarki <code>node8</code> i <code>npm8</code> | ||
* v9.2.0 - binarki <code>node9</code> i <code>npm9</code> | * v9.2.0 - binarki <code>node9</code> i <code>npm9</code> | ||
− | * v10.3.0 - binarki <code>node10</code> i <code> | + | * v10.3.0 - binarki <code>node10</code> i <code>npm10</code> |
Wersja z 17:57, 13 cze 2018
Node.js to otwarte, wieloplatformowe środowisko programistyczne.
Spis treści
Wstępna konfiguracja
Do uruchomienia aplikacji opartej Node.js należy najpierw zadbać o prawidłową konfigurację wstępną pod Node.js. Przed przystąpieniem do dalszych kroków należy upewnić się, że:
- Domena jest prawidłowo dodana i skonfigurowana w naszym systemie DNS.
- Została dodana strona WWW ze wskazaniem typu Node.js w wybranej przez siebie wersji.
- Zostały wykonane polecenia:
mkdir ~/.npm-global npm config set prefix '~/.npm-global' echo 'export PATH=~/.npm-global/bin:~/bin:$PATH ' >> $HOME/.bash_profile && source $HOME/.bash_profile
Wersje Node.js
Na serwerach MyDevil udostępniamy następujące wersje Node:
- v4.8.6 - binarki
node4
inpm4
- v6.12.0 (domyślna) - binarki
node
inpm
- v8.9.1 - binarki
node8
inpm8
- v9.2.0 - binarki
node9
inpm9
- v10.3.0 - binarki
node10
inpm10
Zmiana wersji Node.js pod poleceniami node, npm, w przykładzie została ustawiona wersja v8.9.1, aby wskazać inną należy odpowiednio zmienić cyfrę przy node oraz npm:
mkdir -p ~/bin && ln -fs /usr/local/bin/node8 ~/bin/node && ln -fs /usr/local/bin/npm8 ~/bin/npm && source $HOME/.bash_profile
Aby ponownie zmienić wersję Node.js wystarczy wykonać polecenie ze zmianą cyfr:
mkdir -p ~/bin && ln -fs /usr/local/bin/node4 ~/bin/node && ln -fs /usr/local/bin/npm4 ~/bin/npm && source $HOME/.bash_profile
Projekt Node.js
Głównym katalogiem projektu Node.js (tj. katalog, w którym znajduje się plik app.js
) musi być folder /usr/home/login/domains/domena/public_nodejs
. Należy również usunąć plik index.html poleceniem rm /usr/home/login/domains/domena/public_nodejs/public/index.html
Moduły Node.js
Aby zainstalować wybrany moduł Node.js należy skorzystać z polecenia npm install -g nazwa_modułu
. Moduły posiadające binarki zaleca się instalować w katalogu domowym. Aby móc z nich skorzystać należy koniecznie włączyć binexec i przelogować się.
Aby niektóre moduły npm skompilowały się poprawnie należy ustawić następujące zmienne:
export C=clang export CXX=clang++
a w przypadku błędu należy sprawdzić:
export CC=gcc48 export CXX=g++48
Przygotowanie aplikacji Node.js
Nowy projekt Node.js należy utworzyć w katalogu /usr/home/login/domains/domena/public_nodejs
- najprostszym sposobem utworzenia odpowiedniego projektu jest stworzenie pliku app.js:
var http = require('http'); var server = http.createServer(function(req, res) { res.writeHead(200, { 'Content-Type': 'text/plain' }); res.end("hello world!\n"); }); server.listen(3000);
Widoczny w ostatniej linii port 3000 nie otworzy socketu na porcie 3000. Phusion Passenger automatycznie wybiera losowy, wolny port, przez który komunikuje się z aplikacją. Rezerwacja portu nie jest potrzebna przy uruchamianiu aplikacji przez typ nodejs.
Istniejący projekt Node.js
Istniejący projekt Node.js należy umieścić jako katalog /usr/home/login/domains/domena/public_nodejs
. W przypadku gdy projekt nie nazywa się public_nodejs
należy zmienić jego nazwę. Należy również zmodyfikować plik app.js tak, aby wykonywał aplikację. Zwykle poza odpowiednim require i ustawieniem listen() plik app.js nie potrzebuje zawierać więcej elementów. Trzeba również zainstalować brakujące poleceniem npm install
.
Restart aplikacji
Restart aplikacji Node.js można wykonać za pomocą naszego panelu zarządzania usługą w zakładce WWW, lub przy użyciu polecenia systemu zarządzania kontem Devil: devil www restart domena
.
Pliki statyczne
Wszystkie pliki umieszczone w /usr/home/login/domains/domena/public_nodejs/public
są serwowane jak pliki statyczne. W tym katalogu najlepiej umieścić wszystkie obrazki, skrypty, style, itp. Żądania do plików znajdujących się w tym folderze nie będą przetwarzane przez Node.js i nie będą obciążać interpretatora. Na przykład plik /usr/home/login/domains/domena/public_nodejs/public/robots.txt
będzie dostępny pod adresem http://domena/robots.txt.
Zmienne
Ustawianie zmiennej z poziomu SSH z widocznością dla aplikacji uruchamianej przez Passengera:
- Dopisanie zmiennych do ~/.bash_profile (np. export TESTENV=1).
- Ważne: zmienne nie działają z ~/.bashrc i ~/.shrc
Logi
Istnieje możliwość logowania następujących zdarzeń:
- zapisy na stdout,
- zapisy na stderr,