详解Node项目部署到云服务器上


Posted in Javascript onJuly 12, 2017

本篇介绍了Node项目部署到云服务器上,小编觉得不错,分享给大家,具体如下:

Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,用来方便地搭建快速的易于扩展的网络应用。Node.js 使用了一个事件驱动、非阻塞式 I/O 的模型,使其轻量又高效,非常适合运行在分布式设备的数据密集型的实时应用。Node.js 的包管理器 npm,是全球最大的开源库生态系统。典型的应用场景包括:

  1. 实时应用:如在线聊天,实时通知推送等等(如socket.io)
  2. 分布式应用:通过高效的并行I/O使用已有的数据
  3. 工具类应用:海量的工具,小到前端压缩部署(如grunt),大到桌面图形界面应用程序
  4. 游戏类应用:游戏领域对实时和并发有很高的要求(如网易的pomelo框架)
  5. 利用稳定接口提升Web渲染能力
  6. 前后端编程语言环境统一:前端开发人员可以非常快速地切入到服务器端的开发(如著名的纯Javascript全栈式MEAN架构)

一、服务器购买

阿里云、腾讯云、百度云等等都可以选择,购买对应的云服务器或云服务器 ECS(选择平台不同名字可能会不一致),系统镜像选择CentOS7.2,其他带宽、内存等自行配置。如果只是小型网站,建议配置最低即可。

  1.   CPU:1核
  2.   内存:1GB
  3.   系统盘:Linux 20G
  4.   带宽:1Mbps

二、服务器登陆

通过ssh方式登陆服务器

$ ssh root@192.168.1.112  // 格式: ssh 用户名@公网IP

三、部署Node.js环境

该部署过程使用的安装包是已编译好的二进制文件,解压之后,在bin文件夹中就已存在node和npm,无需手工编译。

wget命令下载Node.js安装包,该安装包是编译好的文件,解压之后,在bin文件夹中就已存在node和npm,无需重复编

$ 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命令全局有效(通过创建软链接的方法,使得在任意目录下都可以直接使用node和npm命令)

$ ln -s /root/node-v6.9.5-linux-x64/bin/node /usr/local/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

注: 如果不在意软件安装路径,就跳过该操作;

四、部署Node.js环境(NVM安装多版本)

NVM(Node version manager)是Node.js的版本管理软件,使用户可以轻松在Node.js各个版本间进行切换。适用于长期做 node 开发的人员或有快速更新node版本、快速切换node版本这一需求的用户。

直接使用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 ls

安装多个Node.js版本

$ nvm install v6.9.5
$ nvm install v7.4.0

需要哪些node版本即安装对应版本即可

查看已安装Node.js版本

$ nvm ls
->    v6.9.5
     v7.4.0

切换Node.js版本至v7.4.0

$ nvm use v7.4.0
 Now using node v7.4.0

五、部署测试项目

  1.   - $ touch server.js  // 新建文件
  2.   - $ vi server.js   // 打开文件server.js
  3.   - 按i进入编辑状态,将下面代码复制到该文件中
  4.   - 按esc退出编辑状态
  5.   - :wq  // 退出并保存
  6.   - $ node server.js  // 运行server.js
  7.   - 在浏览器中打开页面: http://服务器IP:3000
