【AICon】探索八个行业创新案例,教你在教育、金融、医疗、法律等领域实践大模型技术! >>> 了解详情
写点什么

接手了一座年收入 2000 万美元的代码“屎山”,我到底是该重写还是该跳槽?

  • 2022-09-20
    北京
  • 本文字数:2921 字

    阅读完需:约 10 分钟

接手了一座年收入2000万美元的代码“屎山”,我到底是该重写还是该跳槽?

近日 Hacker News上有一则帖子热度非常高,其主题是:我接手了一份极其糟糕的代码和一支技术团队,接下来该怎么办?

 

他给出了一份概述:

 

该代码每年产生超过 2000 万美元的收入。已经在生产环境中直接开发了 12 年,没有源代码控制 (hello index-new_2021-test-john_v2.php)。从未删除任何代码。只是不停添加东西。可能是因为直接在生产环境中开发的,删除东西风险太大。

 

在 PHP 上运行,没有 MVC 或任何其它模式。没有模板库。它是 PHP 2003 样式。JS 和 CSS 也是一片混乱。jQuery 的不同版本互相打架,具体取决于你在哪个页面,有时甚至同一个页面也会有。它不使用 composer 或任何依赖管理,都是 require_once。也不使用任何框架。

 

在许多地方,类似控制器 Controller 的文件,向其自己的 rest API(通过域名,而不是本地主机)发出 curl 请求,进行 oauth 授权等......只是为了获取菜单项或产品列表......

 

路由管理完全是在 Nginx 中重写的(Nginx 配置约为 10,000 行)。数据库结构乱,没有迁移等...添加列时,由于数据量大,他们一般会建一个新表,然后用 join。没有缓存,但有 memcached ,仅用于 Session 会话......

 

贴主还表示他的团队目前只有 3 人,还都相当初级。一个后端,一个前端,一个 iOS/android。生产力非常糟糕,变革的阻力巨大。虽然管理层对该项目制定了非常激进的路线图,但实际上总部对这些阻碍因素没有真正的了解。

 

我们知道代码会随着时间的流逝变得越来越差,而且复杂繁多的应用程序往往牵一发动全身,更改代码存在一定风险,在这种情况下,从头开始重新编写代码看起来是个不错的主意。

 

他本人也认为这种糟糕的代码,完全重写是必要的,但在 COVID 之后,预算真的很紧张,他不知道该如何平衡,所以在 Hacker News 上将问题抛了出来。

 


没想到帖子发出一天多,总共得到了 650 多条建议,很多人有过类似经历,所以其中不乏详实具体的回复,但是也存在一些明显的分歧。

 

建议一:不要考虑重写了,赶紧跑路才是正常的

 

从头开始​​重写是一个坏主意,尤其是在业务做得很好的情况下。

 

如果“此代码每年产生超过 2000 万美元的收入”,那么从商业的角度来看,这里的投资回报率是疯狂的,这份代码简直是一只下金蛋的鸡。

 

就算它很陈旧,对业务人员而言,也是没有任何问题的......因为他们可能认为自己已经建造了一台印钞机,商务人士根本不在乎代码质量,他们在乎价值。如果 2003 风格的 PHP 代码能做到,那就这样吧,忘记重写这回事儿。

 

从他们的角度来看,源代码控制、依赖管理、框架、Nginx 路由等……相对 2000 万美元来说,并不重要,所以很难说服他们。因此,重写不仅是一项技术挑战,更是一项政治挑战。贴主必须同时解决文化问题和技术问题,该过程的每一步都将是一场艰苦的战斗,即使成功了,也可能不会有人注意到,因为应用程序看起来是一样的。只有在市场份额和收入开始下降时,变革的欲望才会出现,届时可能为时已晚。

 

“很多人都在给你技术建议,他们很棒,但现实是除非你在执行层面有权力,或者作为他们信赖的高管来推行重大改变,否则就是在浪费时间。作为中层管理人员或开发人员来执行变革是行不通的,而且会付出巨大的个人成本。而且代码拖成这样,是不重视工程文化的表现,遇到这种情况,如果我还是一位年轻人,可能会留下来并试图成为无名英雄,但现在我年纪大了,我对这种愚蠢行为嗤之以鼻。”作为一名资深开发,swat535 给出了他的建议。

 

不少人对此表示赞成,认为改变环境是困难的,建议再找一份新工作,“如果高层给出的答案含糊不清,或者有什么东西闻起来不对劲,就应该马上跑路。”

 

“他们从 3 个廉价开发者那里获得了 2000 万美元的收入,据公司称,目前进展还顺利,那么他们不会吸取到什么教训。一旦事情搞砸了,负责人肯定会受到指责。我的选择是退出,因为我也曾处于类似的情况。”另一位有同样遭遇的人说道。

 

建议二:不要完全重写

 

也有人认为贴主在假设自己对原始团队和技术非常了解,但事实上新加入的开发人员通常并不知道应用程序为什么会演变成这个样子。

 

“如果不知道为什么,那么就算从头重写,也有可能导致新系统比旧系统更糟糕……”lumost 举例说,“我曾在一家广告技术初创公司工作,当收入达到约 1 亿的时候,公司更换了技术团队。新的技术团队震惊于奇怪的旧技术,于是将代码库重写为 ruby​​ 微服务。为了加速重写/架构迁移,该团队甚至阻止在旧程序上进行投入。不可避免地,生产力直线下降,公司的收入开始下滑。该公司最终对该技术团队再次进行了深度整顿,这个过程实际上花费了他们整个 D 轮融资以及 3 年的产品开发时间。”

 

也就是说不了解整个情况的话,一旦重写失败,沉没成本会相当昂贵。所以,一些网友认为,在有每年 2000 万的收入的条件下,进行完全重写是不应该被考虑的事情。但是贴主可以使用一些严肃的技能,做一些风险系数小的改变:

  • 比如 Fork 分支,小增量的推出更多的功能。如果该领域存在竞争对手,此举能给自己带来市场上的优势。

  • 在尝试做出重大转变之前,可以引入一堆新的实践和模式,进行一些必要的更改。比如不改变代码结构的条件下,利用 git 对代码库,以及每个成员团队的职责进行更高效和更多的控制;对新加代码增加注释;建立分支进行测试;建立 CI/CD 自托管工具;在有测试和 CI/CD 测试数据库迁移....

  • 可以试图解决一些性能和用户体验上的问题,比如利用现代框架重写前端,让管理层和客户兴奋之后,再逐步重构后端(此时,更多的测试覆盖率可能会派上用场)。

 

建议三:如果不能完全重写,那还是赶紧跳槽吧

 

典型的建议是永远不要重写,但也许重写会让问题变得更简单。

 

维护古老的方法和技术对初级开发人员来说是职业生涯倒退,而且如果这份代码是一个企业的收入引擎,那么需要采取保守但果断的行动,否则有可能让当前的情况变得更糟。“只要业务继续运​​作,总会有最重要的事情进来。当添加越来越多的代码时,痛苦只会不断增加。”

 

另一位程序员也分享了自己的经历,“我在一个稍微小一点的团队中遇到了几乎完全相同的情况,并且也是值 500 万美元的 PHP 应用。我们对 Django 进行了完整的重写,花了 2 年时间,经历过难以言喻的政治痛苦,但绝对是正确的选择。遗留代码无法保存,团队中的每个人都同意这一点——这意味着我们没有内部斗争。为了获得支持,我们从非常小的项目开始,将其作为我们一些工程师的‘20% 项目’。在级别设置 auth、CI/CD 和基础设施的东西之后,我们从一个常用的功能开始,将旧的 PHP 页面重定向到新的基于 python 的页面,逐渐用新程序替换掉了旧功能。”

 

“最终,我们有足够的证据表明替换是好的(响应能力大幅提升,升级 UI 对用户十分友好等),我们有幸使这个项目成为一个更大的项目,并极大地降低了成本和复杂性,能够以敏捷的方式为业务提供真正有影响力的东西。随着项目的成功,我们得到了高层领导的体面支持。”

 

“但是,不是所有领导都愿意为此花费大量的政治资本,而且还需要自己团队 100% 的支持和参与。如果达不到这样的条件,你应该辞职,去一个更舒服的地方。简而言之,如果领导层不了解他们处于不可持续的境地,并且不愿意投入时间和金钱来修复它,那么重写或重构的可能性为零。”

 

参考链接:

https://news.ycombinator.com/item?id=32883596

 

