Как установить Node.js и NGINX на Debian
Описание установки node.js и веб-сервера NGINX на виртуальный сервер с операционной системой Debian.
В Serverspace вы можете создать сервер с уже установленным приложением Nginx.
Что такое Node.js и NGINX?
Node.js — это платформа JavaScript, которая может обслуживать динамический и адаптивный контент. JavaScript обычно является встроенным языком браузера, таким как HTML или CSS. А Node.js является серверной платформой JavaScript, сравнимой с PHP. Node.js часто работает с другими популярными серверными приложениями, такими как NGINX или Apache. В этом руководстве будет рассмотрена настройка NGINX для обработки внешних запросов, а Node.js — для обработки внутренних запросов.
Первоначальные требования
Многие из команд в этом руководстве требуют привилегий суперпользователя. Если при использовании команды sudo появляется ошибка bash: sudo: command not found, вам необходимо активировать режим суперпользователя, установить команду sudo и добавить своего пользователя в группу sudo:
su -
apt-get install sudo -y
usermod -aG sudo yourusername
Обновите локальные репозитории и пакеты:
sudo apt-get update && sudo apt-get upgrade
Установка и настройка NGINX
Установите NGINX, а также модуль screen, который будет использоваться позже:
apt-get install nginx screen
Запустите NGINX:
service nginx start
С помощью команды cd перейдите в следующий каталог:
cd /etc/nginx/sites-available/
Создайте новый файл, заменив example.com вашим доменным именем или IP-адресом:
touch example.com
Вставьте следующие строки в созданный файл, заменив example.com вашим доменным именем или IP-адресом:
#Names a server and declares the listening port
server {
listen 80;
server_name example.com www.example.com;
#Configures the publicly served root directory
#Configures the index file to be served
root /var/www/example.com;
index index.html index.htm;
#These lines create a bypass for certain pathnames
#www.example.com/test.js is now routed to port 3000
#instead of port 80
location /test.js {
proxy_pass http://example.com:3000;
proxy_set_header Host $host;
}
}
Сохраните изменения и перейдите в каталог:
cd /etc/nginx/sites-enabled/
Создайте символьную ссылку на созданный файл:
ln -s /etc/nginx/sites-available/example.com
Удалите символьную ссылку по умолчанию:
rm default
Перезапустите NGINX, чтобы применить новую конфигурацию:
service nginx reload
Создание каталогов и HTML-файлов
Создайте следующую иерархию каталогов, заменив example.com:
mkdir -p /var/www/example.com
Перейдите в созданный каталог:
cd /var/www/example.com
Создайте индексный файл:
touch index.html
Вставьте следующие строки:
<!DOCTYPE html>
<html>
<body>
<br>
<br>
<center>
<p>
<b>
If you have not finished the guide, the button below will not work.
</b>
</p>
</center>
<center>
<p>
The button links to test.js. The test.js request is passed through NGINX and then handled by the Node.js server.
</p>
</center>
<center>
<a href="test.js">
<button type="button">Go to test.js</button>
</a>
</center>
</body>
</html>
Установка Node.js
На этом этапе NGINX прослушивает порт 80 и обслуживает контент. Он также настроен на передачу запросов приложения /test.js на порт 3000.
Установите Node Version Manager:
wget -qO- https://raw.githubusercontent.com/creationix/nvm/v0.33.11/install.sh | bash
Закройте и снова откройте свой терминал.
Установите Node.js с помощью следующей команды:
nvm install 0.10
Создайте следующий файл:
touch /var/www/example.com/server.js
Вставьте в него следующее содержимое:
//nodejs.org/api for API docs
//Node.js web server
var http = require("http"), //Import Node.js modules
url = require("url"),
path = require("path"),
fs = require("fs");
http.createServer(function(request, response) { //Create server
var name = url.parse(request.url).pathname; //Parse URL
var filename = path.join(process.cwd(), name); //Create filename
fs.readFile(filename, "binary", function(err, file) { //Read file
if(err) { //Tracking Errors
response.writeHead(500, {"Content-Type": "text/plain"});
response.write(err + "n");
response.end();
return;
}
response.writeHead(200); //Header request response
response.write(file, "binary"); //Sends body response
response.end(); //Signals to server that
}); //header and body sent
}).listen(3000); //Listening port
console.log("Server is listening on port 3000.") //Terminal output
Запустите новую сессию screen:
screen
Далее нажмите Enter и запустите сервер Node.js:
node server.js
Нажмите комбинацию клавиш Ctrl+A, затем D.
Создание тестового приложения
Создайте файл с тестовыми данными:
touch /var/www/example.com/test.js
И вставьте в него следующие данные:
<!DOCTYPE html>
<html>
<body>
<center>
<h2>
Your Node.JS server is working.
</h2>
</center>
<center>
<p>
The below button is technically dynamic. You are now using Javascript on both the client-side and the server-side.
</p>
</center>
<br>
<center>
<button type="button"
onclick="document.getElementById('sample').innerHTML = Date()">
Display the date and time.
</button>
<p id="sample"></p>
</center>
</body>
</html>
Откройте порт 80 для подключения по http:
iptables -A INPUT -p tcp --dport 80 -j ACCEPT
Перейдите в браузере по вашему домену или ip-адресу. Отобразится следующая страница. Нажмите кнопку Go to the test.js:
Если все настроено корректно, с помощью кнопки Display the date and time на новой странице можно вывести текущее время и дату:
Node.js и NGINX теперь работают в связке.