第48章 暗流下的技术对决

1

第十三天,凌晨四点。

星河科技大厦二十八层的灯光还亮着三分之一。“星语”项目区的白板上,倒计时数字已经从“30”变成了“17”,鲜红的墨水在白炽灯下有些刺眼。

林辰站在监控大屏前,眼睛里布满了血丝。

屏幕上显示着过去二十四小时的系统告警统计:

接口超时告警:127次

服务异常重启:43次

数据库慢查询:89次

内存泄漏告警:12次

比昨天上升了30%。

比上周同期上升了150%。

“林总,这样下去不行。”王海清端着一杯浓得像中药的咖啡走过来,声音沙哑,“重构进入深水区,我们动的是最核心的支付链路和订单状态机。每次发布,都像在血管上动手术,稍微出点差错,整个系统就崩了。”

林辰没说话,手指在触摸板上滑动,调出过去七十二小时的发布记录。十七次生产环境发布,成功了九次,失败了八次。失败的原因五花八门:数据不一致、配置错误、依赖冲突、甚至有一次是因为某个第三方服务的证书突然过期。

每一次失败,都意味着一次线上事故。轻则部分功能不可用,重则订单丢失、支付失败、客户投诉。

而每一次事故,都在消耗团队的信心,也在消耗李铭的耐心。

“陈明远那边有什么动静?”林辰问。

“他这几天很安静。”王海清压低声音,“但我听财务部的小王说,陈明远昨天找了李总,说项目进度太慢,开销太大,建议……建议暂停重构,先稳住线上。”

“李总怎么说?”

“李总没表态,只说再看看。”王海清顿了顿,“但我觉得,李总也在犹豫。毕竟连续出了几次事故,客户那边已经有怨言了。昨天下午,百盛集团的技术总监直接打电话到李总办公室,问我们的系统到底什么时候能稳定。”

百盛集团,星河科技最大的客户,年合同额八百万。

林辰闭上眼睛,深吸一口气。

压力像实质的水泥,一层层糊在胸口。他能感觉到团队的状态在滑坡——连续十三天的高强度工作,每天只睡四五个小时,还要承受频繁的线上事故和客户压力。昨天一天,有三个核心开发提出了离职意向,虽然被暂时安抚下来,但人心已经浮动。

“林总,要不……”王海清犹豫着说,“要不我们放缓一点?先把最紧急的几个问题解决了,剩下的慢慢来?三十天的期限,实在不行,可以跟李总申请延期……”

“不能延期。”林辰睁开眼,眼神锐利,“延期一次,就会有第二次。而且陈明远就等着我们延期,一旦开了这个口子,他会立刻把项目搅黄。”

“可再这样硬撑,我怕团队先垮了。”

“我知道。”林辰转身,看向办公区。凌晨四点的灯光下,还能看到十几个没睡的身影,有人趴在桌上小憩,有人盯着屏幕发呆,有人在走廊里来回踱步——那是焦虑的表现。

他走回自己的工位,打开电脑。系统界面在视野中展开,只有他能看到的淡金色数据流缓缓流动。

“系统,评估当前项目状态,给出最优解。”

【收到。启动AI超脑深度分析……】

【数据采集:项目进度、团队状态、技术风险、外部压力……】

【分析中……】

三秒钟后,报告生成:

【项目诊断报告】

【综合评级:C+(中**险)】

【核心问题:】

【1. 团队疲劳度已达临界点(平均疲劳值87/100),继续高压将导致大规模离职或效率暴跌。】

【2. 技术债务清理进入最复杂模块(支付、订单),每个改动都可能引发连锁反应。】

【3. 外部压力持续加大(客户投诉、管理层质疑、竞争对手虎视眈眈)。】

【4. 时间窗口仅剩17天,但剩余工作量至少需要25天。】

【最优解(概率72.3%):】

【A. 技术侧:启用AI架构设计(中级)技能,对剩余模块进行“手术刀式”精准重构,避免大动干戈。】

【B. 管理侧:启动“极限冲刺”模式,但配套“强制轮休”制度,保障核心人员最低休息时间。】

【C. 公关侧:主动联系关键客户,提前沟通风险,争取理解和支持。】

【D. 斗争侧:反击陈明远,转移矛盾焦点。】

【执行此方案,项目成功概率可提升至65.8%。】

林辰快速浏览完报告。

四个方向,都要做。但最紧急的,是技术侧——必须找到一种更安全、更高效的方式,完成剩下的重构。

