Oracle 程序员吐槽:永远不会再为 Oracle 工作了!

九路
• 阅读 1231

一位Oracle程序员在Hacker News上吐槽自己的工作,引起了热议,内容如下:

Oracle数据库12.2。它有近2500万行C代码。

这实在太恐怖了,简直难以想象!你做不到在不破坏成千上万个现有测试的情况下更改产品中的单单一行代码。好几代程序员在很紧的项目期限内编写了这些代码,代码中充斥着各种各样的垃圾内容。

非常复杂的逻辑、内存管理和上下文切换等等,一切都用数千个标志(flag)连接起来。整个代码充斥着神秘的宏命令,要是不掏出笔记本,手动展开宏命令的相关部分,你就无法搞清楚这些宏命令。可能要花一两天才能真正搞明白某个宏命令的作用

有时你需要搞明白20个不同标志的值和效果,以预测代码在不同的情况下会如何运行。有时多达数百个标志!我一点也不夸张。

这个产品仍然存活并仍然可以用的唯一原因是数百万次的测试!

下面是Oracle数据库开发人员平常的一天:

开始处理一个新的bug。

花两周的时间试图搞清楚20个不同的标志,这些标志以神秘的方式相互交互、导致这个困境。

再添加一个标志以处理新的特殊场景。再添加几行代码来检查该标志,避开有问题的情况,并避免该bug。

将更改提交到含有大约100台到200台服务器的测试服务器集群,这些服务器将编译代码,构建新的Oracle数据库,并以分布式方式运行数百万个测试。

下班回家。第二天来上班,处理别的bug。测试可能需要20小时到30小时才能完成。

下班回家。第二天来上班,检查你的服务器集群测试结果。顺利的话,会有大约100个失败的测试。倒霉的话,会有大约1000个失败的测试。随机选择一些测试,并试图搞清楚你的假设出了什么问题。也许另有10来个标志要考虑,才能真正搞清楚bug的本质。

再添加几个标志,试图解决问题。再次提交变更进行测试。再等20小时到30小时。

另外重复冲洗两周,直到你确保神秘的标志组合无误。

终有一天你会成功,没有一次测试失败。

添加针对你更改的100多个测试,确保下一个不幸接触这段新代码的开发人员永远不会破坏你的修复程序。

为最后一轮测试提交工作。然后提交以供审查。审查本身可能另外需要2周到2个月。所以现在改而搞下一个bug。

2周到2个月后,一切都已完成,代码最终合并到主分支中。

以上就是在Oracle修复bug的程序员日常工作的客观描述,一点也不夸张。现在想象一下开发新功能会有多么恐怖。开发一项小小的功能就需要一年半载(有时甚至长达两年!)(比如说添加一种新的身份验证模式,比如支持AD身份验证)。

这款产品可以用这本身简直就是个奇迹!

我不再为Oracle工作了。永远不会再为Oracle工作了!

点赞
收藏
评论区
推荐文章
浅梦一笑 浅梦一笑
5个月前
初学 Python 需要安装哪些软件?超级实用,小白必看!
编程这个东西是真的奇妙。对于懂得的人来说,会觉得这个工具是多么的好用、有趣,而对于小白来说,就如同大山一样。其实这个都可以理解,大家都是这样过来的。那么接下来就说一下python相关的东西吧,并说一下我对编程的理解。本人也是小白一名,如有不对的地方,还请各位大神指出01名词解释:如果在编程方面接触的比较少,那么对于软件这一块,有几个名词一定要了解,比如开发环
blmius blmius
1年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
技术小男生 技术小男生
5个月前
linux环境jdk环境变量配置
1:编辑系统配置文件vi/etc/profile2:按字母键i进入编辑模式,在最底部添加内容:JAVAHOME/opt/jdk1.8.0152CLASSPATH.:$JAVAHOME/lib/dt.jar:$JAVAHOME/lib/tools.jarPATH$JAVAHOME/bin:$PATH3:生效配置
光头强的博客 光头强的博客
5个月前
Java面向对象试题
1、请创建一个Animal动物类,要求有方法eat()方法,方法输出一条语句“吃东西”。创建一个接口A,接口里有一个抽象方法fly()。创建一个Bird类继承Animal类并实现接口A里的方法输出一条有语句“鸟儿飞翔”,重写eat()方法输出一条语句“鸟儿吃虫”。在Test类中向上转型创建b对象,调用eat方法。然后向下转型调用eat()方
Jacquelyn38 Jacquelyn38
1年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
刚刚好 刚刚好
5个月前
css问题
1、在IOS中图片不显示(给图片加了圆角或者img没有父级)<div<imgsrc""/</divdiv{width:20px;height:20px;borderradius:20px;overflow:h
小森森 小森森
5个月前
校园表白墙微信小程序V1.0 SayLove -基于微信云开发-一键快速搭建,开箱即用
后续会继续更新,敬请期待2.0全新版本欢迎添加左边的微信一起探讨!项目地址:(https://www.aliyun.com/activity/daily/bestoffer?userCodesskuuw5n)\2.Bug修复更新日历2.情侣脸功能大家不要使用了,现在阿里云的接口已经要收费了(土豪请随意),\\和注意
晴空闲云 晴空闲云
5个月前
css中box-sizing解放盒子实际宽高计算
我们知道传统的盒子模型,如果增加内边距padding和边框border,那么会撑大整个盒子,造成盒子的宽度不好计算,在实务中特别不方便。boxsizing可以设置盒模型的方式,可以很好的设置固定宽高的盒模型。盒子宽高计算假如我们设置如下盒子:宽度和高度均为200px,那么这会这个盒子实际的宽高就都是200px。但是当我们设置这个盒子的边框和内间距的时候,那
密钥管理系统-为你的天翼云资产上把“锁
本文关键词:数据安全,密码机,密钥管理一、你的云上资产真的安全么?1.2021年1月,巴西的一个数据库30TB数据被破坏,泄露的数据包含有1.04亿辆汽车和约4000万家公司的详细信息,受影响的人员数量可能有2.2亿;2.2021年2月,广受欢迎的音频聊天室应用Clubhouse的用户数据被恶意黑客或间谍窃取。据悉,一位身份不明的用户能够将Clubho
helloworld_34035044 helloworld_34035044
8个月前
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为