文档

部署Node.js环境

更新时间:

本教程介绍如何在Alibaba Cloud Linux 2系统的ECS实例上安装Node.js并部署项目。

背景信息

Node.js使用了一个事件驱动、非阻塞式I/O的模型,使其轻量又高效,非常适合运行在分布式设备的数据密集型的实时应用。Node.js的包管理器npm,是一个开源库生态系统。Node.js的典型应用场景包括:

  • 实时应用:如在线聊天,实时通知推送等等(例如socket.io)。

  • 分布式应用:通过高效的并行I/O使用已有的数据。

  • 工具类应用:海量的工具,小到前端压缩部署(例如grunt),大到桌面图形界面应用程序。

  • 游戏类应用:游戏领域对实时和并发有很高的要求(例如网易的pomelo框架)。

  • Web渲染:利用稳定接口提升Web渲染能力。

  • 前后端编程语言环境统一:前端开发人员可以非常快速地切入到服务器端的开发(例如著名的纯JavaScript全栈式MEAN架构)。

前提条件

  • 使用本教程进行操作前,请确保您已经注册了阿里云账号。如还未注册,请先完成账号注册

  • 已创建ECS实例。具体操作,请参见自定义购买实例

    说明

    本文示例场景中,创建ECS实例时选用了公共镜像Alibaba Cloud Linux 2.1903 LTS 64位。

步骤一:部署Node.js环境

  1. 远程连接已创建的ECS实例。

  2. 部署Node.js环境。

    使用NVM安装多个Node.js版本

    NVM(Node Version Manager)是Node.js的版本管理软件,使您可以轻松在Node.js各个版本间进行切换。适用于长期做node开发的人员或有快速更新node版本、快速切换node版本的场景。具体操作步骤如下:

    1. 安装分布式版本管理系统Git。

      yum install git -y
    2. 使用Git将NVM的源码克隆到本地的~/.nvm目录下,并检查最新版本。

      说明

      由于网络原因,可能会出现无法克隆的问题,建议您多尝试几次。

      git clone https://gitee.com/mirrors/nvm.git ~/.nvm && cd ~/.nvm && git checkout `git describe --abbrev=0 --tags`
    3. 依次运行以下命令,配置NVM的环境变量。

      echo ". ~/.nvm/nvm.sh" >> /etc/profile
      source /etc/profile
    4. 运行以下命令,修改npm镜像源为阿里云镜像,以加快Node.js下载速度。

      export NVM_NODEJS_ORG_MIRROR=https://npmmirror.com/mirrors/node
    5. 运行以下命令,查看Node.js版本。

      nvm list-remote
    6. 安装多个Node.js版本。

      1. 安装v14.0.0版本。

        nvm install v14.0.0
      2. 安装v16.0.0版本。

        nvm install v16.0.0
    7. 查看已安装的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版本为例,具体操作说明如下:

    1. 下载Node.js安装包。

      wget https://nodejs.org/dist/v16.0.0/node-v16.0.0-linux-x64.tar.xz
      说明

      更多Node.js版本,请参见Node.js官网

    2. 运行以下命令,解压Node.js安装包。

      tar xvf node-v16.0.0-linux-x64.tar.xz
    3. 依次运行以下命令,创建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
    4. 依次查看node、npm版本信息。

      node -v
      npm -v

      至此,Node.js环境已安装完毕。软件默认安装在/root/node-v16.0.0-linux-x64/目录下。

      如果您需要将该软件安装到其他目录下,例如:/opt/node/,可以依次运行以下命令:

      1. 创建/opt/node/路径。

        mkdir -p /opt/node/
      2. 将Node.js的所有文件移动至/opt/node/

        mv /root/node-v16.0.0-linux-x64/* /opt/node/
      3. 依次运行以下命令,移除源路径中node和npm的软链接。

        rm -f /usr/local/bin/node
        rm -f /usr/local/bin/npm
      4. 依次运行以下命令,在/opt/node/中新建node和npm的软链接。

        ln -s /opt/node/bin/node /usr/local/bin/node
        ln -s /opt/node/bin/npm /usr/local/bin/npm

步骤二:部署测试项目

  1. 依次运行以下命令,创建测试项目文件example.js

    1. 返回/root路径。

      cd
    2. 创建测试项目文件example.js

      touch example.js
  2. 修改项目文件example.js

    1. 运行以下命令打开example.js

      vim example.js
    2. 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}/`);
      });
    3. 添加完成后,按Esc键退出编辑模式,并输入:wq后按Enter键,保存退出文件。

  3. 运行项目并得到项目的端口号。

    node ~/example.js &
  4. 运行以下命令,列入系统已在监听的端口信息。

    netstat -tpln

    本示例中,返回的结果列表中包含端口3000,表明项目正常运行。

  5. 在ECS实例的安全组中,添加入方向规则,放行项目中配置的端口号。

    本示例中,项目端口号为3000。添加安全组规则的具体操作,请参见添加安全组规则

  6. 在本地Windows主机或其他任一具有公网访问能力的Windows主机中,打开浏览器并访问http://<ECS实例公网IP地址>:<项目端口号>

    本示例中,<项目端口号>为3000。访问到的测试项目如下图所示:

  • 本页导读 (1)
文档反馈