“启用AI架构设计(中级)技能。”他在脑海中下令。

【收到。技能启用中……】

【正在扫描“星语”系统剩余模块架构……】

【识别可优化点……生成重构方案……】

一瞬间,大量架构知识和设计模式涌入脑海。不是生硬的灌输,而是与林辰已有的经验融合,形成了一种全新的、高维的视角。他再看“星语”的代码,就像外科医生在看X光片,哪些地方是肿瘤必须切除,哪些地方可以微创,哪些地方暂时不能动,一目了然。

更重要的是,系统还提供了“并行重构”的方案——将最复杂的支付链路拆解成七个独立的小模块,每个模块可以由不同的小组并行开发,最后再无缝集成。这样可以将原本需要十五天的工期,压缩到七天。

但风险在于,模块之间的接口设计必须绝对精确,任何一个参数定义错误,都会导致集成失败。

“系统,生成支付链路拆解方案,包括接口定义文档、测试用例、集成 checklist。”

【收到。方案生成中……预计耗时5分钟。】

林辰站起身,拍了拍手。办公区里还醒着的人都抬起头。

“所有人,五分钟后来会议室。紧急会议。”

2

凌晨四点半,小会议室里挤了二十多人。核心架构师、各小组长、还有几个技术骨干。很多人睡眼惺忪,端着咖啡强打精神。

“长话短说。”林辰站在白板前,马克笔在手中转了个圈,“我们遇到了瓶颈。按现在的进度,三十天肯定完不成。而且团队已经到极限了,再压要出事。”

没人说话,但很多人低下头——这话说到了他们心里。

“所以我们要换打法。”林辰在白板上画了一个大大的支付链路架构图,然后“啪”地一声,用红笔在中间划了七道竖线,将整个链路切成了七个方块。

“从今天起,支付链路重构,不再是一个大项目,而是七个独立的小项目。”他指着那些方块,“每个方块,一个小组负责,组长自己定计划,自己控制进度。七天后,我们在这里集成。”

会议室里响起吸气声。

“林总,这太冒险了。”负责支付服务的架构师老赵第一个反对,“支付链路是系统最核心的部分,业务逻辑极其复杂,拆成七块,接口定义稍微有点偏差,集成的时候就是灾难。而且七个小组并行,沟通成本会爆炸。”

“所以才需要精确的接口定义。”林辰从电脑里调出一份文档,投到幕布上,“这是我刚写的《支付链路模块化设计规范》,总共四十七页,定义了所有模块的输入输出、错误码、状态流转、幂等性要求。每个小组必须严格按这个规范来,偏差率不能超过1%。”

文档在屏幕上滚动。老赵凑近看,眼睛越瞪越大。文档详细得可怕,不仅定义了接口,还给出了各种边界情况的处理示例,甚至连并发场景下的数据一致性问题都考虑到了。

“这……这是你刚写的?”老赵不敢相信。

“嗯。”林辰面不改色地撒谎——总不能说是系统五分钟生成的,“所以技术风险可控。至于沟通成本……”

他看向会议室里的七个组长。

“从今天起,每天早上七点、晚上七点,我们开两次十分钟的站会,只同步三件事:进展、问题、需要什么支持。所有技术讨论,必须在专门的聊天群里进行,禁止私聊。重要决策,必须有文字记录,@我确认。”

“那测试呢?”测试组长陈静问,“七个模块并行开发,测试怎么跟?”

“每个模块自己负责单元测试和接口测试,测试用例我已经写在规范里了。”林辰说,“集成测试由测试组统一做,但必须等所有模块开发完成才能开始。所以,你们的进度必须严格对齐,任何一个模块延迟,所有人陪绑。”

这话很重,七个组长脸色都严肃起来。

“最后,关于休息。”林辰顿了顿,“从今天起,实行强制轮休。每个人每周必须保证至少两天的完整睡眠——不是在公司行军床上眯一会儿,是回家,躺床上,睡足六小时。轮休表已经排好了,一会儿发给大家。谁要是违反,扣奖金。”

会议室里安静了几秒,然后响起低低的议论声。

“林总,真要轮休?时间本来就不够……”有人小声说。

“就是时间不够,才更要休息。”林辰看着他们,“人不是机器,连续运转会报废。我要的是一支能打满三十天的队伍,不是一群撑到二十天就全倒下的残兵。这是命令,不是商量。”

他说得很坚决。

