百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

再见,MySQL

ccwgpt 2025-02-27 14:29 30 浏览 0 评论

芬兰程序员Monty有三个孩子,分别叫做My, Maria, Max。

这三个孩子非常幸运,因为他们的父亲把他们的名字永远地“刻”在了三个数据库产品之上:

MySQL

MaxDB

MariaDB

这位父亲就是MySQL的主要作者Michael Widenius,大家经常叫他Monty。

今天我们来聊一聊为什么是Monty创建了MySQL,MySQL又是怎么发展成为世界上最流行的开源数据库的。


01 编程达人

Monty1962年出生于芬兰的赫尔辛基, 1978年,16岁的他发现了一件高科技产品:ABC80计算机。


这个计算机的CPU只有4M Hz, 内存只有8K ,但是对于只玩过可编程计算器的Monty来说, 这才是真正的计算机。

于是Monty 找了一个“勤工俭学”的活儿:在赫尔辛基的街道上铺沥青, 虽然赚来了一笔钱,但还是不够,Monty老爸又出了一半的钱,这才成功地把ABC80抱回了家。

从此,Monty 整天和这台计算机“厮混”在一起。

Monty是个不折不扣的编程天才,对别人来说非常难的东西,他都能轻松搞定,编程对于他来说,就像读一本有趣的小说,或者玩一个游戏,不知不觉几个小时就过去了。

由于ABC80上没有多少软件,Monty小试牛刀, 用汇编语言把把游戏机上的一些热门游戏在这个机器上实现了!



可见游戏有着多么强大的驱动力!

两年以后,Monty又把ABC80升级成了 ABC800,此时的Monty已经不满足当一个游戏Boy了,开始在上面开发真正的软件了,比如:

字处理器

硬盘控制器

磁带备份

......


在一次演讲中,Monty说到:那真是美好的旧时光, 你想使用计算机的话,得从底层学习计算机硬件和软件的方方面面,对于现代的程序员来说,没有这样的机会了。


02 “桃园三结义”


由于ABC 电脑是瑞典制造的,很多配件只有瑞典才有,Monty经常乘船去瑞典买配件,有一次去买内存的时候,Monty结识了Allan Larsson。

Allan开着一个电脑商店,有一家叫做TcX的咨询公司,Monty逐渐和他变得熟络起来。

得知Monty是个编程天才以后,Allan给了他一个数据库程序,请他基于这个数据库为客户开发一个软件出来。

Monty把数据库程序拿来一看就发现,这程序写得太烂,难以理解,难以维护, 既然如此,还不如重写一个。

大牛就是这么任性。

Monty写的数据库程序叫做Unireg,最初用Basic在ABC800 编写,到了1983年,Monty又用C语言重写了一遍, 这样就可以运行在一个有着2M内存的强大机器上。

这就是Unireg的界面,纯文本,有点像打印机的格式。 虽然有点丑,但可以轻松地创建,更新数据库的数据,并且产生报表。

Monty和Allan都不会想到,这个看起来很简陋的数据库将来会一飞冲天,变成软件世界的中流砥柱:MySQL!

有了数据库,Allan拉来了更多的活儿,Monty作为TcX唯一的开发人员,不仅开发客户的应用程序,还花费了大量的时间来完善Unireg。

1985年, Monty和Allan干脆合伙开了一个叫TCX DataKonsult AB ,专注数据仓库领域, Monty把Unireg移植到了更强大的Sun工作站上,以便能处理更大规模的数据。


有多大规模呢?大概是每月百万行的数据。

可见这个时候的Unireg数据库,已经相当不错, 能处理大数据了!

在此期间, Monty又认识了David Axmark, 两人相见恨晚,经常在一起讨论技术问题,打电话到深夜。

David是一个自由软件的铁杆粉丝,他将来会对MySQL 的开源模型,盈利模式产生重大的影响。

Monty , David, Allan这三个人如同“桃园三结义”的兄弟,从此以后,他们将联手开启一段新历史。