$ node server.js & // 将项目置于后台运行(只要服务器不关机,它就会一直在后台运行)
 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}/`);
 });

六、文件上传到服务器

scp

优点: 简单方便,安全可靠;支持限速参数

格式: scp [参数] <源地址(用户名@IP地址或主机名)>:<文件路径> <目的地址(用户名 @IP 地址或主机

scp /home/work/source.txt work@192.168.0.10:/home/work/ #把本地的source.txt文件拷贝到192.168.0.10机器上的/home/work目录下
scp work@192.168.0.10:/home/work/source.txt /home/work/ #把192.168.0.10机器上的source.txt文件拷贝到本地的/home/work目录下
scp work@192.168.0.10:/home/work/source.txt work@192.168.0.11:/home/work/ #把192.168.0.10机器上的source.txt文件拷贝到192.168.0.11机器的/home/work目录下
scp -r /home/work/sourcedir work@192.168.0.10:/home/work/ #拷贝文件夹,加-r参数 
scp -r /home/work/sourcedir work@www.myhost.com:/home/work/ #使用主机名 
scp -r -v /home/work/sourcedir work@www.myhost.com:/home/work/ #显示详情,加-v

github (前提是项目是开源)

  1. - 将本地代码托管到github
  2. - 在服务器中将代码clone下来

本地代码如果有修改,先更新到github代码仓库;在服务器中,更新代码即可;

七、关于后台运行进程

$ node server.js &

通过该命令行$ node server.js & ,将项目置于后台运行

$ netstat -tpln

如果想要查看项目端口是否存在,即查看项目是否在后台运行

$ kill xxx

结束对应的进程,kill后面写的是进程号.

详解Node项目部署到云服务器上

进程号

例如想要结束端口号为2017的进程,2017端口对应的进程号是19451,通过命令行 kill 19451

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
20个非常棒的 jQuery 幻灯片插件和教程分享
Aug 23 Javascript
jquery 表格的增行删行实现思路
Mar 21 Javascript
火狐下table中创建form导致两个table之间出现空白
Sep 02 Javascript
jQuery+CSS实现一个侧滑导航菜单代码
May 09 Javascript
jQuery简单实现tab选项卡切换效果
Jun 20 Javascript
JS基于构造函数实现的菜单滑动显隐效果【测试可用】
Jun 21 Javascript
js面向对象实现canvas制作彩虹球喷枪效果
Sep 24 Javascript
JS实现的简易拖放效果示例
Dec 29 Javascript
webpack4.0打包优化策略整理小结
Mar 30 Javascript
angular4 共享服务在多个组件中数据通信的示例
Mar 30 Javascript
解决vue js IOS H5focus无法自动弹出键盘的问题
Aug 30 Javascript
微信小程序实现多图上传
Jun 19 Javascript
angular.js中解决跨域问题的三种方式
Jul 12 #Javascript
JavaScript+HTML5实现的日期比较功能示例
Jul 12 #Javascript
JavaScript实现设置默认日期范围为最近40天的方法分析
Jul 12 #Javascript
Bootstrap提示框效果的实例代码
Jul 12 #Javascript
JavaScript输出所选择起始与结束日期的方法
Jul 12 #Javascript
微信小程序三级联动地址选择器的实例代码
Jul 12 #Javascript
微信小程序 共用变量值的实现
Jul 12 #Javascript
You might like
用PHP实现将GB编码转换为UTF8
2006/11/25 PHP
php数组相加 array(“a”)+array(“b”)结果还是array(“a”)
2012/09/19 PHP
Windows下php+mysql5.7配置教程
2017/05/16 PHP
jQuery 1.0.4 - New Wave Javascript(js源文件)
2007/01/15 Javascript
Javascript 写的简单进度条控件
2008/01/22 Javascript
JavaScript入门教程(10) 认识其他对象
2009/01/31 Javascript
js 将json字符串转换为json对象的方法解析
2013/11/13 Javascript
jquery 选取方法都有哪些
2014/05/18 Javascript
JSON.parse()和JSON.stringify()使用介绍
2014/06/20 Javascript
node.js中的console.time方法使用说明
2014/12/09 Javascript
javascript感应鼠标图片透明度显示的方法
2015/02/24 Javascript
jquery动态添加文本并获取值的方法
2016/10/12 Javascript
jQuery实现点击任意位置弹出层外关闭弹出层效果
2016/10/19 Javascript
javascript跨域请求包装函数与用法示例
2016/11/03 Javascript
js随机生成一个验证码
2017/06/01 Javascript
JavaScript中使用import 和require打包后实现原理分析
2018/03/07 Javascript
浅谈Angular6的服务和依赖注入
2018/06/27 Javascript
JS实现的JSON序列化操作简单示例
2018/07/02 Javascript
javascript中UMD规范的代码推演
2018/08/29 Javascript
vue 使用vue-i18n做全局中英文切换的方法
2018/10/29 Javascript
Angular脚手架开发的实现步骤
2019/04/09 Javascript
vue+element UI实现树形表格带复选框的示例代码
2019/04/16 Javascript
js获取本日、本周、本月的时间代码
2020/02/01 Javascript
使用Taro实现小程序商城的购物车功能模块的实例代码
2020/06/05 Javascript
vue实现滚动鼠标滚轮切换页面
2020/12/13 Vue.js
详解 Python中LEGB和闭包及装饰器
2017/08/03 Python
python opencv实现运动检测
2018/07/10 Python
django开发post接口简单案例,获取参数值的方法
2018/12/11 Python
python实现几种归一化方法(Normalization Method)
2019/07/31 Python
Python numpy数组转置与轴变换
2019/11/15 Python
基于python实现上传文件到OSS代码实例
2020/05/09 Python
美国受欢迎的眼影品牌:BH Cosmetics
2016/10/25 全球购物
英国最大的手表网站:The Watch Hut
2017/03/31 全球购物
汽车维修专业毕业生的求职信分享
2013/12/04 职场文书
办理退休介绍信
2014/01/09 职场文书
公司保洁员管理制度
2015/08/04 职场文书