会议室里渐渐安静下来。很多人看着林辰,眼神复杂——有怀疑,有担忧,但也有一丝……感激。连续十三天的高压,每个人都在硬撑,林辰是第一个说出“该休息了”的人。

“还有什么问题?”林辰问。

“有。”老赵举起手,“如果……我是说如果,七天后集成失败了,怎么办?”

“那就重来。”林辰平静地说,“但我不允许失败。因为失败意味着,我们过去十三天的努力,白费了。意味着陈明远会拿着这个结果,去找李总,要求停止重构。意味着在座的各位,可能有人要丢工作。”

他扫视全场。

“所以,没有如果。必须成。散会。”

人群散去。林辰独自站在会议室里,看着白板上那七道红笔划出的分割线。

很冒险。

但如果成了,就是一场漂亮的歼灭战。

他拿出手机,给苏雨晴发了条微信:“今晚我回家睡,大概六点到家。不用等我吃饭,给我留口汤就行。”

三秒钟后,苏雨晴回复:“好。我炖了鸡汤,给你热着。”

很简单的对话,但林辰看着屏幕,嘴角微微扬起。

然后他收起手机,走出会议室。

战争还在继续。

但至少今晚,他能回家,喝一口热汤,睡一个整觉。

这就够了。

3

上午十点,林辰走进李铭的办公室。

CEO办公室在顶层,整面落地窗,视野极好。李铭坐在办公桌后,正在看一份报表,听到敲门声抬起头。

“林辰,坐。”他指了指对面的椅子。

林辰坐下。办公室里有淡淡的檀香味,角落的加湿器喷出细密的水雾。很安静,安静得能听见自己的心跳。

“百盛集团那边,我已经安抚好了。”李铭放下报表,双手交叉放在桌面上,“但他们的耐心有限。最多再给一周,如果系统稳定性还不能明显改善,他们就要启动备用方案——把部分业务切到云图科技的系统上。”

云图科技,星河科技最大的竞争对手,CEO陈伟是林辰的大学同学,也是宿敌。

“我明白。”林辰说,“一周内,支付链路重构完成,系统稳定性会有质的提升。”

“你确定?”李铭看着他,“我听说,你昨晚调整了策略,把支付链路拆成了七个模块并行开发。这很冒险,林辰。”

消息很灵通。林辰心里清楚,是陈明远汇报的。

“是冒险,但也是唯一能在期限内完成的办法。”林辰没有否认,“常规做法需要二十五天,我们只有十七天。必须用非常规手段。”

“那如果失败了呢?”

“失败了我负责。”林辰说,“但我需要您再给我一周的时间,不要受任何干扰。特别是……陈总那边。”

他说的很直接。

李铭沉默了一会儿,然后笑了:“林辰,你知道我最欣赏你什么吗?”

“什么?”

“你敢赌,也敢担。”李铭站起身,走到窗边,背对着林辰,“陈明远跟我十年了,是公司元老。他做事稳妥,但缺乏魄力。你正好相反,有魄力,但太激进。你们俩,一个像刹车,一个像油门。”

他转过身,看着林辰。

“一个企业,既需要油门,也需要刹车。但什么时候踩油门,什么时候踩刹车,得看路况。现在这条路,前面是悬崖,但后面是追兵。慢下来是死,冲太快也可能死。这个分寸,很难拿捏。”

“所以您把决定权交给了我。”林辰说。

“是。”李铭点头,“但我必须看到进展。一周,林辰。一周后,我要看到支付链路的重构成果,看到系统稳定性的数据提升。如果看不到……”

他没说完,但意思很明白。

“明白。”林辰起身,“一周后,给您结果。”

他转身离开,手碰到门把时,李铭的声音从身后传来:

“林辰。”

“嗯?”

“保重身体。你眼里的血丝,隔着三米都能看见。”

林辰顿了顿,没回头:“谢谢李总。”

门开了又关。

李铭重新坐回办公椅,手指在桌面上轻轻敲击。半晌,他拿起内线电话:“小张,让陈副总来一趟。”

4

下午两点,林辰接到一个陌生电话。

号码归属地显示江州,但没存名字。他犹豫了一下,接起。

“喂,是林辰林总吗?”电话那头是个中年男声,语气客气但透着疏离。

“我是,您哪位?”

“我是百盛集团技术部的王磊,我们刘总让我跟您联系一下,关于系统对接的一些细节……”

林辰心里一紧。百盛的技术总监亲自打电话,绝不是“细节”这么简单。

“王总监您说。”