03 MySQL问世


不知道Monty和Allan 用Unireg赚了多少钱,TcX这个小小的公司应该活得比较滋润。

如果就这么发展下去,估计MySQL就不会诞生了。

90年代中后期, 蓬勃发展的互联网将给Monty他们带来一个前所未有的挑战,当然也带来了前所未有的机遇。

1994年,客户希望TcX开始基于Unireg开发Web的应用,不幸的是,Unireg这个桌面软件的设计缺点暴露出来了:不支持SQL,没法和Web页面有效集成。

要么固守桌面软件,慢慢落后于时代,要么主动拥抱Web,Monty和TcX走到了一个十字路口。

这时候Monty 发现了开源的miniSQL (简称mSQL), Monty研究了一番后发现,mSQL最要命的问题是不支持索引,性能很差。

Monty联系mSQL的作者,问他能不能修改mSQL来使用Unireg的索引,mSQL的作者忙着开发mSQL 2.0,已经设计好了索引方案,就拒绝了。

自己动手,丰衣足食,Monty决心实现自己的数据库。

一年以后, 1995年1月,支持SQL接口,索引,有着C/S架构的MySQL 1.0 问世了。

狂热的开源软件爱好者David立刻找到Monty和Allan,给他俩施压,希望MySQL可以开源。

可是开源以后,大家都能用了,怎么赚钱呢?

David想了一个绝妙的主意:双重许可

客户可以以开源的方式使用MySQL,不需要付费。

但是,如果客户在自己的产品中使用了MySQL,还想通过闭源的方式来销售自己的产品,那对不起,需要付费购买商业许可。

这样,既能扩大软件的使用用户,收入还不至于颗粒无收。


04 15分钟 和 3万封邮件

MySQL是幸运的,它踏上了互联网的风口:Web网站如雨后春笋般出现,每个网站都需要一个免费的数据库,MySQL正好填补了这个空白

当时建站的主要语言是PHP,Perl , 这些程序员也对MySQL做了大量宣传:简单、易用、高性能。

Monty和David设定了一个目标:让用户在下载完MySQL以后,15分钟内就能运行起来, 在现在RPM, DEB等安装包大行其道的时代,15分钟听起来非常漫长, 但是在1996年,通常需要从源代码安装,一点点小问题,就会花费数小时。

为了这15分钟,Monty他们付出了辛苦的努力,需要模拟用户在8~10个操作系统上编译,安装MySQL的不同版本。

Monty 对用户非常负责, 他在MySQL问世前5年的时间里,回复了30000多封邮件,来解决大家的疑问。

David 也没有闲着,马不停蹄地参加各种会议,到处宣传MySQL, 他在飞机上度过的时间超越了在家的时间。

免费的MySQL逐渐成为建站的第一选择。加上Apache和Linux, 形成了著名的LAMP。


05 5000万美元


到了1999年,MySQL已经被一些人注意到了, 并且开出了5000万美元的高价想把MySQL买下。

如果是目光短浅的我,十有八九就卖了,多么诱人的报价,卖了以后就财务自由了!

但是Monty他们有着更大的愿景:做点儿事情,改变世界。

他们不想就此失去对公司的控制,于是他们拒绝了这次收购。

随着时间推移,MySQL越长越大, 公司从3个人发展到了15个人, 客户越来越多,需要的功能也水涨船高。MySQL公司需要更多人手去做技术支持、编写文档、销售。

市场上也出现了像PostgresSQL这样的竞争对手, 如果再不引入投资,靠之前的收入缓慢增长,MySQL迟早会被飞速发展的时代干掉。

2001 年 M?rten Mickos 被聘为MySQL CEO, 专门和投资者谈,最后从风险投资那里获得了400万欧元的A轮融资, 仅仅出让了10%的股权, 控制权依然在Monty他们手中。

MySQL从此进入了发展的快车道,到2003年,仅两年的时间,MySQL的安装数就翻了一番,达到400万, 成为了全世界最受欢迎的开源数据库。

