https://www.phusionpassenger.com/docs/tutorials/what_is_passenger/


What is Passenger?

一个开源的web程序服务。它除了HTTP请求,管理进程和资源,能够administration, monitoring,并进行问题诊断。

容易使用,让产品的部署变得容易和scalable(

if a piece of computer hardwareor software is scalable, it continues to work well even if it is made bigger or connected to a larger number of other pieces of equipment

)即使程序逐步变大仍然运行良好。

它支持多种编程语言,Ruby, Python, Node。

它也能同时服务多个程序。

https://www.phusionpassenger.com/advantages   (图文简介,很有趣,把自己比做航天器,功能强大,让passengers轻松使用)

Fundamental concepts

关于Ruby的。

Passenger and "rails server"

ROR框架提供一个内建的服务器工具, 让可以使用rails server命令。但"rails server"本身不是一个app server,而是一个小的wrapper,在一个app server内,发射你的app。

这就是人们不使用"rails server"在production的原因。他们直接地使用一个应用程序服务an application server,比如Passenger。

"rails server" uses Puma by default as of Rails 5.

如果你增加Passenger到你的Gemfile(点击看step by step), “rails server”会发射Passenger替代Puma。当然也可以直接选择launch Passenger 。

How Passenger fits in the stack

当部署web app到production, 有各种类型的组件be involved(参与)。

你可能听说过Unicorn, Puma, Nginx, Apache and Capistrano.

Passenger当和其他组件合作时,会取代一些组件。Passenger replaces some components, while collaborating with other components.

In a typical production stack, one would use Nginx or Apache as the web server, Passenger as application server, and Capistrano as release automation tool. Passenger integrates with Nginx or Apache and manages the application and its resources.

在一个典型的产品堆,一个将使用Nginx/Apache作为web服务器, Passenger作为app服务器,Capistrano作为版本释放的自动化工具。Passenger集成了Nginx/Apache并管理app和它的resources.

需要联合使用Nginx or Apache的原因:(2个)

web servers. 提供HTTP transaction 处理和服务静态的文件。

1.但是,它们不是Ruby app 服务器,不能直接的跑Ruby app.

所以需要联合一个app 服务器,例如Passenger.

Application servers make it possible for Ruby apps to speak HTTP.

app服务器可以让Ruby apps理解并使用HTTP语法。Ruby apps(如Rails)它们自身做不到这点。

2.另一方面,app server明显不能像Nginx/Apache那样高效的处理HTTP请求。

魔鬼在细节里:

Nginx/Apache更善于处理I/O安全, HTTP并发concurrency管理, timeout超时连接等等!!!

因此,在产品环境内,程序服务器app server和Nginx/Apache联合起来被使用。

Capistrano

一个应用程序 release automation tool! (释放版本时,自动化处理一系列actions的工具)。

当释放一个你的web application的新版本时,会有actions需要被执行performed, 如uploading你的程序代码到服务器, 运行一条命令来安装你的gem bundle,重启进程等等。Capistrano会自动化这些actions.

Capistrano不能取代一个server来提供HTTP transaction handling, 所以它联合app servers和web servers。

Unicorn and Puma

可选的app servers。被Passenger代替了。

因为,Passenger让使用更方便,和其他组件集成,自动管理和问题诊断diagnosis.

Multiple integration mode 多重集成模型

之前讲了Passenger和其他组件合作。因此它支持多重集成模型。

下面只会涉及Standalone mode。 Nginx/Apache集成模型在deployment tutorial会讲解。

在Standalone mode, Passenger使用内建web server。在Nignx/Apache集成模型,Passenger和Nignx/Apache集成。

Standalone mode

这个模型,不和其他组件合作。在development阶段,可以使用这个模型。

Nginx integration mode

这个模型,Passenger作为一个Nginx模块来操作。

绝大多数情况下是通过Nginx和通过Nginx配置文件,来操作Passenger。

因此可以把它们当成一个整体。

这个模型用于production,不是development。

What Passenger does not do

  1. 不能建立一个带操作系统的服务器。Passenger假设你已经有一个服务器和工作的操作系统。Passenger不是一个hosting service主机服务。
  2. 不能安装Ruby。想要在Passenger上运行Ruby,你必须先安装Ruby。你需要告诉Passenger你在哪安装了Ruby。
  3. 不能传输app code和file到server。 你需要使用如Capistrano之类的工具。Passenger假定app code和文件已经在server上了。
  4. 不能安装应用依赖。 这些工作属于Bundler和Capistrano。
  5. 不能管理数据库。如果你的系统需要一个数据库,你必须自己安装。