“是这样,我们这边最近在做系统稳定性评估,发现从贵司‘星语’系统同步过来的订单数据,有千分之三左右的丢失率。虽然比例不高,但涉及资金流,我们比较重视。想跟您确认一下,这个问题什么时候能解决?”

千分之三的丢失率。

林辰脑子飞快运转。他记得上周的监控报告里,订单同步的成功率是99.98%,丢失率只有万分之二。这才几天,怎么就上升到千分之三了?

“王总监,这个数据是最近才出现的吗?”

“就这三五天。之前还好,最近突然升高。我们的监控显示,大部分丢失集中在晚上十点到凌晨两点,也就是你们的发版窗口期。”

发版窗口期。

林辰明白了。这是重构过程中,频繁发布导致的数据不一致。虽然每次事故后都有数据补偿机制,但有些极端情况,补偿也会失败。

“这个问题我们已经在处理了。”林辰尽量让声音平稳,“最近我们正在做系统重构,有些临时性的波动。预计一周内,等重构完成,数据同步的稳定性会有质的提升。”

“一周……”王磊在电话那头沉吟,“林总,不是我不相信您。但我们这边压力也很大。财务部门已经投诉好几次了,说对账对不上。刘总的意思,如果三天内看不到明显改善,我们可能要考虑……临时切换一部分流量到备用系统。”

三天。

比李铭给的一周,还少了四天。

“王总监,三天太紧了。重构是个系统工程,就像做手术,不能做到一半就缝合。”林辰试图争取时间。

“我理解,但我也有我的难处。”王磊语气强硬了些,“这样吧,林总。我也不为难您。三天,您给我们一个详细的问题分析报告和解决时间表。如果能让我们看到明确的路径,我们可以再等等。如果看不到……”

他没说完,但威胁的意味很明显。

“……好,三天。”林辰咬牙,“三天后,我把报告给您。”

“那期待您的报告。再见。”

电话挂了。

林辰放下手机,手心有些出汗。百盛是星河科技最大的客户,如果丢了,不止是八百万合同的问题,更是对整个公司信誉的打击。到时候,不用陈明远动手,李铭就会第一个让他滚蛋。

他走到办公区,拍了拍手。

“所有人,停一下手里的活。出事了。”

二十多号人抬起头,看向他。

“百盛那边,发现订单数据有千分之三的丢失,给了我们三天时间解决问题,否则就要切流量。”林辰语速很快,“问题集中在晚上十点到凌晨两点,也就是我们的发版窗口期。谁负责那个时段的发布?”

几个组长面面相觑。

“上周是我。”一个叫刘凯的架构师举手,“但每次发布我都严格按流程走,发布前备份,发布后验证,没发现问题啊。”

“发布日志调出来。”林辰走到刘凯的工位,“系统监控也调出来,我要看那个时间段的所有异常。”

屏幕亮起,日志如瀑布般滚动。林辰盯着屏幕,眼睛快速扫描。系统也在辅助分析,将可疑的条目高亮标记。

“这里。”林辰指着一条日志,“晚上十点二十三分,订单服务重启,导致正在处理的二十三个订单状态丢失。数据补偿机制启动了,但补偿失败了——原因是补偿服务本身的数据库连接超时。”

他又指向另一条:“十一点零七分,支付服务发布,新老版本同时运行了三分钟。这期间,有部分订单被老版本处理,部分被新版本处理,状态不一致。数据同步时发生冲突,有七个订单被标记为‘异常’,需要人工处理。”

一条,又一条。

总共发现了十三个问题点,分布在过去五天的发布记录里。每个问题单独看都不大,但累积起来,就造成了千分之三的丢失率。

“所以不是技术问题,是流程问题。”林辰直起身,“我们太赶了,发布频率太高,验证时间太短,导致小问题没被发现,积累成了大问题。”

“那怎么办?”刘凯问,“降低发布频率?可进度怎么办?”

“不降低频率,但要加强验证。”林辰在脑海里快速构思方案,“从今天起,所有发布必须通过三道关卡:第一,自动化测试覆盖率必须达到95%以上;第二,预发环境必须模拟线上流量压测一小时;第三,生产环境发布后,必须有专人监控核心指标十五分钟,确认无异常才算成功。”

“这样时间会更紧……”

“紧也得做。”林辰打断他,“丢一个客户,比延迟三天更致命。王海清,你重新排发布计划,把非紧急的优化往后挪,优先保障核心链路的稳定性。刘凯,你带三个人,专门做数据一致性校验工具,确保每次发布后,数据都是对的。”

