12.2部署的基础知识

假定你创建了一个想要展示的Web程序,或者创建了一个商业应用,在把它放到生产环境中
之前需要测试一下。你很可能会从一个简单的部署开始,然后再做些工作让它的正常运行时间和
性能达到最优。本节会带着你经历一次简单、临时的Git部署,并教你如何用Forever把程序跑起
来。临时性部署在重启后会丢失,但它们的优势是设置起来很迅速。

12.2.1 从Git存储库部署
我们快速过一下使用Git存储库的基本部署,让你对主要步骤有个直观的认识。
大多数部署都需要完成下面这些步骤:
(1) 用SSH连接到服务器上;
(2) 如果需要的话,在服务器上安装Node和版本控制工具(比如Git和Subversion) ;
(3) 从版本控制存储库中下载程序文件,包括Node脚本、图片和CSS样式表,放到服务器上;
(4) 启动程序。
这里有个例子,用Git下载完程序文件后启动它:
像PHP一样,Node也不是后台任务。因此我们列出来的这个基本部署不能断开 SSH连接。SSH
连接一旦断开,程序就会终止。不过用一个简单的工具就可以轻松地让程序保持运行状态。
自动部署 有几种可以自动部署Node 程序的办法。其中一种是使用Fleet
(https://github.com/substack/fleet)这样的工具,可以用git push部署到一或多个服务器
上。更传统的方式是用Capistrano, Evan Tahler的博客 Bricolage上发表了一篇详细介绍
文章“用Capistrano部署node.js程序”(http://mng.bz/3K9H)。

12.2.2 让Node保持运行
比如说你用Cloud9 Nog博客程序(https://github.com/c9/nog)创建了一个个人博客,现在你
想要部署它,并要确保在你断开SSH连接后它仍能运行。
在Node社区中,针对这个问题最常用的处理工具是Nodejitsu的Forever(https://github.com/
nodejitsu/forever)。它能在你断开SSH连接后让程序保持运行状态,在程序崩溃退出后还能重启它。
图12-3是Forever工作机制的概念图。


你可以用sudo命令做Forever的全局安装。
SUDO命令 在做npm模块的全局安装时(带-g选项),经常需要在npm命令前面
加上sudo(www.sudo.ws/),以超级管理员的权限运行npm命令。在你第一次使用sudo
命令时,系统会提示你输入密码。然后再运行跟在sudo后面的命令。
如果你一直跟着我们,现在用下面的命令安装Forever:

sudo npm install  -g   forever

Forever装好之后,你可以用下面这条命令启动你的博客,并让它一直运行下去:

forever start  server.js

如果出于某些原因你想停止这个博客,可以用Forever的stop命令:

forever stop server.js

使用Forever时,你可以用它的list命令获取它所管理的程序清单:

forever list

Forever还有一个比较实用的功能,当有源码文件发生变化时,可以让它重启程序。这样每次
添加新特性或修订bug时,你就不用再手动重启了。
要在这种模式下启动Forever,请用-w选项:

forever -w  start server.js

尽管Forever在程序部署上是一个极其实用的工具,但你可能想要一些功能更完备的东西做长
期部署。下一节我们会看一些工业级强度的监测方案,并看看如何让程序的性能达到最优。

部署node程序并维持正常运行时间的更多相关文章

  1. 使用 pm2 优雅的部署 node 程序

    使用 pm2 优雅的部署 node 程序 # 启动并监控名字为 XXX 的 npm run start:dev 命令 pm2 start npm --watch --name XXX -- run s ...

  2. 一种简单的生产环境部署Node.js程序方法

    最近在部署Node.js程序时,写了段简单的脚本,发觉还挺简单的,忍不住想与大家分享. 配置文件 首先,本地测试环境和生产环境的数据库连接这些配置信息是不一样的,需要将其分开为两个文件存储 到conf ...

  3. 在Heroku上部署Node.js应用

    最近在学习Node.js,想找一个可以免费部署Node的平台,于是便找到了Heroku 直接进入主题,接下来我们一步一步部署自己的Node应用. 步骤1: 注册一个免费的Heroku账号. 步骤2: ...

  4. 部署Node.js项目(CentOS)

    Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,用来方便地搭建快速的易于扩展的网络应用.Node.js 使用了一个事件驱动.非阻塞式 I/O 的模型,使其轻量又 ...

  5. 阿里云部署Node.js项目(CentOS)

    Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,用来方便地搭建快速的易于扩展的网络应用.Node.js 使用了一个事件驱动.非阻塞式 I/O 的模型,使其轻量又 ...

  6. Java核心技术卷一基础知识-第10章-部署应用程序和applet-读书笔记

    第10章 部署应用程序和applet 本章内容: * JAR文件 * Java Web Start * applet * 应用程序首选项存储 10.1 JAR文件 一个JAR文件既可以包含类文件,也可 ...

  7. 【转载】在Centos系统上采用二进制文件部署Node.js环境

    Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,用来方便地搭建快速的易于扩展的网络应用.Node.js 使用了一个事件驱动.非阻塞式 I/O 的模型,使其轻量又 ...

  8. Nodejs实战 —— 测试 Node 程序

    读 <node.js实战2.0>,进行学习记录总结. 当当网购买链接 豆瓣网1.0链接 测试 Node 程序 本章内容 用 Node 的 assert 模块测试 使用其他断言库 使用 No ...

  9. 使用pm2自动化部署node项目

    1.pm2简介 pm2(process manager)是一个进程管理工具,维护一个进程列表,可以用它来管理你的node进程,负责所有正在运行的进程,并查看node进程的状态,也支持性能监控,负载均衡 ...

随机推荐

  1. android 入门-基础了解

    strings.xml – 文字資源. colors.xml – 顏色資源. dimens.xml – 尺寸資源. arrays.xml – 陣列資源. styles.xml – 樣式資源. #RGB ...

  2. WPF之MVVM(Step2)——自己实现DelegateCommand:ICommand

    在自己实现MVVM时,上一篇的实现方式基本是不用,因其对于命令的处理不够方便,没写一个命令都需要另加一个Command的类.此篇主要介绍DelegateCommand来解决上面所遇到的问题. 首先,我 ...

  3. Android学习网站推荐(转)

    收集了一些比较好的Android学习网站,希望对大家有所帮助: 1.http://developer.android.com/ Android官方网站,可惜被屏蔽了,需要使用FQ软件 2.http:/ ...

  4. ViewPager onPageChangeListener总结(转)

    android ViewPager滑动事件讲解 今天在做项目的时候,由于要处理viewPager页面滑动的事件,所以对其进行了一个小小的研究: 首先ViewPager在处理滑动事件的时候要用到OnPa ...

  5. customTextbox

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.W ...

  6. javase基础笔记4——异常/单例和类集框架

    继承 extends final关键 多态 是在继承的基础上 接口 interface 异常 exception 包的访问可控制权限 private default protect public 异常 ...

  7. ios 区域检测 使用coreLocation

    #import "ViewController.h" #import <CoreLocation/CoreLocation.h> @interface ViewCont ...

  8. 移动 Web 开发技巧

    1.使用click会出现绑定点击区域闪一下的情况,解决:给该元素一个样式如下 -webkit-tap-highlight-color: rgba(0,0,0,0); 2.用iphone或ipad浏览很 ...

  9. Released Mocked Streams for Apache Kafka

    Kafka Streams is a de­ploy­ment-ag­nos­tic stream pro­cess­ing li­brary writ­ten in Java. Even thoug ...

  10. js获取一个对象的所以属性和值

    在HTML DOM中,获取某个元素对象的时候,往往记不住它的很多属性,可以通过下面的例子来查找一下: <!DOCTYPE html> <html> <body> & ...