部署:

Passenger简介的更多相关文章

  1. Spring Web Flow 简介

    Spring Web Flow 简介 博客分类: 转载 SSH 最近在TSS上看到了一片介绍Spring Web Flow的文章,顺便就翻译了下来,SWF的正式版估计要到6月份才能看到了,目前的例子都 ...

  2. rails 部署 nginx + passenger

    转自 http://segmentfault.com/a/1190000002911605 https://ruby-china.org/topics/16245 运行 RAILS_ENV=produ ...

  3. Java 依赖注入标准(JSR-330)简介

    作者:88250 ,Vanessa 时间:2009 年 11 月 19 日      Java 依赖注入标准(JSR-330,Dependency Injection for Java)1.0 规范已 ...

  4. ASP.NET Core 1.1 简介

    ASP.NET Core 1.1 于2016年11月16日发布.这个版本包括许多伟大的新功能以及许多错误修复和一般的增强.这个版本包含了多个新的中间件组件.针对Windows的WebListener服 ...

  5. MVVM模式和在WPF中的实现(一)MVVM模式简介

    MVVM模式解析和在WPF中的实现(一) MVVM模式简介 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 MVVM模式解析和在 ...

  6. Cassandra简介

    在前面的一篇文章<图形数据库Neo4J简介>中,我们介绍了一种非常流行的图形数据库Neo4J的使用方法.而在本文中,我们将对另外一种类型的NoSQL数据库——Cassandra进行简单地介 ...

  7. REST简介

    一说到REST,我想大家的第一反应就是“啊,就是那种前后台通信方式.”但是在要求详细讲述它所提出的各个约束,以及如何开始搭建REST服务时,却很少有人能够清晰地说出它到底是什么,需要遵守什么样的准则. ...

  8. Microservice架构模式简介

    在2014年,Sam Newman,Martin Fowler在ThoughtWorks的一位同事,出版了一本新书<Building Microservices>.该书描述了如何按照Mic ...

  9. const,static,extern 简介

    const,static,extern 简介 一.const与宏的区别: const简介:之前常用的字符串常量,一般是抽成宏,但是苹果不推荐我们抽成宏,推荐我们使用const常量. 执行时刻:宏是预编 ...

随机推荐

  1. Linux电源管理(五)thermal【转】

    本文转载自:https://blog.csdn.net/zhouhuacai/article/details/78172267 版权声明:本文为博主原创文章,未经博主允许不得转载.    https: ...

  2. dede的应用

    gbk和utf-8版本选择 gbk是国家编码,所有的内容编码,包括中文,英文,英文字符都占两个字节. utf-8是国际编码,中文三个字节,英文1个字节 现阶段,网站都用gbk编码, 一方面节省本地/网 ...

  3. FJUT 倒水(倒水问题)题解

    题意:开学了, fold拿着两个无刻度, 容量分别是5L和7L的量筒来问Anxdada, 说水是无限的, 并且可以无限次将杯子装满或者清空, 那怎么用这个两个量筒倒出恰好4L水了? 我说简单啊, 先装 ...

  4. Hierarchical Question-Image Co-Attention for Visual Question Answering

    Hierarchical Question-Image Co-Attention for Visual Question Answering NIPS 2016 Paper: https://arxi ...

  5. Twitter OAuth

    新浪微博和 Twitter 的 Oauth API 为什么感觉流程不一样 新浪: 开发者引导用户到新浪授权页面, 页面链接中需要带上自己的 apikey : 用户授权后新浪跳转到开发者指定指定的页面, ...

  6. Kubernetes命令

    kubectl applykubectl getkubectl set image deployment/xxx -n ns  echoservice=xxxkubectl deletekubectl ...

  7. codeforce gym/100495/problem/F Snake++——DFS应用

    emmmm.... 在被新生暴打后,我花了很久才补出这道DFS.由于WA1检查了半天,最后竟然是输出少了一个:   ,心态小崩. 这里普通的dfs算出的连通区域并不能直接当做最后的答案.所以需要类似模 ...

  8. springmvc上传zip文件并解压缩代码示例

    <input type="file"  id="file"  name="file"> spring中的配置: <!-- ...

  9. 使用 node 创建代码服务器

    var express = require('express'); var proxy = require('http-proxy-middleware'); var app = express(); ...

  10. K-近邻

    概述 KNN算法本身简单有效,是一种lazy-learning算法: 分类器不需要使用训练集进行训练,训练时间复杂度为0: KNN分类的计算复杂度和训练集中的文档数目成正比,也就是说,如果训练集中文档 ...