0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

为所有离职的谷歌工程师写的一份“厂外”生存指南

MqC7_CAAI_1981 来源:lp 2019-04-19 16:30 次阅读

一位曾经的谷歌工程师,花费两年时间,辛苦整理了一份清单。

这个名为“xg2xg”的清单,原本是这位前谷歌工程师(ex-Googler),为所有离职的谷歌工程师写的一份“厂外”生存指南。

但实际上,这个大全实打实地也成为了一份最佳开发工具大全。

所有的程序员,都能受益于此。

美国网友对这个大全给予了很高的评价:这份清单中列出的开源软件,不仅解决了硅谷大厂前员工的难处,也能为其他所有码农解除困惑。

在这套大全的指导下,任何一个工程师,都能获得类似在谷歌内部写代码的体验。xg2xg上线仅仅一天就登上趋势榜,收获2500+星!

清单其中大部分替代软件是Google开源的项目,或者是受谷歌论文的启发,由开源软件基金会自己做的第三方实现。即使你从来没进过Google工作,也在享受着Google工程师们带来的福利。不禁让人感叹“谷歌拯救世界”。

下面就让我们一起来看看这份清单吧。

开发工具一览

这份清单总共有两部分,前半部分介绍的是码农常用的开发工具,包括核心技术、基础设施、服务、开发运维等;后半部分则面向非技术人员。

核心技术工具

大数据处理工具

Google内部工具:MapReduce;替代品:ApacheHadoop、Spark

想要在上千台机器组成的大集群上、并行处理上TB级别的海量数据集,就要用到这类大规模数据处理工具了。

MapReduce,就是这类工具的先驱。JeffDean等人2004年提出了这个分布式计算架构,最早在Google内部用来处理大规模数据的并行计算。JeffDean还亲自为它撰写过使用指南。

而ApacheHadoop这个开源替代品,也是根据JeffDean当年的论文自行实现而成,能提供与MapReduce文件系统类似的功能。

如果想要更快的数据处理速度,还有ApacheSpark供你选择。相对于Hadoop的MapReduce会在运行完工作后将中介数据存放到磁盘中,Spark使用了存储器内运算技术,能在数据尚未写入硬盘时即在存储器内分析运算。

序列化工具

Google内部:ProtocolBuffer;外部替代品:Protobuf、Thrift、Avro

这一组工具用于结构化数据序列化,上面这些,都是xml替代品,比它更小、更快、也更简单。

ProtocolBuffer和Protobuf都是Google开发的序列化格式(SerializationFormat),github上可以找到这个项目的源代码。

比起XML和JSON,Protobuf更小、更快,也更简洁,很适合做数据存储或RPC数据交换格式。只需要定义一次数据结构,就可以利用各种不同语言或者从各种不同数据流中对结构化数据进行轻松读写。

完全撇开Google,也不是就没有别的选择了。其他厂商也有类似的序列化方案。

比如Facebook开发的Thrift,它与Protobuf基本一样。

Avro同样也有schema(也就是程序中结构化数据的定义),但是实现方式跟Protobuf和Thrift有很大区别。

由于数据不需要额外的标注,Avro在序列化大量相同的数据时会比Protobuf和Thrift更有效率。不过在编码大量变化的数据时,因为schema会随数据一同存储,Avro的效率会退化到JSON和MessagePack的级别。

看来在核心技术工具上,重回人间的前Google人还是有许多不错的选择的。

基础设施

大型集群管理系统

Google内部:Borg;外部替代品:Kubernetes、ApacheMesos、HashiCorpNomad

大型集群管理系统用于管理云平台中多个主机上的容器化的应用。

Borg是Google内部的大型集群管理系统,现如今应用最广泛的服务编配系统Kubernetes就脱胎于Borg。

Borg让开发者能够不必操心资源管理的问题,做到跨多个数据中心的资源利用率最大化。

没有Borg十五年的经验,也就不会有Kubernetes。虽然作者把它放在开源/真实世界这一栏里,但事实上Kubernetes也是由Google设计并参与开发的。

Kubernetes使用Go语言编写,是一个大而全的解决方案,服务调度、网络、存储、安全通通一手抓,而且本身的架构也非常好,在上面做二次开发非常容易。

HashiCorpNomad同样是一个比较常见的开源调度程序,架构简单,能将资源管理器和调度程序的功能集成到一个系统中。Nomad也是分布式的,高可用且易操作。但显然Kubernetes的功能会更丰富。

至于Mesos,它仅仅是一个调度系统,无法直接使用,要配合各种Mesosframework来实现各类功能。

存储

当然,Google内部工具也不是所有的都能找到完美的替代品。

至少在存储这件事情上,就有网友不赞同原作者观点。他认为这份清单在一定程度上具有误导性,某些替代品根本达不到Google内部工具的水平。

比如将Colossus和HDFS对比是在开玩笑,相比之下,HDFS就像是一个玩具。要说对比,它智能和十年前已经退役的GFS相当。

但HDFS恐怕是开源软件中Colossus最好的替代品,对于“通用,大型,分布式文件系统”的使用情况,很难找到有比HDFS更好的了。

其他开发工具

列表中还有服务、开发运维、安全等工具的替代品清单,由于篇幅限制,我们不再一一介绍,有需求的同学可以自取。全部工具的下载链接请参阅文末的GitHub地址。

还有什么福利

如果你不是工程师,上面那些工具大概就用不上了。不过,只要是个公司或者团队,总会有IT和运营需求。

比如说,饭总是要吃的。

很多网友看了这份清单,最感兴趣的就是这一项:

离开Google的人类,再也找不回免费食堂。

毕竟,“中午吃什么”的哲学问题,每次想起来都是折磨。

羡慕的时候,可以用以下口令来安慰自己:

公司有吃的,还不是为了让你们多点时间工作?

如果你觉得这一条说服力不够,还可以跟一句补充说明:

Google最初是为什么提供免费食物的?就是山景城总部周围吃的选择太少了,开车出去吃来回要一小时。对,就是想让员工省下时间好好上班。

吃,只是IT/运营章节的第一条。

后面,还有梗图生成器Memegen。

工作太辛苦的时候,可以皮一下:

△当没有GPU的人,遇到了Google Colab

对此,甚至有人呼吁:

如果Google全家桶把Memegen收了就好了。

所以,这个章节并没有和工作相关的资源么?

看看完整列表的话,还是能找到的:

有一些必要的小工具。

比如,CODEOWNERS可以用来指定哪些用户来审查代码,1Password是个密码管理器。

也有一些同学,没在上面找到自己需要的答案,便直接提问了:

Google这样的大厂,公司内部wiki用的是什么啊?我们公司用的是Quip,它就是个黑洞,文档一进去就出不来了。

然后,有热心人士回答了这个问题:

虽然不知道Google用的什么,但Confluence是很常用的。

xg2xg项目地址:https://github.com/jhuangtw-dev/xg2xg

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Google
    +关注

    关注

    5

    文章

    1757

    浏览量

    57405
  • 存储器
    +关注

    关注

    38

    文章

    7447

    浏览量

    163581
  • 源代码
    +关注

    关注

    96

    文章

    2944

    浏览量

    66657

原文标题:最佳开发工具大全!前谷歌工程师两年打造“厂外生存指南”,登上GitHub热榜

文章出处:【微信号:CAAI-1981,微信公众号:中国人工智能学会】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    电子工程师指南 全面介绍工程师所具备的电路知识

    电子工程师指南全面介绍工程师所具备的电路知识电子工程师指南全面介绍工程师所具备的电路知识
    发表于 04-07 10:28

    电子工程师指南

    电子工程师指南,有必要看
    发表于 02-03 17:00

    电子工程师指南

    电子工程师指南
    发表于 08-14 13:20

    篇来自华为内部的硬件工程师手册

    本帖最后由 冒烟的开发板 于 2015-1-13 15:20 编辑 虽被称为“狼性文化”,起来看下狼性文化下面孕育着怎样的硬件工程师~~篇来自华为内部的硬件工程师手册~~PS
    发表于 08-26 13:17

    电子工程师,这里有一份datasheet阅读指南

    ,物理参数,甚至制造材料,使用建议等,内容形式说明文字,各种特性曲线,图表,数据表等。数据手册的PDF文件般是免费发放的。作为工程师,必须注意的还有器件的典型性能、最小和最大需
    发表于 03-13 10:07

    硬件工程师经典笔试题集总结

    所谓金三银四,现在3月和4月之间,现在不少的工程师小伙伴也在忙着找工作,特意送上一份资料《硬件工程师经典笔试题集锦》电子书,助力
    发表于 08-06 02:48

    工程师告诉你如何去做PCB设计?

    工程师告诉你如何去做PCB设计?有一份指南请查收。
    发表于 04-26 07:03

    谁分享一份嵌入式软件工程师/单片机软件工程师面试试题&答案,THX!

    谁分享一份嵌入式软件工程师/单片机软件工程师面试试题&答案,THX!
    发表于 10-25 17:26

    电子工程师指南

    电子工程师指南
    发表于 03-15 09:51 0次下载

    电子工程师十大离职原因

    电子工程师是个特殊的群体,我接触过的HR人都这样讲,都来问我这样工程师出身的管理者个问题“电子工程师那么难沟通,他们到底在想什么”,对
    的头像 发表于 12-22 15:49 7217次阅读

    怎样找到一份工程师工作

    说实话,你是位优秀的工程师候选人吗?你怎么评价自己?你面试过多少家公司?你拿到offer的比率是多少?试下用以下的公式来计算。
    的头像 发表于 11-27 15:33 1571次阅读

    谷歌是如何管理工程师的?

    谷歌创立开始,向来信奉“技术至上”的公司员工就直质疑管理的价值。正如软件工程师埃里克•福莱特(Eric Flatt)所说,“我们是家由工程师
    的头像 发表于 08-02 09:56 3782次阅读

    前端工程师的简历到底怎么

    其实前端工程师并不少,但很多时候合适的前端工程师难找。可能是由于程序员比较内向,前端工程师都没有把自己最厉害的那面表现出来。今天我们来聊聊前端工程
    的头像 发表于 04-16 17:08 3692次阅读

    工程师操作指南——RF指标的内在和意义

    来源:RF技术社区 本文来自与非网 这篇文章的初衷是源自我给工厂工程师一份“操作指南”,按理说这些东西对于工作了十来年的人来说应该是手
    的头像 发表于 12-08 15:42 613次阅读

    外国工程师的PLC程序分享

    分享个外国工程师的PLC程序,大家感觉如何?
    的头像 发表于 10-24 11:43 959次阅读