70+专家分享实战经验,2024年度AI最佳实践都在AICon北京 了解详情
写点什么

关注部署:谈 Rails 应用的最后一公里

  • 2008-01-15
  • 本文字数:1912 字

    阅读完需:约 6 分钟

基于 Rails 框架应用开发的普及,在为用户带来众多创造性应用的同时,也赋予了开发者令人兴奋的高效与快捷体验。使用 Rails 开发 Web 应用的最后一个步骤,是要把 Ruby 代码从开发测试环境中迁移到实际生产模式之下。相比于开发过程来说,应用的部署并非易事。如何保证部署后站点的稳定和健壮性,并且可以从容应对大规模的并发访问,每一位富有经验的开发者或许都有自己的一套途径,就此,InfoQ 中文站汇总了近期 Rails 部署问题的各方面观点,为您提供参考。

早在 Rails 应用普及之初,就时常会听见针对 Rails 部署问题的抱怨。对于 PHP,一直以来都是以成熟的 LAMP 模式进行部署,讨论主要是集中在如何有效的进行服务器规模的拓展等等。而 Rails 方面则是没有统一的规则,Web 服务器的组合方式和部署工具也都有各自的特色,应用的部署对开发新手来说,是个常会产生困惑的问题,在题为“我不喜欢 RoR 的原因”的帖子中,一位开发者提到:

RoR 无疑是目前最具生产效率的开发框架之一,实现同样的应用,确使得开发时间缩减到原先的一半。但令我感到困扰的是,RoR 对于开发者的确具有吸引力,但客户却并不这么认为。比方说,Rails 应用的部署方式非常复杂,客户并不熟悉如何将开发好的应用部署在自己的服务器上,并且他们不喜欢使用命令行和脚本来操作 Rails 应用。

的确,相比 PHP 应用 LAMP 模式的部署,Rails 的可选方案非常多。保持站点的稳定性和健壮性,所涉及的不仅仅是 Rails 或 Ruby 开发相关的技术,还有很多因素来自于 Web 服务器和应用服务器的选择与搭配。Rails 部署常见的架构中,前端服务器加多个进程处理的方式如 Fastcgi,Mongrel 的选择以及与 Web 服务器的搭配使用,往往会给用户造成困扰。在《应用 Rails 进行敏捷 Web 开发》一书中,对于 Rails 的部署过程也作了简单的描述,但是所提供的部署方式并不十分合适于大规模网站的并发访问。论坛里的讨论中,常会针对于 Lighttpd+FastCGI、Nginx+Mongrel、Apache+FastCGI 等不同的搭配模式展开讨论。对于 Mongrel 服务器,Robbin 在文章“ RoR 部署方案深度剖析”中评价道:

我们假设使用服务器端程序控制带权限的文件下载,某用户下载的是一个 100MB 的文件,该用户使用了多线程下载工具,他开了 10 个线程并发下载,那么每个线程 Mongrel 在响应之后,都会把整个文件读入到内存的 StringIO 对象当中,所以总共会创建出来 10 个 StringIO 对象保存 10 份文件内 容,所以 Mongrel 的内存会一下暴涨到 1GB 以上。而且最可怕的是,即使当用户下载结束以后,Mongrel 的内存都不会迅速回落,而是一直保持如此 高的内存占用,这是因为 Ruby 的 GC 机制不好,不能够及时进行垃圾回收。

对此,robinlu 根据自己的 Rails 部署经验写道

Mongrel 处理 rails request 和静态文件使用的是不同的 handler。处理静态文件用的是 DirHandler,DirHandler 没有通过调用 response 的 start 方法使用到 StringIO, 而是直接调用了 response 的 send_file 方法,直接 write socket。验证过程非常简单,自己起一个 mongrel,在 public 下放一个 100M 的文件,通过浏览器下载一下。在我的 mac 上, 本来是 76M 的 mongrel,在下载结束后是 74M,下载过程中也一直小于 80M,最低到过 68M。无论是过程中还是结束后,都没有出现占用内存暴涨的现象。

的确,针对 Rails 部署的 Web 服务器与应用服务器的搭配方案,会令客户面对众多的选择,并且 JVM 之上的 JRuby 以及微软.Net 平台上的 Ruby 运行环境,都可能会使得 Rails 的部署呈现多元化发展的趋势。Robbin 在文章中对于 JavaEye 站点部署方案的选择做出了如下的总结:

Lighttpd+FastCGI 是性能最佳,服务器资源消耗最少的 RoR 部署方案,事实上目前 RoR 网站部署使用最多最流行的也是 Lighttpd+FastCGI 方式,而 JavaEye 网站,自然也是这种方式的部署。因此我们可以对各种方案进行一个性能优劣的排队,即 Lighttpd+FastCGI 是性能最佳方案,而 Apache+FastCGI 是性能最差方案。

