【AICon】AI 基础设施、LLM运维、大模型训练与推理,一场会议,全方位涵盖! >>> 了解详情
写点什么

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

  • Tina

  • 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:0913370
语言 & 开发 研发效能 软件工程 最佳实践 性能优化 编程语言 框架

评论 2 条评论

发布
用户头像
zhao4zhong1
你应该使用这款极其趁手的专挖屎山的工具: https://blog.csdn.net/zhao4zhong1/article/details/126596717
2022-09-26 17:00 · 北京
回复
用户头像
孙亚东。
to be or not to be
2022-09-23 14:43 · 北京
回复
没有更多了
  • 小团队中微服务的可怕之处

    保证在适当的时候选择合适的架构并且保持简单。关注代码架构和质量。

    架构 产品 软件工程 最佳实践 技术选型 微服务 领域驱动设计 企业动态
  • 开篇词|为什么要选择 React Native 做你的跨端方案?

    可以预见,React Native 新架构将会给我们带来巨大惊喜。

    2022-03-28

  • 我见过的最糟糕代码

    本文介绍了作者见过的最糟糕的代码

    语言 & 开发 文化 & 方法 其他 方法论
  • 敏捷为何在企业中鲜有成效?

    不管怎样,我也是没有银弹的。

    文化 & 方法 研发效能 Scrum 编程语言 框架 数字人才培养 团队搭建 汽车 行业深度
  • PHP“垂死”十年

    对于一门古老的语言来说,支撑未来技术的东西不是与时俱进吗?

    语言 & 开发 大前端 编程语言 方法论 最佳实践 架构/框架 性能优化 框架 实时计算 银行 保险 企业动态
  • 走过二十年的软件测试业

    XML之父:不对代码做测试就像“上完厕所不洗手”

    语言 & 开发 软件工程 研发效能 最佳实践 方法论 性能优化 编程语言 框架 企业动态
  • 工作流设计:如何设计合理的多人开发模式?

    今天我们来聊聊如何设计合理的开发模式,我会为你介绍4种受欢迎的工作流,你可以选择其中一种作为你的工作流设计。

    2021-06-08

  • 当“增加人员”不足以解决问题,你就该考虑应用“微前端”了

    本文最初发表于ITNEXT的博客站点,经原作者[Manu Ustenko授权由InfoQ中文站翻译分享。

    大前端 语言 & 开发 企业动态 方法论 架构/框架 编程语言 框架 汽车
  • 蚂蚁内部开源:迈出第一步,但还有很长路要走

    第一阶段是源码开放,第二个阶段是社区讨论,第三阶段是产品视角。内源很容易卡在第二步,因为第二步有很核心的点,是要有足够的人参与进来。

    2022-10-25

  • GitHub 前 CTO:全面微服务是最大的架构错误!网友:这不是刚改完 GitHub 吗

    单体>应用程序>服务>微服务?

    语言 & 开发 文化 & 方法 架构 方法论 技术选型 编程语言 框架 企业动态
  • 结束语 | 不盲从于群体思维,走一条适合自己的路

    希望你不仅成为一个具有很强技术能力的人,同时还能真正走出一条适合自己的路,成为人生赢家。

    2021-05-25

  • 个性化测试流程,不搞一刀切

    每个团队都是不一样的,为什么采用的流程要一样呢?

    文化 & 方法 软件工程 最佳实践 社区 研发效能 方法论 框架 汽车 医疗
  • 不要让框架影响你最初的架构设计

    在真正需要之前,不要对任何特定的框架、模式或策略过多投入。

    架构 文化 & 方法 方法论 最佳实践 性能优化 编程语言 框架 亚马逊云科技 银行 保险 企业动态 行业深度
  • 32 条关于软件开发的建议和教训

    近几年来,我一直为大大小小的客户开发专业软件。这些软件中有一些是在非常严格的环境下使用的,安全性和可靠性是最重要的。

    语言 & 开发 文化 & 方法 研发效能 银行
  • 谷歌工作十年,我总结了这些工程师必备软技能

    谷歌浏览器的一位高级工程经理,分享了他在谷歌工作十年时间里学到的一些软技能,下文为部分经验摘录。 

    语言 & 开发 文化 & 方法 架构 技术管理 软件工程 Chrome 方法论 最佳实践 架构/框架 性能优化 编程语言 框架
  • 开源三大收获:异步协同、文档优先与快乐工作

    那时候我天天盼着下班,我白天疯狂地在项目室闭关,回到家里,快速吃个饭,就又开始疯狂地参与开源。印象中我每天晚上都干到凌晨两三点,很开心,很兴奋,好像不觉得累

    2022-10-25

  • 误泄露公司代码、疫情期间被裁,一个“菜鸟”程序员的生存日记

    “我是如何从每一次失败中成长起来的。”

    文化 & 方法 软件工程 语言 & 开发 方法论 编程语言 微服务 团队搭建
  • 30 万行代码的平台升级:给跑着的汽车换轮胎

    这个项目的成本是:3.5年的开发时间,每行代码只需要2美元。

    架构 开源 软件工程 数据库 编程语言 Linux Python 中间件 框架 汽车
  • 02|小厂创业:做出一个产品,卖给所有人

    写程序其实没什么难的,就是工程,是个抽象问题

    2022-09-28

  • Sentry 的前端测试实践:从 Enzyme 迁移到 RTL

    如何在测试前端代码时避免一些常见的陷阱和错误。

    大前端 软件工程 语言 & 开发 架构/框架 性能优化 编程语言 汽车
发现更多内容

AlDente Pro激活码 v1.24 Macbook充电限制软件

Rose

AlDente Pro破解版 AlDente 激活码 Macbook充电限制软件

宣布全面推出适用于 macOS 的 Amazon EC2 M2 Pro Mac 实例

亚马逊云科技 (Amazon Web Services)

Amazon EC2 ELB ebs Amazon VPC Nitro 第五代系统

GTD任务管理器:Chaos Control 免激活最新版

mac大玩家j

Mac软件 任务管理器

2023年11月文章一览

codists

Axure RP 10中文授权版下载

Rose

原型设计 Axure RP 10 汉化版 Axure RP 10 下载 Axure RP 10授权

如何在 Parallels Desktop for Mac 中备份、恢复或转移 Windows 虚拟机

Rose

Mac虚拟机下载 Parallels Desktop 19 Pd虚拟机破解版下载 Parallels 永久密钥

概念回顾:QUIC 和 HTTP/3

NGINX开源社区

TLS udp 数据流 QUIC HTTP/3

Windows、Linux 和 Mac:操作系统之间的比较

小魏写代码

4K Image Compressor Pro fo mac(高效图像压缩器) 1.2.0永久激活版

mac

苹果mac Windows软件 图片压缩软件 4K Image Compressor Pro

达芬奇DaVinci Resolve Studio 18:视频后期处理的全能神器

Rose

达芬奇18破解版 DaVinci Resolve Studio 达芬奇调色软件 DaVinci18密钥

beyondcompare4永久激活密钥 及Beyond Compare 4破解方法

Rose

mac软件下载 文件同步对比工具 Beyond Compare 4 注册版 Beyond Compare密钥

【亲测有效】Sketch for mac v99.1中文一键安装破解版

Rose

mac软件下载 矢量绘图设计 Sketch 99 Sketch中文破解

把大模型当CPU,前阿里云首席安全科学家创业项目曝光

Openlab_cosmoplat

对大模型和AI的认识与思考

AIWeker

AI 总结 大模型 AIGC GPT

JVM 小科普:Java 程序背后的老大哥

Java 工程师蔡姬

Java 程序员 JVM 21 天技术人写作行动营

FxFactory 8 Pro:打造专业视觉效果的利器

Rose

视频特效插件 FxFactory 8 pro

软件测试/测试开发丨人工智能在软件测试领域的成就

测试人

人工智能 软件测试

高效图像压缩器 4K Image Compressor Pro激活中文版

胖墩儿不胖y

压缩图片 图片压缩器 图片管理工具

32 | 字符串匹配基础(上):如何借助哈希算法实现高效字符串匹配

鲁米

Navicat Premium 15永久激活教程 Mac/win 数据库管理软件

Rose

数据库管理工具 Navicat Premium破解版 Navicat Premium 15中文版 Navicat 数据库下载

Waves 14混音效果全套插件 附Waves mac破解补丁

Rose

Waves 14破解教程 Waves 14 最新版 Waves 14 Complete破解 后期混音

拆解全景,解锁未来——深度分析大模型六大领域及五大应用解决方案

SEAL安全

人工智能 AI LLM LLM模型

以太坊 NFT 市场激增:为什么要在 2024 年推出 NFT 市场?

区块链软件开发推广运营

dapp开发 区块链开发 链游开发 NFT开发 公链开发

极狐GitLab CI/CD 变量黑魔法之自定义变量

极狐GitLab

DevOps gitlab 变量 CI/CD gitlab ci

长安汽车金融:借助一体化智能可观测平台 Bonree ONE,提升智能告警收敛能力

博睿数据

解码大语言模型奥秘:《大规模语言模型:从理论到实践》震撼上市!

博文视点Broadview

开发案例:使用canvas实现图表系列之折线图

HarmonyOS开发者

HarmonyOS

33 | 字符串匹配基础(中 ,下):如何实现文本编辑器中的查找功能

鲁米

聊点写作配图那点破事儿

6点无痛早起学习的和尚

写作 21 天技术人写作行动营

sublime text 中文破解版 附sublimetext注册码 Mac/win 文本代码编辑器

Rose

代码编辑器 mac软件下载 Sublime Text 4 破解版 Sublime Text注册码

NFTScan 获得比特丛林 (BitJungle) 公司战略投资

NFT Research

NFT NFTScan

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

天下网标王惠州百度竞价包年推广价格张家界优化保山网站优化按天收费公司宜春百度竞价包年推广哪家好内江百度竞价包年推广哪家好惠州SEO按天扣费多少钱延安阿里店铺托管十堰优秀网站设计多少钱烟台企业网站改版公司金昌网站推广系统多少钱烟台SEO按天扣费多少钱池州SEO按效果付费咸宁网站开发报价玉林模板制作多少钱郴州推广网站推荐龙岗品牌网站设计报价包头网站定制推荐鸡西网站关键词优化价格清徐网站优化排名报价沙井优秀网站设计丹东阿里店铺运营报价石岩网页制作报价朔州网站推广系统公司石岩网络推广公司衡阳关键词排名包年推广价格清远网站改版报价西宁网站推广推荐南京网站推广方案价格甘孜模板网站建设怒江关键词按天收费公司香港通过《维护国家安全条例》两大学生合买彩票中奖一人不认账让美丽中国“从细节出发”19岁小伙救下5人后溺亡 多方发声卫健委通报少年有偿捐血浆16次猝死汪小菲曝离婚始末何赛飞追着代拍打雅江山火三名扑火人员牺牲系谣言男子被猫抓伤后确诊“猫抓病”周杰伦一审败诉网易中国拥有亿元资产的家庭达13.3万户315晚会后胖东来又人满为患了高校汽车撞人致3死16伤 司机系学生张家界的山上“长”满了韩国人?张立群任西安交通大学校长手机成瘾是影响睡眠质量重要因素网友洛杉矶偶遇贾玲“重生之我在北大当嫡校长”单亲妈妈陷入热恋 14岁儿子报警倪萍分享减重40斤方法杨倩无缘巴黎奥运考生莫言也上北大硕士复试名单了许家印被限制高消费奥巴马现身唐宁街 黑色着装引猜测专访95后高颜值猪保姆男孩8年未见母亲被告知被遗忘七年后宇文玥被薅头发捞上岸郑州一火锅店爆改成麻辣烫店西双版纳热带植物园回应蜉蝣大爆发沉迷短剧的人就像掉进了杀猪盘当地回应沈阳致3死车祸车主疑毒驾开除党籍5年后 原水城县长再被查凯特王妃现身!外出购物视频曝光初中生遭15人围殴自卫刺伤3人判无罪事业单位女子向同事水杯投不明物质男子被流浪猫绊倒 投喂者赔24万外国人感慨凌晨的中国很安全路边卖淀粉肠阿姨主动出示声明书胖东来员工每周单休无小长假王树国卸任西安交大校长 师生送别小米汽车超级工厂正式揭幕黑马情侣提车了妈妈回应孩子在校撞护栏坠楼校方回应护栏损坏小学生课间坠楼房客欠租失踪 房东直发愁专家建议不必谈骨泥色变老人退休金被冒领16年 金额超20万西藏招商引资投资者子女可当地高考特朗普无法缴纳4.54亿美元罚金浙江一高校内汽车冲撞行人 多人受伤

天下网标王 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化