“明白。”

“好,干活。”

人群散去。林辰回到工位,打开电脑,开始写给百盛的报告。系统辅助他分析根因、制定方案、预估时间,但他必须用自己的语言组织成专业、可信的文字。

这是场硬仗。

但好在,他有系统,有团队,还有十三天积累下来的信任资本。

够用了。

5

晚上十点,林辰终于写完报告,发给百盛的王磊。对方很快回复:“收到,我们会评估。期待三天后的结果。”

客气,但冰冷。

林辰关掉邮箱,靠在椅子上,揉了揉太阳穴。连续工作了十八个小时,脑子像一团被搅过的浆糊,思考都有些迟滞。

手机震动,是苏雨晴发来的微信:“鸡汤在锅里,记得热一下再喝。我和孩子先睡了,你早点休息。”

配了一张照片:灶台上放着砂锅,旁边是洗好的碗勺。

很简单的画面,但林辰看了很久。

然后他回复:“好,马上回。”

他关掉电脑,收拾东西,走出办公区。还有几个人在加班,看到他都站起来。

“林总,要走了?”

“嗯,回家。你们也早点休息,别熬太晚。”

“我们再弄会儿,这个模块马上调通了。”

“行,注意身体。”

林辰点点头,走进电梯。轿厢下行时,他看着镜子里那个胡子拉碴、眼窝深陷的男人,突然觉得有点陌生。

三十五天前,他还是个站在天台想跳楼的失业中年。

三十五天后的现在,他带着一支八十多人的团队,在跟时间赛跑,在跟竞争对手较劲,在跟公司内部的阻力周旋。

变化太大,快得有些不真实。

电梯到一楼,门开。他走出大厦,深夜的风带着凉意,吹在脸上很舒服。街道空旷,路灯把他的影子拉得很长。

他走到路边,准备打车。手机又震了,这次是个陌生号码。

“喂?”

“林辰?”电话那头是个熟悉的声音,带着笑意,但那笑意里藏着针。

林辰身体一僵。

陈伟。

他的大学同学,云图科技的CEO,也是他最大的竞争对手。

“陈伟。”林辰的声音冷了下来,“有事?”

“没事就不能找老同学聊聊?”陈伟在电话那头笑,“听说你最近在星河科技干得风生水起啊,空降COO,立军令状,要大刀阔斧搞重构。有魄力,佩服。”

“你到底想说什么?”

“别急嘛。”陈伟慢悠悠地说,“我就是想提醒你一句,步子太大,容易扯着蛋。你们星河科技那个‘星语’系统,病根太深,不是三十天能治好的。硬来,只会崩得更快。”

“这是我们公司的事,不劳你费心。”

“我当然要费心。”陈伟的笑意收敛了,“百盛集团那边,我已经接触过了。他们的刘总,对你们最近的表现很不满意。如果我这时候递上一份更稳定、更便宜的方案,你说,他们会怎么选?”

林辰握紧了手机。

“陈伟,你这是趁火打劫。”

“商场如战场,老同学。”陈伟的声音很平静,“你当年抢我奖学金的时候,不也这么说的?现在,轮到我了。”

电话挂了。

忙音嘟嘟作响。

林辰站在深夜的街头,握着手机,手背青筋暴起。

原来如此。

百盛突然施压,不只是因为系统问题。背后有陈伟在推波助澜。他想趁星河科技内部动荡、林辰立足未稳的时候,抢走最大的客户,给星河科技致命一击。

好手段。

不愧是陈伟。

林辰深吸一口气,缓缓吐出。然后他解锁手机,给王海清发了条微信:“明天早上六点,所有人会议室集合。紧急会议。”

发完,他收起手机,拦了辆出租车。

“师傅,去滨江花园。开快点。”

车启动,驶入夜色。

窗外的城市向后飞掠,霓虹灯在玻璃上拖出长长的光轨。

林辰靠在座椅上,闭上眼睛。

但这一次,他没有休息。

他在脑海里,调出了系统界面。

“系统,启动AI超脑深度推演模块。推演场景:云图科技针对星河科技的技术方案、报价策略、客户关系网络。给我一份完整的竞争分析报告,以及……反击方案。”

【收到。启动深度推演……数据采集中……分析中……】

【预计完成时间:2小时13分钟。】

很好。

林辰睁开眼睛,看向窗外。

陈伟想玩?

那就玩把大的。