如何在Ubuntu上使用pm2和Nginx部署Node.js应用

简介:

如何在Ubuntu上使用pm2和Nginx部署Node.js应用

pm2 是一个 Node.js 应用的进程管理器,它可以让你的应用程序保持运行,还有一个内建的负载均衡器。它非常简单而且强大,你可以零间断重启或重新加载你的 node 应用,它也允许你为你的 node 应用创建集群。

在这篇博文中,我会向你展示如何安装和配置 pm2 用于这个简单的 'Express' 应用,然后配置 Nginx 作为运行在 pm2 下的 node 应用的反向代理。

前提:

  • Ubuntu 16.04 - 64bit
  • Root 权限

第一步 - 安装 Node.js LTS

在这篇指南中,我们会从零开始我们的实验。首先,我们需要在服务器上安装 Node.js。我会使用 Nodejs LTS 6.x 版本,它能从 nodesource 仓库中安装。

从 Ubuntu 仓库安装 python-software-properties 软件包并添加 “nodesource” Nodejs 仓库。

 
 
  1. sudo apt-get install -y python-software-properties  
  2. curl -sL https://deb.nodesource.com/setup_6.x | sudo -E bash - 

安装最新版本的 Nodejs LTS:

 
 
  1. sudo apt-get install -y nodejs 

安装完成后,查看 node 和 npm 版本。

 
 
  1. node -v 
  2. npm -v 

检查 node.js 版本

检查 node.js 版本

第二步 - 生成 Express 示例 App

我会使用 express-generator 软件包生成的简单 web 应用框架进行示例安装。express-generator 可以使用 npm 命令安装。

用 npm安装 express-generator:

 
 
  1. npm install express-generator -g 

-g : 在系统内部安装软件包。

我会以普通用户运行应用程序,而不是 root 或者超级用户。我们首先需要创建一个新的用户。

创建一个名为 yume 的用户:

 
 
  1. useradd -m -s /bin/bash yume 
  2. passwd yume 

使用 su 命令登录到新用户:

 
 
  1. su - yume 

下一步,用 express 命令生成一个新的简单 web 应用程序:

 
 
  1. express hakase-app 

命令会创建新项目目录 hakase-app。

用 express-generator 生成应用框架

用 express-generator 生成应用框架

进入到项目目录并安装应用需要的所有依赖。

 
 
  1. cd hakase-app 
  2. npm install 

然后用下面的命令测试并启动一个新的简单应用程序:

 
 
  1. DEBUG=myapp:* npm start 

默认情况下,我们的 express 应用会运行在 3000 端口。现在访问服务器的 IP 地址:192.168.33.10:3000 :

express nodejs 运行在 3000 端口

express nodejs 运行在 3000 端口

这个简单 web 应用框架现在以 'yume' 用户运行在 3000 端口。

第三步 - 安装 pm2

pm2 是一个 node 软件包,可以使用 npm 命令安装。(用 root 权限,如果你仍然以 yume 用户登录,那么运行命令 exit 再次成为 root 用户):

 
 
  1. npm install pm2 -g 

现在我们可以为我们的 web 应用使用 pm2 了。

进入应用目录 hakase-app:

 
 
  1. su - yume 
  2. cd ~/hakase-app/ 

这里你可以看到一个名为 package.json 的文件,用 cat 命令显示它的内容。

 
 
  1. cat package.json 

配置 express nodejs 服务

配置 express nodejs 服务

你可以看到 start 行有一个 nodejs 用于启动 express 应用的命令。我们会和 pm2 进程管理器一起使用这个命令。

像下面这样使用 pm2 命令运行 express 应用:

 
 
  1. pm2 start ./bin/www 

现在你可以看到像下面这样的结果:

使用 pm2 运行 nodejs app

使用 pm2 运行 nodejs app

我们的 express 应用正在 pm2 中运行,名称为 www,id 为 0。你可以用 show 选项 show nodeid|name 获取更多 pm2 下运行的应用的信息。

 
 
  1. pm2 show www 

pm2 服务状态 

pm2 服务状态

如果你想看我们应用的日志,你可以使用 logs 选项。它包括访问和错误日志,你还可以看到应用程序的 HTTP 状态。

 
 
  1. pm2 logs www 

pm2 服务日志

pm2 服务日志

你可以看到我们的程序正在运行。现在,让我们来让它开机自启动。

 
 
  1. pm2 startup systemd 
  • systemd: Ubuntu 16 使用的是 systemd。

你会看到要用 root 用户运行命令的信息。使用 exit 命令回到 root 用户然后运行命令。

 
 
  1. sudo env PATH=$PATH:/usr/bin /usr/lib/node_modules/pm2/bin/pm2 startup systemd -u yume --hp /home/yume 

它会为启动应用程序生成 systemd 配置文件。当你重启服务器的时候,应用程序就会自动运行。

pm2 添加服务到开机自启动

pm2 添加服务到开机自启动

第四步 - 安装和配置 Nginx 作为反向代理

在这篇指南中,我们会使用 Nginx 作为 node 应用的反向代理。Ubuntu 仓库中有 Nginx,用 apt 命令安装它:

 
 
  1. sudo apt-get install -y nginx 

下一步,进入到 sites-available 目录并创建新的虚拟主机配置文件。

 
 
  1. cd /etc/nginx/sites-available/ 
  2. vim hakase-app 

