Приложения Node.js популярны благодаря своей способности масштабироваться. Запуск нескольких параллельных процессов на нескольких серверах снижает задержку и увеличивает время безотказной работы. При управлении несколькими серверами проще всего автоматически запускать приложения Node.js в случае сбоя. Из этого туториала вы узнаете, как быстро настроить постоянство приложений из пустого экземпляра Ubuntu 16.04.
Предпосылки
- Создайте экземпляр Vultr любого размера с Ubuntu 16.04 LTS x64.
- Если вы не являетесь пользователем root, запустите
sudo -s
и введите свой пароль. Корневой доступ необходим для изменения файла запуска, чтобы диспетчер процессов запускался при загрузке.
- Убедитесь, что Node.js установлен на экземпляре, и что версия Node.js - 8.9.3 LTS или новее, что требуется для бесперебойной работы диспетчера персистентности. Используйте
node -v
для проверки установленной версии. Если Node.js не в правильной версии, следующие команды установят его.
Установите Node.js.
$ sudo apt-get update
$ curl -sL https://deb.nodesource.com/setup_8.x | sudo -E bash -
$ sudo apt-get install -y nodejs
Создать раздел подкачки
Этот шаг не является обязательным, но рекомендуется для установки. Разделы подкачки - это части жесткого диска, которые предназначены для пополнения оперативной памяти. На экземплярах меньшего размера Vultr, таких как экземпляр ОЗУ объемом 512 МБ, создание раздела подкачки было бы полезно для производительности. Для автоматической версии учебника по подкачке используйте команды ниже.
$ git clone https://github.com/teamtofu/server-tools.git tools
$ bash ./tools/swap.sh
Вообще говоря, использование swap не будет необходимо для экземпляров с 4 ГБ ОЗУ или более при настройке постоянных приложений, хотя это может повысить производительность приложений. Оперативная память более отзывчива, чем подкачка, поэтому экземпляры с большим объемом оперативной памяти, как правило, дают лучшие результаты независимо от подкачки.
Установить пряжу
Yarn - это простой в использовании менеджер пакетов из Facebook для пакетов Node.js. Это быстрее, чем NPM, а также детерминированный, что особенно полезно при развертывании нескольких серверов.
$ curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | sudo apt-key add -
$ echo "deb https://dl.yarnpkg.com/debian/ stable main" | sudo tee /etc/apt/sources.list.d/yarn.list
$ sudo apt-get update && sudo apt-get install yarn
Однако вместо Yarn можно использовать NPM, и он имеет команды, сравнимые со всеми в этом руководстве.
Установите приложение Node.js
Если ваше приложение размещено в git-репозитории, клонируйте его и используйте yarn install
. Ваше приложение должно иметь файл входа на сервер, обычно server.js
или index.js
, который будет использоваться на следующих шагах.
Установите Process Manager 2
Process Manager 2 - это пакет, который автоматически перезапускает приложение. Process Manager 2 очень популярен, его используют Microsoft, PayPal и Intuit, поэтому он безопасен и надежен.
$ yarn global add pm2
Добавить заявку как процесс
Приложение будет демонизировано (запущено в фоновом режиме) и автоматически перезапущено с помощью команды запуска.
$ pm2 start [path to your entry.js] -i max
Если вы хотите запустить максимальное количество процессов автоматически, передайте -i max
аргумент. Если этот экземпляр Vultr используется исключительно для обслуживания приложения, то это рекомендуется. Для экземпляров Vultr с более чем одним процессором будет запущено несколько процессов, и Process Manager 2 будет выступать в качестве балансировщика нагрузки для всех этих отдельных процессов.
Автоматически запускать ваше приложение при загрузке
После запуска приложения сохраните конфигурацию приложения. Затем запустите команду запуска для автоматического запуска Process Manager 2 в фоновом режиме при загрузке Ubuntu. Для Ubuntu 16.04 Process Manager 2 будет привязан к systemd
.
$ pm2 save
$ pm2 startup
Теперь, если ваше приложение Node.js аварийно завершает работу из-за ошибки, оно будет перезапущено, и если по какой-либо причине произойдет сбой Ubuntu, процесс автоматически перезапустится с Ubuntu. Процессы могут быть перезапущены, pm2 gracefulReload all
а Process Manager 2 может быть перезапущен pm2 update
. Чтобы остановить запуск Process Manager 2 при загрузке, запустите pm2 unstartup
.
тестирование
Попробуйте набрать reboot
и проверить, обслуживается ли ваше приложение после загрузки Ubuntu. Если приложение предназначено для Интернета и обслуживается через порт 80
, то curl http://localhost/
отобразится HTML-код для начальной страницы. В случае, если это не работает, команда pm2 status
покажет запущенные процессы, и команда запуска может быть переиздана.
Развертывание новых версий приложения
Если приложение обновляется, например, путем извлечения git-репозитория, необходимо выполнить команду для обновления запущенных процессов приложения.
$ pm2 update
Пример использования
Parse Server , популярная платформа с открытым исходным кодом в качестве службы, служит бэкэндом для приложения. Серверная часть может завершиться сбоем из-за ошибок в коде или объеме запросов, но приложение не будет иметь времени простоя, потому что другие серверы (и / или процессы) продолжают работать, и процесс Parse Server быстро перезапускается.