Pull to refresh

Как запустить простой статический сайт за пять ≈пятиминутных шагов при помощи Node.js и Express

Website developmentJavaScriptNode.JS
Tutorial
В качестве отклика на инструкцию «Как сделать простой веб-сайт за один час» я решил опубликовать собственную, состоящую из пяти простых и обозримых ≈пятиминутных шагов.

Шаг 1. Установить движок Node.js в соответствии с инструкциями, имеющимися в вики для каждой из поддерживаемых операционных систем. (Для Windows достаточно скачать и запустить MSI-файл, для CentOS — воспользоваться системным менеджером пакетов, и так далее.)

Шаг 2. Создать пустой каталог и поместить в нём файл «site.js» следующего содержания:

site.js
// Перечисление зависимостей:
var path = require('path');
var express = require('express');

// Описание настроек:
var staticSiteOptions = {
   portnum: 80, // слушать порт 80
   maxAge: 1000 * 60 * 15 // хранить страницы в кэше пятнадцать минут
};

// Запуск сайта:
express().use(express.static(
   path.join(__dirname, 'static'),
   staticSiteOptions
)).listen(staticSiteOptions.portnum);

Настройки staticSiteOptions можно переменить по собственному вкусу.

Шаг 3. В том же каталоге подать команду «npm install express», которая автоматически создаст подкаталог «node_modules» и установит туда Express, скачав из Интернета.

Шаг 4. В том же каталоге создать подкаталог «static» и поместить в нём файлы статического сайта. Этот подкаталог станет корнем сайта. Файлы с именами «index.html» будут использоваться как файлы-индексы. Иными словами, при ответе сервера на запрос с адресом, содержащим только имя некоторого каталога (будь то корень сайта или один из его подкаталогов), будет показан файл с именем «index.html» из указанного каталога (если есть).

Шаг 5. В том же каталоге подать команду «node site», которая запустит сервер. Убедившись в её работоспособности, обеспечить автозапуск этой команды в этом каталоге после каждой перезагрузки операционной системы. (Например, на CentOS 6.2 можно использовать upstart для этой цели.)

Всё.

Под хабракатом уместно упомянуть (и упоминаю) о том, что просто запустить сервер на некотором компьютере может быть не достаточно: у этого компьютера также должно быть некоторое имя, известное читателям сайта, а до сервера должны доходить запросы, отправляемые на слушаемый им внешний порт.

Но задачу о том, как назначить имя тому компьютеру, на котором запущен сервер, я оставляю на усмотрение читателя, потому что у ней есть несколько общеизвестных решений.

(Можно купить VPS с фиксированным IP-адресом, запустить на нём веб-сервер, а затем купить домен, купить DNS-серверы или подобрать бесплатные по вкусу, сообщить их имена доменоторговцу, а затем связать IP-адрес с желаемым именем в панели управления первичным DNS-сервером. Можно запускать веб-сервер на домашнем компьютере, а фиксированный IP-адрес для него купить у поставщика Интернета. Можно использовать динамический DNS, обходиться без фиксированного IP-адреса. А может оказаться, что внешнего IP-адреса и вовсе не надо, если веб-сервер нужен для интранета.)

Да и задачу о том, как пробросить через файерволл тот порт, который слушает сервер, я также оставляю на усмотрение читателя. Её решение обыкновенно излагается в инструкции к файерволлу.
Tags:Node.jsNodeJSNodeExpressExpress.jsExpressJSстатический сайтсоздание сайтафайерволл
Hubs: Website development JavaScript Node.JS
Total votes 31: ↑11 and ↓20 -9
Views31K

Popular right now

Node.js Developer
from 140,000 to 220,000 ₽HolyWebRemote job
Node.js разработчик (удаленно/ офис)
from 2,000 $Steam Inventory HelperRemote job
Программист-разработчик Node.JS
from 100,000 to 200,000 ₽Mesh GroupRemote job
Fullstack JavaScript developer
from 5,500 to 6,500 $BrightdataRemote job
Senior Javascript/Node.JS Разработчик
from 3,000 to 4,000 $MakeomaticRemote job

Top of the last 24 hours