粘贴下面的配置:

 
 
  1. upstream hakase-app { 
  2.     # Nodejs app upstream 
  3.     server 127.0.0.1:3000; 
  4.     keepalive 64; 
  5. # Server on port 80 
  6. server { 
  7.     listen 80; 
  8.     server_name hakase-node.co; 
  9.     root /home/yume/hakase-app; 
  10.     location / { 
  11.         # Proxy_pass configuration 
  12.         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
  13.         proxy_set_header Host $http_host; 
  14.         proxy_set_header X-NginX-Proxy true
  15.         proxy_http_version 1.1; 
  16.         proxy_set_header Upgrade $http_upgrade; 
  17.         proxy_set_header Connection "upgrade"
  18.         proxy_max_temp_file_size 0; 
  19.         proxy_pass http://hakase-app/; 
  20.         proxy_redirect off
  21.         proxy_read_timeout 240s; 
  22.     } 

保存文件并退出 vim。

在配置中:

  • node 应用使用域名 hakase-node.co 运行。
  • 所有来自 nginx 的流量都会被转发到运行在 3000 端口的 node app。

测试 Nginx 配置确保没有错误。

 
 
  1. nginx -t 

启用 Nginx 并使其开机自启动。

 
 
  1. systemctl start nginx 
  2. systemctl enable nginx 

第五步 - 测试

打开你的 web 浏览器并访问域名(我的是):http://hakase-app.co 

你可以看到 express 应用正在 Nginx web 服务器中运行。

Nodejs app 在 pm2 和 Nginx 中运行

Nodejs app 在 pm2 和 Nginx 中运行

下一步,重启你的服务器,确保你的 node app 能开机自启动:

 
 
  1. pm2 save 
  2. sudo reboot 

如果你再次登录到了你的服务器,检查 node app 进程。以 yume 用户运行下面的命令。

 
 
  1. su - yume 
  2. pm2 status www 

nodejs 在 pm2 下开机自启动

nodejs 在 pm2 下开机自启动

Node 应用在 pm2 中运行并使用 Nginx 作为反向代理。





作者:Muhammad Arul
来源:51CTO
目录
相关文章
|
5天前
|
开发框架 JavaScript 中间件
中间件应用Koa.js(Node.js)
我们添加了两个中间件。第一个中间件记录请求的开始时间,并在下一个中间件执行完毕后计算并打印出请求的总时间。第二个中间件与之前的示例相同,它设置响应体为 "Hello World"
20 6
|
19小时前
|
存储 监控 JavaScript
使用Node.js构建实时聊天应用的技术指南
【5月更文挑战第12天】本文指导使用Node.js、Express.js和Socket.IO构建实时聊天应用。技术栈包括Node.js作为服务器环境、WebSocket协议、Express.js作为Web框架和Socket.IO处理实时通信。步骤包括项目初始化、安装依赖、搭建服务器、实现实时聊天功能、运行应用以及后续的完善和部署建议。通过这个指南,读者可以学习到创建简单实时聊天应用的基本流程。
|
5天前
|
JavaScript 中间件 API
中间件应用Express.js(Node.js)
我们定义了一个名为 `logger` 的中间件函数。它接受请求对象、响应对象以及下一个中间件函数作为参数。当接收到请求时,它会打印出请求的 HTTP 方法和 URL,然后调用 `next()` 函数来将控制权传递给下一个中间件或路由处理器。我们使用 `app.use()` 方法将 `logger` 中间件添加到了应用级别的中间件堆栈中,这意味着它将对所有请求生效。
12 3
|
5天前
|
Ubuntu Apache 数据库
如何在Ubuntu系统部署Z-blog博客结合cpolar实现无公网IP访问本地网站
如何在Ubuntu系统部署Z-blog博客结合cpolar实现无公网IP访问本地网站
23 2
|
5天前
|
应用服务中间件 nginx
如何在树莓派部署Nginx并实现无公网ip远程访问内网制作的web网站
如何在树莓派部署Nginx并实现无公网ip远程访问内网制作的web网站
8 0
|
6天前
|
数据采集 JavaScript 数据可视化
Node.js爬虫在租房信息监测与分析中的应用
Node.js爬虫在租房信息监测与分析中的应用
|
14天前
|
运维 Serverless 应用服务中间件
Serverless 应用引擎产品使用之在阿里云Serverless中函数计算FC nginx 部署上去之后放置静态页面如何解决
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
219 0
|
14天前
|
运维 JavaScript Java
Serverless 应用引擎产品使用之阿里云Serverless函数计算中,在Node.js环境中执行jar文件如何解决
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
21 0
|
Web App开发 弹性计算 JavaScript
部署Node.js环境
本教程介绍如何在安装了CentOS 7.2系统的ECS实例上,安装Node.js并部署项目。
968 0
|
20天前
|
JSON JavaScript 前端开发
❤Nodejs 第九章(token身份认证和express-jwt的安装认识)
【4月更文挑战第9天】Node.js第九章介绍了Token身份认证,特别是JWT(JSON Web Token)作为跨域认证的解决方案。JWT由Header、Payload和Signature三部分组成,用于在客户端和服务器间安全传输用户信息。前端收到JWT后存储在localStorage或sessionStorage中,并在请求头中发送。Express-JWT是一个中间件,用于解析JWT。基本用法包括设置secret和algorithms。注意安全问题,避免混合使用不同算法以防止降级攻击。
40 0