2022-09-20 15:0913367

评论 2 条评论

发布
用户头像
你应该使用这款极其趁手的专挖屎山的工具:https://blog.csdn.net/zhao4zhong1/article/details/126596717
2022-09-26 17:00 · 北京
回复
用户头像
to be or not to be
2022-09-23 14:43 · 北京
回复
没有更多了
发现更多内容

一文搞清楚Java中的包、类、接口

不在线第一只蜗牛

Java 前端 开发

秒级弹性!探索弹性调度与虚拟节点如何迅速响应瞬时算力需求?

阿里巴巴云原生

阿里云 云原生 弹性调度

小红书多模态团队建立新「扩散模型」:解码脑电波,高清还原人眼所见

小红书技术REDtech

CV 计算机视觉 脑机接口 扩散模型 AAAI

2023 年度龙蜥最佳用户案例奖揭晓,中国移动、小红书、中国人寿财险等企业上榜!

OpenAnolis小助手

开源 操作系统 用户案例 龙蜥社区 商业版

一个例子形象地理解同步与异步

EquatorCoco

Java 前端 异步 同步

i人事2023:在不确定性的年份做正确的事情

ToB行业头条

元宇宙技术对于虚拟仿真应用的一些帮助

3DCAT实时渲染

虚拟仿真 元宇宙 元宇宙解决方案

实现定时任务的六种策略

不在线第一只蜗牛

前端 定时任务 开发

外贸独立站如何SEO优化推广?

九凌网络

验证邮箱有效性的反向操作

为自己带盐

dotnetcore 邮件通知

Yuliverse:引领区块链游戏新篇章!

Footprint Analytics

区块链游戏 元宇宙 链游 Web3 游戏

SpringBoot3集成Zookeeper

Java 架构 SpringBoot3 Zookeeper3.8 Curator5.5

低代码,让软件开发不再复杂

这我可不懂

软件开发 低代码 JNPF

基于taro搭建小程序多项目框架

EquatorCoco

小程序 taro 前端框架 小程序开发

动态规划-序列比对-最长公共子序列

alexgaoyh

Java 编辑距离 最长公共子序列 Smith-Waterman 序列对比

定向减免!函数计算让 ETL 数据加工更简单

Serverless Devs

容器 云原生 中间件 函数计算 函数计算FC

国内有哪些不错的项目管理系统?深度对比6款

PingCode

项目管理 项目管理软件

二、nextjs API路由如何做好JWT登录鉴权、身份鉴权,joi字段校验,全局处理异常等(c-shopping电商开源)

Geek_9da61c

开源 JWT next.js joi

魔搭+ 函数计算: 一键部署,缩短大模型选型到生产的距离

Serverless Devs

容器 云原生 中间件 函数计算 函数计算FC

惊为天人!这个保存推特视频到手机相册的办法真的一绝!

frank

twitter

基于 pytorch-openpose 实现 “多目标” 人体姿态估计

北桥苏

Python OpenCV PyTorch MediaPipe Pytorch-OpenPose

一种快速开发适配鸿蒙的App思路:基于小程序技术

FinFish

鸿蒙操作系统 小程序容器 小程序技术 鸿蒙Next 鸿蒙5.0

百度智能云千帆AppBuilder新手指南

AI大咚咚

AI API LLM AI原生应用

走出大模型部署新手村!小明这样用魔搭+函数计算

Serverless Devs

容器 中间件 函数计算 函数计算FC

电商平台接口自动化测试框架设计与实现

技术冰糖葫芦

API

杭绍甬高速杭绍段等浙3条高速通车,三思再树标杆工程。

电子信息发烧客

2023 IoTDB Summit:中核武汉核电运行技术股份有限公司主管工程师方华建《IoTDB 在核电数字化转型过程中的应用实践》

Apache IoTDB

高效工作必备神器:这款在线软件能完美替代Visio!

彭宏豪95

在线白板 办公软件 绘图工具 效率软件 Visio

聚道云连接器:实现航信费控与用友NCC对接,助力某商贸集团业务升级

聚道云软件连接器

案例分享

如果查看iPhone的GPU

雪奈椰子

接手了一座年收入2000万美元的代码“屎山”,我到底是该重写还是该跳槽?_语言 & 开发_Tina_InfoQ精选文章