这一年,MySQL又获得了1950万美元的B轮融资。


06 和Oracle的暗战


Oracle是数据库领域的绝对老大, 统治着企业级数据库市场, 但是在Web领域却干不过免费、开源的MySQL。

Google, Facebook, Snapchat, Quora, Dropbox ,Youtube , Twitter 等IT巨头都不使用Oracle,他们不约而同地选择了MySQL, 因为不用给Oracle交巨额的License费用,还可以修改源代码适合自己的场景。

更要命的是, MySQL正在从Web领域杀下企业级市场,很多重量级客户从Oracle 转向免费的MySQL,这给Oracle带来了巨大的威胁。

2006年, Oracle 试图收购MySQL,但是没有成功。

Larry Ellison狂妄地说:

它(MySQL)只是一家小小的公司,年收入也就三四千万吧, 而我们Oracle的收入是150亿!


我们只收购那些有商业价值的公司,MySQL并不在我们收购的列表中。

话虽这么说, Oracle 却在不断地挖MySQL的墙角。

2005年, Oracle收购了一个叫做innobase的芬兰公司,正是这家公司给MySQL提供了支持事务处理的InnoDB 引擎。

过了一年,Oracle又收购了Sleepycat,这家公司给MySQL提供了Berkeley DB事务引擎。


07 并购


2008年, 年收入达到7500万美元的MySQL面临一个抉择:究竟是上市呢?还是卖个好价钱?

M?rten Mickos, Monty, David等人经过一番讨论以后,他们选择了Sun,这是因为:

1. Sun是一家技术导向的公司

2. Sun是开源运动的推动者,没有把MySQL变成闭源软件的风险。

2008年1月,MySQL以10亿美元卖给了Sun,Monty也凭借这笔收入成为这一年芬兰的10大富豪之一。

可是人算不如天算, 让人苦笑不得的是,仅仅一年以后,Sun居然又被Oracle给收购了!

MySQL最终还是没有逃脱Oracle的手掌心。

MySQL的前景一下子黯淡下来,Monty说道:

很多核心的MySQL开发者,包括我自己,都不相信Oracle能善待MySQL,我们要确保MySQL的代码完全开源,永远开源。

2009年,作为对Oracle收购Sun的回应, Monty立刻创建了一个MySQL的分支:MariaDB, 它和MySQL兼容,并且完全开源,一大批核心开发人员追随Monty,离开MySQL,加入MariaDB。


2009年Monty已经47岁了, 和MySQL说了再见,他踏上了新的征程。

2020年,Monty已经58岁了,依然在一线奋战。

传奇将会继续......

(完)

相关推荐

团队管理“布阵术”:3招让你的团队战斗力爆表!

为何古代军队能够以一当十?为何现代企业有的团队高效似“特种部队”,有的却松散若“游击队”?**答案正隐匿于“布阵术”之中!**今时今日,让我们从古代兵法里萃取3个核心要义,助您塑造一支战斗力爆棚的...

知情人士回应字节大模型团队架构调整

【知情人士回应字节大模型团队架构调整】财联社2月21日电,针对原谷歌DeepMind副总裁吴永辉加入字节跳动后引发的团队调整问题,知情人士回应称:吴永辉博士主要负责AI基础研究探索工作,偏基础研究;A...

豆包大模型团队开源RLHF框架,训练吞吐量最高提升20倍

强化学习(RL)对大模型复杂推理能力提升有关键作用,但其复杂的计算流程对训练和部署也带来了巨大挑战。近日,字节跳动豆包大模型团队与香港大学联合提出HybridFlow。这是一个灵活高效的RL/RL...

创业团队如何设计股权架构及分配(创业团队如何设计股权架构及分配方案)

创业团队的股权架构设计,决定了公司在随后发展中呈现出的股权布局。如果最初的股权架构就存在先天不足,公司就很难顺利、稳定地成长起来。因此,创业之初,对股权设计应慎之又慎,避免留下巨大隐患和风险。两个人如...