从设计架构上来说,对静态文件的处理应尽量由 Web 服务器前端处理,避免多线程下载对 cpu 和带宽的影响。搭配的方式有很多,方案选择的优劣也不能一概而论,需要根据具体情况做出最合适自身的选择。在 InfoQ 中文站之前的一篇新闻“与时俱进的轻量级Web 服务器”中,也解释了Lighttpd+FastCGI 成为目前Rails 网站优秀部署方案的原因。对于各种选择和经验之谈,毕竟是仁者见仁、智者见智的事情,但无疑,关注小型轻量级服务器的发展,及其自动化部署工具和一站式集成化生产环境,都会给应用的部署上线带来有益的帮助。

关于应用服务器部署的更多信息,可以在InfoQ 中文站的部署应用服务器相关主题,以及 ChinaonRails 服务器架构讨论区中详细了解。

2008-01-15 07:092923
用户头像

发布了 74 篇内容, 共 12.1 次阅读, 收获喜欢 3 次。

关注

评论

发布
暂无评论
发现更多内容

Serverless应用架构转型

阿泽🧸

Serverless 10月月更

Kubernetes的pod

急需上岸的小谢

10月月更

kubernetes的Controller

急需上岸的小谢

10月月更

网络安全之等保2.0测评

网络安全学海

黑客 网络安全 信息安全 渗透测试 等保测评

【一Go到底】第十八天---函数的注意事项

指剑

Go golang 10月月更

cstdio的源码学习分析10-格式化输入输出函数fprintf---宏定义/辅助函数分析05

桑榆

源码刨析 10月月更 C++

从《三体》到Silkpunk,这些中式科幻用什么打动了西方人?

脑极体

Kubernetes的pod调度

急需上岸的小谢

10月月更

【ArchSummit】小红书缓存服务多云建设之路

小明Java问道之路

redis 架构 微服务 云原生 10月月更

搞一搞明白Vitepress的文档渲染基础

小鑫同学

前端 markdown vite markdown-it 10月月更

JS Array数组几个循环实用方法总结

MegaQi

JavaScrip 10月月更

2022-10-17:特殊的二进制序列是具有以下两个性质的二进制序列: 0 的数量与 1 的数量相等。 二进制序列的每一个前缀码中 1 的数量要大于等于 0 的数量。 给定一个特殊的二进制序列 S,以

福大大架构师每日一题

算法 rust 福大大

Jenkins流水线(pipeline)实战之:从部署到体验

程序员欣宸

Java jenkins 10月月更

搭建一套 gocd 的环境

lihui

CI/CD pipeline gocd

K8s Helm 微服务部署利器

CTO技术共享

Kubernetes 个人成长 Helm 10月月更

Kubernetes能否帮助解决自动化

CTO技术共享

Kubernetes 个人成长 10月月更

【愚公系列】2022年10月 Go教学课程 031-结构体方法

愚公搬代码

10月月更

Java多线程 CompletionService和ExecutorCompletionService

Yeats_Liao

后端 多线程 Java core 10月月更

用声网 Android UIKit 为实时视频通话应用添加自定义背景丨声网 SDK 教程

声网

视频 人工智能’ SDK 教程

2022年证券行业818理财节,量变开始转向质变

易观分析

证券 理财节

大数据入门学习框架

Lansonli

大数据 大数据学习框架 学习大数据

始料未及-- 元宇宙传来好消息,全球轰动

CECBC

一起聊服务架构的演进过程

南极仙翁

架构 技术 后端 服务架构

作为码农,如何让35岁璀璨耀眼

南极仙翁

码农 生活随想 35岁危机 35岁焦虑 10月月更

2022年中国小微普惠数字化进程专题分析

易观分析

小微金融

每个系统管理员都应该知道的 6 个 Linux 网络命令

wljslmz

Linux 网络命令 10月月更 系统管理员

分布式协调服务的存在意义

穿过生命散发芬芳

分布式协调 10月月更

【愚公系列】2022年10月 Go教学课程 032-结构体方法继承

愚公搬代码

10月月更

Java多线程 ThreadPoolExecutor自定义线程池

Yeats_Liao

后端 Java core 10月月更

Java多线程 ThreadPoolExecutor-RejectedExecutionHandler拒绝执行策略

Yeats_Liao

后端 Java core 10月月更

你有真正的享受过闲暇吗?

暮春零贰

成长 时间管理 10月月更

关注部署:谈Rails应用的最后一公里_Ruby_高昂_InfoQ精选文章