这里文章内容全参考阿里云nodejs服务器部署文档
步骤一:创建并连接ECS实例
完成以下操作,创建并连接ECS实例:
- 使用公共镜像CentOS 7.2 64位,创建ECS实例。具体操作,请参见创建ECS实例。
- 使用root用户连接ECS实例。具体操作,请参见使用用户名密码验证连接Linux实例。
步骤二:部署Node.js环境
选择以下任意一种方法部署Node.js环境。
-
使用二进制文件安装
该部署过程使用的安装包是已编译好的二进制文件。解压之后,在bin文件夹中就已存在node和npm,无需重复编译。
完成以下操作,使用二进制文件部署Node.js环境:
-
下载Node.js安装包。
wget https://nodejs.org/dist/v6.9.5/node-v6.9.5-linux-x64.tar.xz
-
解压文件。
tar xvf node-v6.9.5-linux-x64.tar.xz
-
创建软链接,您就可以在任意目录下直接使用node和npm命令。
首先注意usr
指Unix System Resource
,而不是User
/usr/bin
下面的都是系统预装的可执行程序,会随着系统升级而改变。/usr/local/bin
目录是给用户放置自己的可执行程序的地方,推荐放在这里,不会被系统升级而覆盖同名文件。所以我们一般把我们可执行的脚本文件放到这个目录,这样我们在linux
系统里面任何目录都可以运行了。如果没有将可执行脚本安装到该目录,我们使用软连接建立引用,使/usr/local/bin -> 脚本安装目录/文件
ln -s [源文件或目录] [目标文件或目录]
ln -s /root/node-v6.9.5-linux-x64/bin/node /usr/local/bin/node // 执行后/usr/local/bin/目录下生成node执行脚本,该脚本指向/root/node-v6.9.5-linux-x64/bin/node ln -s /root/node-v6.9.5-linux-x64/bin/npm /usr/local/bin/npm
-
查看node、npm版本。
node -v npm -v
至此,Node.js环境已安装完毕。软件默认安装在/root/node-v6.9.5-linux-x64/目录下。
-
如果需要将该软件安装到其他目录(例如:/opt/node/)下,请进行如下操作:
mkdir -p /opt/node/ mv /root/node-v6.9.5-linux-x64/* /opt/node/ rm -f /usr/local/bin/node rm -f /usr/local/bin/npm ln -s /opt/node/bin/node /usr/local/bin/node ln -s /opt/node/bin/npm /usr/local/bin/npm
-
-
使用NVM安装多版本
NVM(Node Version Manager)是Node.js的版本管理软件,使您可以轻松在Node.js各个版本间进行切换。适用于长期做node开发的人员或有快速更新node版本、快速切换node版本的场景。
完成以下操作,使用NVM安装多个Node.js版本:
-
使用git将源码克隆到本地的~/.nvm目录下,并检查最新版本。
yum install git git clone https://github.com/cnpm/nvm.git ~/.nvm && cd ~/.nvm && git checkout `git describe --abbrev=0 --tags`
-
激活NVM。
echo ". ~/.nvm/nvm.sh" >> /etc/profile source /etc/profile
-
列出Node.js的所有版本。
nvm list-remote
-
安装多个Node.js版本。
nvm install v6.9.5 nvm install v7.4.0
-
运行
nvm ls
查看已安装的Node.js版本,当前使用的版本为v7.4.0。返回结果如下所示。[root@iZXXXXZ .nvm]# nvm ls v6.9.5 -> v7.4.0 system stable -> 7.4 (-> v7.4.0) (default) unstable -> 6.9 (-> v6.9.5) (default)
-
运行
nvm use v7.4.0
切换Node.js版本至v7.4.0。返回结果如下所示。[root@iZXXXXZ .nvm]# nvm use v7.4.0 Now using node v7.4.0
-
步骤三:部署测试项目
完成以下操作,部署测试项目:
-
新建项目文件example.js。
cd ~ touch example.js
-
修改项目文件example.js。
-
运行以下命令打开example.js。
vim example.js
- 按i进入编辑模式。
-
将以下项目文件内容粘贴到文件中。
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}/`); });
说明本示例中,项目配置的端口号为3000。实际应用过程中,您可以自行配置端口号,但是必须在ECS实例安全组的入方向添加安全组规则,放行您配置的端口号。具体操作,请参见添加安全组规则。
填写0.0.0.0/0表示允许或拒绝所有IP地址的访问 - 按Esc退出编辑模式,然后输入:wq并回车以保存并关闭文件。
-
-
运行项目。
node ~/example.js &
-
运行以下命令查看是否在监听项目端口。
netstat -tpln
本示例中,返回的结果列表中包含端口3000,表明项目正常运行。
- 登录ECS管理控制台,并在ECS实例安全组的入方向添加规则, 放行项目中配置的端口(本示例中端口号为3000)。
添加安全组规则的具体步骤,请参见添加安全组规则。
- 在本地机器的浏览器中输入
http://<ECS实例公网IP地址>:端口号
访问项目。参考
https://blog.csdn.net/longgeaisisi/article/details/78429099
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。