消息称吴永辉入职后引发字节大模型团队架构大调整

2月21日,有消息称前谷歌大佬吴永辉加入字节跳动,并担任大模型团队Seed基础研究负责人后,引发了字节跳动大模型团队架构大调整。多名原本向朱文佳汇报的算法和技术负责人开始转向吴永辉汇报。简单来说,就是...

31页组织效能提升模型,经营管理团队搭建框架与权责定位

分享职场干货,提升能力!为职场精英打造个人知识体系,升职加薪!31页组织效能提升模型如何拿到分享的源文件:请您关注本头条号,然后私信本头条号“文米”2个字,按照操作流程,专人负责发送源文件给您。...

异形柱结构(异形柱结构技术规程)

下列关于混凝土异形柱结构设计的说法,其中何项正确?(A)混凝土异形柱框架结构可用于所有非抗震和抗震设防地区的一般居住建筑。(B)抗震设防烈度为6度时,对标准设防类(丙类)采用异形柱结构的建筑可不进行地...

职场干货:金字塔原理(金字塔原理实战篇)

金字塔原理的适用范围:金字塔原理适用于所有需要构建清晰逻辑框架的文章。第一篇:表达的逻辑。如何利用金字塔原理构建基本的金字塔结构受众(包括读者、听众、观众或学员)最容易理解的顺序:先了解主要的、抽象的...

底部剪力法(底部剪力法的基本原理)

某四层钢筋混凝土框架结构,计算简图如图1所示。抗震设防类别为丙类,抗震设防烈度为8度(0.2g),Ⅱ类场地,设计地震分组为第一组,第一自振周期T1=0.55s。一至四层的楼层侧向刚度依次为:K1=1...

结构等效重力荷载代表值(等效重力荷载系数)

某五层钢筋混凝土框架结构办公楼,房屋高度25.45m。抗震设防烈度8度,设防类别丙类,设计基本地震加速度0.2g,设计地震分组第二组,场地类别为Ⅱ类,混凝土强度等级C30。该结构平面和竖向均规则。假定...

体系结构已成昭告后世善莫大焉(体系构架是什么意思)

实践先行也理论已初步完成框架结构留余后人后世子孙俗话说前人栽树后人乘凉在夏商周大明大清民国共和前人栽树下吾之辈已完成结构体系又俗话说青出于蓝而胜于蓝各个时期任务不同吾辈探索框架结构体系经历有限肯定发展...

框架柱抗震构造要求(框架柱抗震设计)

某现浇钢筋混凝土框架-剪力墙结构高层办公楼,抗震设防烈度为8度(0.2g),场地类别为Ⅱ类,抗震等级:框架二级,剪力墙一级,混凝土强度等级:框架柱及剪力墙C50,框架梁及楼板C35,纵向钢筋及箍筋均采...

梁的刚度、挠度控制(钢梁挠度过大会引起什么原因)

某办公楼为现浇钢筋混凝土框架结构,r0=1.0,混凝土强度等级C35,纵向钢筋采用HRB400,箍筋采用HPB300。其二层(中间楼层)的局部平面图和次梁L-1的计算简图如图1~3(Z)所示,其中,K...

死要面子!有钱做大玻璃窗,却没有钱做“柱和梁”,不怕房塌吗?

活久见,有钱做2层落地大玻璃窗,却没有钱做“柱子和圈梁”,这样的农村自建房,安全吗?最近刷到个魔幻施工现场,如下图,这栋5开间的农村自建房,居然做了2个全景落地窗仔细观察,这2个落地窗还是飘窗,为了追...

不是承重墙,物业也不让拆?话说装修就一定要拆墙才行么

最近发现好多朋友装修时总想拆墙“爆改”空间,别以为只要避开承重墙就能随便砸!我家楼上邻居去年装修,拆了阳台矮墙想扩客厅,结果物业直接上门叫停。后来才知道,这种配重墙拆了会让阳台承重失衡,整栋楼都可能变...

取消回复欢迎 发表评论: