部署Node.js环境(CentOS 7)
Node.js是一个基于Chrome V8引擎的JavaScript运行环境,用来方便快速地搭建易于扩展的网络应用。本文介绍如何在CentOS 7.x操作系统的ECS实例上,安装Node.js并部署测试项目。
背景信息
Node.js使用了一个事件驱动、非阻塞式I/O的模型,使其轻量又高效,非常适合运行在分布式设备的数据密集型的实时应用。Node.js的包管理器npm,是一个开源库生态系统。Node.js的典型应用场景包括:
实时应用:如在线聊天,实时通知推送等等(例如socket.io)。
分布式应用:通过高效的并行I/O使用已有的数据。
工具类应用:海量的工具,小到前端压缩部署(例如grunt),大到桌面图形界面应用程序。
游戏类应用:游戏领域对实时和并发有很高的要求(例如网易的pomelo框架)。
Web渲染:利用稳定接口提升Web渲染能力。
前后端编程语言环境统一:前端开发人员可以非常快速地切入到服务器端的开发(例如著名的纯JavaScript全栈式MEAN架构)。
准备工作
快速部署时选择已有实例或手动部署Node.js环境时,已有ECS实例必须满足以下条件:
实例已分配公网IP地址或绑定弹性公网IP(EIP)。
操作系统必须为CentOS 7.x。
实例安全组的入方向规则已放行22端口。具体操作,请参见添加安全组规则。
操作步骤
快速部署
快速部署基于阿里云资源编排服务ROS(Resource Orchestration Service)实现,使用NVM(Node Version Manager)安装了v14.0.0和v16.0.0版本的Node.js环境,并部署了一个测试项目example.js。
打开快速配置模板链接进入ROS控制台。
- 在页面左侧顶部,选择目标资源所在的地域。
在配置模板参数页面,输入资源栈名称,选择已有ECS实例或新建ECS实例。
新建ECS实例时,需要选择可用区、实例规格、系统盘类型,输入实例密码。
重要创建ECS实例会创建一个CentOS 7.x操作系统的按量付费ECS实例并绑定了1 Mbps按使用流量计费的固定公网IP,关于ECS和固定公网IP的计费说明,请参见计费概述。
确认填写信息后,单击创建。
当资源栈信息页签下的状态由创建中变为创建成功时,说明Node.js环境已部署完成。
单击输出页签,然后单击ExampleUrl右侧的链接。
访问到的测试项目如下图所示:
后续使用Node.js时,您可以运行nvm install <版本号>
命令安装具体版本的Node.js,运行nvm use <版本号>
切换Node.js的版本。例如,切换至Node.js v18.0.0版本的命令为nvm use v18.0.0
。
手动部署
步骤一:部署Node.js环境
远程连接已创建的ECS实例。
具体操作,请参见通过密码或密钥认证登录Linux实例。
部署Node.js环境。
使用NVM安装多个Node.js版本
NVM(Node Version Manager)是Node.js的版本管理软件,使您可以轻松在Node.js各个版本间进行切换。适用于长期做node开发的人员或有快速更新node版本、快速切换node版本的场景。具体操作步骤如下:
安装分布式版本管理系统Git。
yum install git -y
使用Git将NVM的源码克隆到本地的~/.nvm目录下,并检查最新版本。
说明由于网络原因,可能会出现无法克隆的问题,建议您多尝试几次。
git clone https://gitee.com/mirrors/nvm.git ~/.nvm && cd ~/.nvm && git checkout `git describe --abbrev=0 --tags`
依次运行以下命令,配置NVM的环境变量。
echo ". ~/.nvm/nvm.sh" >> /etc/profile source /etc/profile
运行以下命令,修改npm镜像源为阿里云镜像,以加快Node.js下载速度。
export NVM_NODEJS_ORG_MIRROR=https://npmmirror.com/mirrors/node
运行以下命令,查看Node.js版本。
nvm list-remote
安装多个Node.js版本。
安装v14.0.0版本。
nvm install v14.0.0
安装v16.0.0版本。
nvm install v16.0.0
查看已安装的Node.js版本。
nvm ls
返回结果如下所示,表示当前已安装v14.0.0、v16.0.0两个版本,正在使用的是v16.0.0版本。
v14.0.0 -> v16.0.0 default -> v14.0.0 iojs -> N/A (default) unstable -> N/A (default) node -> stable (-> v16.0.0) (default) stable -> 16.0 (-> v16.0.0) (default) lts/* -> lts/hydrogen (-> N/A) lts/argon -> v4.9.1 (-> N/A) lts/boron -> v6.17.1 (-> N/A) lts/carbon -> v8.17.0 (-> N/A) lts/dubnium -> v10.24.1 (-> N/A) lts/erbium -> v12.22.12 (-> N/A) lts/fermium -> v14.21.3 (-> N/A) lts/gallium -> v16.20.1 (-> N/A) lts/hydrogen -> v18.16.1 (-> N/A)
说明您可以运行nvm use <版本号>命令切换Node.js的版本。例如,切换至Node.js v18.0.0版本的命令为nvm use v18.0.0。
使用二进制文件安装
该方式使用的安装包是已编译好的二进制文件。解压文件之后,在bin文件夹中就已存在node和npm,无需重复编译。本文以安装Node.js v16.0.0版本为例,具体操作说明如下:
下载Node.js安装包。
wget https://nodejs.org/dist/v16.0.0/node-v16.0.0-linux-x64.tar.xz
说明更多Node.js版本,请参见Node.js官网。
运行以下命令,解压Node.js安装包。
tar xvf node-v16.0.0-linux-x64.tar.xz
依次运行以下命令,创建node和npm的软链接。
创建软链接后,您可以在任意目录下直接使用node和npm命令。
ln -s /root/node-v16.0.0-linux-x64/bin/node /usr/local/bin/node ln -s /root/node-v16.0.0-linux-x64/bin/npm /usr/local/bin/npm
依次查看node、npm版本信息。
node -v npm -v
至此,Node.js环境已安装完毕。软件默认安装在/root/node-v16.0.0-linux-x64/目录下。
如果您需要将该软件安装到其他目录下,例如:/opt/node/,可以依次运行以下命令:
创建/opt/node/路径。
mkdir -p /opt/node/
将Node.js的所有文件移动至/opt/node/。
mv /root/node-v16.0.0-linux-x64/* /opt/node/
依次运行以下命令,移除源路径中node和npm的软链接。
rm -f /usr/local/bin/node rm -f /usr/local/bin/npm
依次运行以下命令,在/opt/node/中新建node和npm的软链接。
ln -s /opt/node/bin/node /usr/local/bin/node ln -s /opt/node/bin/npm /usr/local/bin/npm
步骤二:部署测试项目
依次运行以下命令,创建测试项目文件
example.js
。返回
/root
路径。cd
创建测试项目文件example.js。
touch example.js
修改项目文件
example.js
。运行以下命令打开
example.js
。vim example.js
按i键进入编辑模式,并将以下内容添加至example.js文件中。
本示例中,项目占用的端口号为3000、输出的内容为Hello World。您需要根据实际的业务需求自行配置项目内容(res.end)、端口号(const port)等信息。
const http = require('http'); const hostname = '0.0.0.0'; const port = 3000; const server = http.createServer((req, res) => { res.statusCode = 200; res.setHeader('Content-Type', 'text/plain'); res.end('Hello World\n'); }); server.listen(port, hostname, () => { console.log(`Server running at http://${hostname}:${port}/`); });
添加完成后,按Esc键退出编辑模式,并输入
:wq
后按Enter键,保存退出文件。
运行项目并得到项目的端口号。
node ~/example.js &
运行以下命令,列入系统已在监听的端口信息。
netstat -tpln
本示例中,返回的结果列表中包含端口3000,表明项目正常运行。
在ECS实例的安全组中,添加入方向规则,放行项目中配置的端口号。
本示例中,项目端口号为3000。添加安全组规则的具体操作,请参见添加安全组规则。
在本地Windows主机或其他任一具有公网访问能力的Windows主机中,打开浏览器并访问
http://<ECS实例公网IP地址>:<项目端口号>
。本示例中,<项目端口号>为3000。访问到的测试项目如下图所示: