写点什么

Ruby on Rails 项目的救赎

  • 2009-07-12
  • 本文字数:1985 字

    阅读完需:约 7 分钟

Ruby on Rails 发布已有五年,在此期间,开发者编写了大量的应用。其中很多应用程序都是开发者们在学习 Ruby 和 Rails 的过程中写就的,代码质量堪虞,却已经运行于生产环境之中。

这些 Web 应用程序的规模数年来不断猛增,由于代码行数不断增加,它们已经变得臃肿,难以维护。这是很多开发者们不得不面对的情况。而且,他们几乎不知道从何下手。

一本新近出版的书能够帮助开发者解决这类问题,这本书叫做 Rails 拯救手册,由 Mike Gunderloy 编写。这本书也同时以 PDF 的形式发布,购买的用户可以终身收到最新版。InfoQ 获得了一个和 Mike 直接对话的机会,试图了解到这本书的核心思想。

Mike 介绍他的新书时说:

Rails 拯救手册是我心血的结晶,当你面对一个乱糟糟的 Rails 应用程序,并且希望把它进行重构(或是仅仅使它能够工作),它能够一步一步指导你如何 去做。这本书介绍了一些简单 Rails 应用程序的共同问题点,并且在战略和战术级别上对如何重构,以及回到高效开发上给出了建议。

这本书面向的读者不是 Ruby on Rails 的新手。Mike 解释了本书的读者群:

本书面向的是正在和陈旧的 Rails 应用程序搏斗,并且需要帮助的开发者。在大部分情况下;一个项目会有第二个开发 者,他会在第一个开发者不能发布可运行代码的时候被加入到这个项目中。有些时候,甚至不会有第二个开发者:一旦你意识到你可能会有问题(或者,很多问 题),没有人能够阻止你重构你的项目。

修正代码问题的关键一环便是知道问题在哪,有些非常明显,但是有些就不是。关于这个问题:

表面上说,Rails 项目中发现问题的数量和客户需求无关。我看到过这些问题是以两种形式。开发者不能够按时发布能 够工作的代码,或者发布的新特性破坏了程序的其他部分。当然,后者是最常见的问题之一:缺乏足够的高质量测试覆盖。当你获得源代码的时候,经常可以在这些 地方发现问题:由于缺乏对数据库层的考虑,不可思议的臃肿的控制器以及充满了 SQL 语句的视图等等导致了低下的性能。

一旦这些问题被找出,那么需要一个结构化的方法来修正它们。Mike 给出了一个开放的结构化的方法:

首先,你需要了解客户的需求,明白哪些修改是必须的。客户需要了解到当开发者试图使程序稳定的时期内,应用程序可能会很少甚至没有新特性。这个过程的一个 关键点在于设置良好的沟通渠道,及时通知客户——经常你需要处理一些不可思议的遗留问题,但是不会满足客户的需求。透明是这个过程中的口号。

在你确认你已经获得了能够继续进行的足够多的支持之后,下一步就是对现存代码做一些巨大的改动(假设这些都不是你写的)。检查 Rails 的版本,将一份拷 贝放到你的桌面(如果可以的话),检查一下路由器以及模型、控制器和视图。仔细查找问题点。通常客户将会知道性能和功能问题出在哪儿;仔细听他们说。

当你已经知道代码中的问题之后,那么着手重构它们。通常重构之后需要进行测试。你需要确认问题已经走上正轨,而且开发过程处于掌控之中。

我们然后讨论了通过选择一些容易完成的目标来达到快速制胜:

书中有一些秘诀,能够轻松为客户带来益处(也能够帮助他们成为反馈式的开发者)。例如,花费在理解数据模型和寻找模式的时间能够帮助你寻找到如何得到本质的性能提升。

也有一些地方需要注意,他介绍了一些入手点:

此外如果需要关注数据库层(尤其是在开发者的第一个或者第二个 Rails 项目),通过运行 Google Page Speed 类似的工具能够知道那些地方存在性能瓶颈(性能问题是客户最关心的问题之一)。在一个公共站点,确保有一些异常通知来告诉你哪些东西失败了,是 另外一个能够知道代码的哪些部分需要特别关注的方法。

当被问道他在 Ruby 社区的背景以及他如何意识到这些常见问题的类型的时候,Mike 指出他多年的咨询经验以及学习帮助了他:

在过去两年中,我已经帮助了大量的项目转到正轨来,但是为了客户的信心,我不能透露他们的名字。我也曾经在做 Action Rails 的 时候,做过一些代码检查。这些项目有些只是一些简单站点,基于 10 个左右模型,但是这些模型缺少了一些基本的 Rails 功能,例如模型关联(因此编写了太 多自定义代码),有些却是大型应用程序,已经被部署用作主要的功能实现,但是却被 Bug 缠身。我花费了很多时间在客户的项目以及转包合同,而不是在产品或 者临时工作中,这些并没有给我太多机会来审视它们为什么失败。

更多信息可以在 Rails 拯救手册的官方站点上找到。

Mike Gunderloy 在多种语言和平台上有着二十年的开发经验。从 2006 年开始,他全职转向 Rails 工作,对于和各种规模的分布式敏捷团队的协作,以及 和各类项目参与人员(从开发者到项目经理)的合作有着丰富的经验。他对 core Rails 也是贡献良多,还是 Rails 文档团队的成员。此外,在他在 Lark 集团的本职咨询工作中,是一位在高端 Rails 咨询领域的合伙人,同时也是 RailsBridge 的创始人之一。

查看英文原文: Rescuing Your Ruby on Rails Projects

2009-07-12 12:402849
用户头像

发布了 90 篇内容, 共 34.4 次阅读, 收获喜欢 5 次。

关注

评论

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

报名倒计时 2 天!龙蜥社区系统安全 Meetup 演讲亮点一览

OpenAnolis小助手

操作系统 系统安全 浪潮信息 龙蜥meetup

低代码用得好,开发真的很顺手

伤感汤姆布利柏

广东人仁康一项技术通过国家科技成果评价达到国际先进水平平

Geek_2d6073

ApsaraMQ Copilot for RocketMQ:消息数据集成链路的健康管家

阿里巴巴云原生

阿里云 RocketMQ 云原生

被黑客入侵的 DMM 比特币为比特币购买获得 3.2 亿美元

区块链开发团队DappNetWork

SD-WAN实现企业出海网络加速

Ogcloud

SD-WAN 企业组网 SD-WAN组网 SD-WAN服务商 SDWAN

低代码开发赋能教育数字化及典型场景

不在线第一只蜗牛

低代码 教育新创

数据驱动的未来:数据融合与平台化应用的探索

快乐非自愿限量之名

低代码 数据驱动 平台化

GitHub爆火标星127k!这份字节Python背记手册到底有什么魔力?

没脾气

Python 程序员 自学编程 python教程 python自学

惊了!字节大佬总结的这份《零基础学python神级笔记全彩版》真的太强了

没脾气

Python 程序员 自学编程 架构师 自学python

一台桌面工作站的智慧之光,照见宁畅“全局智算”版图

脑极体

AI

天谋科技与腾讯云完成兼容性互认证

Apache IoTDB

Altair RapidMiner,将数据科学、深度学习等多种功能同时集成的一站式数据分析平台

Altair RapidMiner

机器学习 大模型 #人工智能 #数据分析

开发体育赛事直播平台源码:具备全面的体育数据资料库

软件开发-梦幻运营部

【YashanDB知识库】outline固化执行计划

YashanDB

yashandb 崖山数据库

运营海外社媒平台的最佳工具:云手机

Ogcloud

云手机 海外云手机 云手机海外版 国外云手机 海外云手机推荐

PingCAP 与沙利文联合发布《中国企业全球化运营白皮书》

先锋IT

业务转型,你的团队该如何应对?

凌晞

团队管理 数字化业务转型IT路线图

案例研究|为什么 CDG 会选择从 DataDog 迁移至观测云?

观测云

可观测性

Mint Blockchain 成立 Mint Eco Fund 发展基金,并启动 Season1 开发者活动 NFT Summer!

NFT Research

NFT Layer 2

Netty FastThreadLocal实践

FunTester

计算机英文教材太难啃?Higress 和通义千问帮你!

阿里巴巴云原生

阿里云 云原生 Higress

天润融通,荣获2024中国AI应用层创新企业

天润融通

人工智能 天润融通

深入解读Prometheus Adapter:云原生监控的核心组件

快乐非自愿限量之名

微服务 云原生 容器化

iLogtail 2.0 重大升级,端上支持 SPL

阿里巴巴云原生

阿里云 云原生 日志服务 sls

龙蜥社区 5 月度运营大事件回顾

OpenAnolis小助手

开源 操作系统 龙蜥社区 月报

SMC-R 透明加速 TCP 技术,在 Redis 场景下的应用实践 | 干货推荐

OpenAnolis小助手

操作系统 龙蜥社区 SMC-R 浪潮信息 TCP 技术

6 大亮点!全新 Anolis OS 23.1 GA 版正式发布,满足多样化平台支持

OpenAnolis小助手

操作系统 国产操作系统 龙蜥操作系统 Anolis OS Anolis OS 23.1

从仿真到生成式仿真,大模型助力工业智能化发展

Altair RapidMiner

#人工智能 仿真技术 制造业数字化 #大模型

小游戏应该如何创建一个元服务项目

FN0

鸿蒙卡片 元服务

Ruby on Rails项目的救赎_Ruby_Robert Bazinet_InfoQ精选文章