加入阿里技术团队三年,哪些习惯让我在工作上持续受益?

2017年研究生毕业,我加入阿里巴巴数据库技术团队,从事分布式数据库研发,如今算来已经有三年时间了,在这期间,我深度参与了双十一背后的数据库PolarDB-X从设计到实现的全过程。在这三年的时间里,于我而言,最大的收获来自两方面:

(1)大型数据库项目的磨砺。数据库作为三大基础软件之一,复杂度不言而喻,而分布式数据库将这个复杂度又提升了一个层次,因此尝试这个领域的企业并不多。一毕业就有机会挑战这个级别的难度,磨砺造就成长。
(2)有幸与一群实力超群的小伙伴一起工作,从他们身上能学习到太多东西了。

配图.jpg

根据工作经验和观察身边优秀的同事,我发现优良的工作习惯是区别一般工程师和专家工程师的重要素质。想要提升自己,必须要认识到哪些工作习惯会拖延工作效率,提升项目复杂度,增加沟通难度,甚至让合作伙伴失望,然后改正它们。刻意练习那些被证明有效实用的工作方式,成为习惯。在阿里的这三年,我积累了这些工作习惯:

01

最基础也最重要的习惯:想清楚再动手。大模块和功能,详细的设计文档必不可少。小模块和功能,最好动手之前,在白板或纸上写画清楚,并记录下来,千万不要靠巧合编程,要理解正在做的事情,并全面考虑各种可能性。

02

设计、编写正交性好的代码模块。这是大家公认的良好编程习惯,但说起来容易,做起来难。工程师可能会图一时之快,编写重复、复杂的“面条代码”,随着代码量膨胀,这无疑会是代码维护和问题排查的灾难。平时最好能刻意练习编写正交性好的代码(刚开始可能花时间,但要熟悉这种思维习惯),学习业界优秀的代码也是精进的方式。这里简单列四点实用技巧:

1、不向其它模块暴露任何不必要的信息,也尽量不依赖其它模块,隐藏复杂性

2、尽量避免编写相似的函数,让复用变的容易。

3、尽量避免直接使用全局变量。

4、编写独立的函数,减少函数间的依赖,函数解耦的一些技巧:

(1)只调用对象自身的函数。

(2)只调用传入参数对象的成员函数。

(3)只调用函数内部创建对象的函数。

(4)减少函数的长度。

03

如果发现代码中不满意的地方,早重构、多重构。尽量不要容忍软件中的“垃圾”。重构前应该确保:

1、不要在重构的同时加功能;
2、重构前确保拥有良好测试,确保重构对系统重量的影响最小化;
3、采取短小、深思熟虑的重构节奏。

04

系统里的每一项知识都是单一、无歧义、权威的,要与所有研发人员达成一致。避免合作者之间因为理解的差异,编写出语义相悖的代码。

05

把低级的知识放在代码里,注释留给高级的说明,糟糕的代码才需要许多注释,当然也不能没有注释。commit message也要认真写。

06

时刻考虑并发对代码的影响,面向并发设计;时刻考虑空间和时间效率;时刻考虑Corner case。

07

为项目制定详细的编码规范,并严格遵守。精心的为模块、文件、变量和函数命名,意义清晰无歧义。合理布局文件和文件夹。

08

关于bug排查。

1、遇到bug,不要恐慌,相信自己能解决它。学会评估bug的影响面。
2、bug是你的还是别人的没有关系,不要抱怨,问题已经在那了,解决它。
3、如果排除一个bug花费了很长时间,思考能否做点什么(例如增加日志、总结文档、优化代码等),让下次排查更容易。
4、Crash early,一旦发生异常,立即崩溃,让问题第一现场尽早暴露。如果认为什么不可能发生,就用断言确保它不会发生,不要自己说服和欺骗自己。
5、打印含有跟踪信息、格式统一规范的日志,尤其是异常路径的。

09

尽可能多、尽可能早、尽可能全面地测试。让质量成为正式的需求。

1、单元测试要覆盖正向路径和异常路径,关注一些边界条件,并且校验结果。
2、模块测试、集成测试、压力测试、性能测试都应该自动化。
3、不要忽略资源耗尽、故障恢复的测试场景

10

关于工具使用:

1、选择一种强大的编辑器,尽可能学好它,利用它。
2、尽可能多的自动化,让计算机去做那些重复的工作,显然它们更擅长。这既避免了出现错误,又提高效率。
3、使用配置文件,而不是集成在代码里。把抽象放进代码,把细节放进元数据。

11

做一个知识输出者,多写文章和总结,在自己常用的平台分享,总结和复盘能加快进步。不要害怕交流,不要害怕暴露缺点,有效的交流越多,你就越有影响力。

12

今天了不起的软件,比明天完美的软件更重要。

13

最后,多运动,保持头发和衣着整洁,保护好颈椎,保护好视力...


阿里云分布式数据库PolarDB-X团队招人啦!

团队简介:

PolarDB-X是阿里巴巴全自研自主可控的分布式数据库系统。不同于同品牌基于共享存储架构的数据库PolarDB,PolarDB-X是一款Share Nothing架构的分布式数据库,可支撑千万级并发规模及百PB级海量存储,专注解决海量数据存储、超高并发吞吐、大表瓶颈以及复杂计算效率等数据库瓶颈问题。

面向人群

2021 届海内外院校应届毕业生

(毕业时间为 2020 年 11 月 - 2021 年 10 月)

应聘方式:扫描下方阿里巴巴春招二维码

春季招聘.png

或直接将简历投递至dehao.wdh@alibaba-inc.com


直播预告

3月26日 15:00-16:00邀您一同见证

云数据库SQL Server 2019版全国首发

全面提升性价比及数据库能力

一年享4折

点这里

预约观看直播
SQL.jpg

 

原文链接
本文为云栖社区原创内容,未经允许不得转载。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/516492.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

征战多云时代,Nutanix这款Kubernetes多云PaaS新利器,你Get到了吗?

当前,全球企业上云步伐加快,企业都有相同的目标:尽快将业务迁移上云,从而减少基础架构成本,提高员工效率,缩短业务研发时间,提供性能可靠的IT系统。 当下,以容器、服务网格、微服务…

学习笔记之数据可视化(二)——页面布局(中)

续上一章 2.6 监控区域布局2.6.1 布局结构解析:2.6.2 样式描述:2.6.3 HTML结构及CSS样式代码2.6.3 ### 监控区域-效果2.6.7 点位区域(point)2.6 监控区域布局 监控区域 monitor盒子高度: 480px,布局划分及内部盒子类名如下: 2.6.1 布局结构解析: .tab样切换:tabs 标…

OFD文件、pdf文件相互转换、ofd文件在线预览

文章目录一、在线预览1. api使用2. 案例3. 效果二、ofd转odf2.1. api使用2.2. 参考案例三、odf转ofd3.1. api使用3.2. 参考案例3.3. 开源项目一、在线预览 1. api使用 ofd文件在线预览: 使用方式: 格式:/ofdViewer/viewer.html?file1.ofd相对路径 2.…

【开发者成长】Vue.js 中有哪些性能陷阱

云栖号资讯:【点击查看更多行业资讯】 在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! 我内心深处对游戏的热爱,让我一直渴望能自己制作一些电子游戏。几个月前我开始将这种梦想变为现实,并…

【职业生涯】这样的开发人员每个团队都想要

云栖号资讯:【点击查看更多行业资讯】 在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! 合作是你职业生涯中不会缺少的一个部分。 什么是团队?团队就为了共同目标而努力的一群人。一个团队实现目标的过…

elasticsearch-7.15.2 同时支持中文ik分词器和pinyin分词器

文章目录1. 自定义分词器2. 映射模型3. 效果图1. 自定义分词器 ES如何支持拼音和中文分词 ? 自定义分词器 支持拼音和中文分词 PUT /jd_goods {"settings": {"analysis": {"analyzer": {"ik_smart_pinyin": {"type&…

【数字康复治疗】自闭症市场能否走出供求困境

云栖号资讯:【点击查看更多行业资讯】 在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! 世界卫生组织将每年的4月2日设为“世界提高自闭症意识日”,旨在提高人们对自闭症和相关研究与诊断以及自闭症患者…

微软全球 AKS 女掌门人,这样击破云原生“怪圈”!

来源 | 程序人生作者 | 伍杏玲近年来,“云原生”成为IT界的热词,可什么是“云原生”?不少开发者表示“云里雾里”,更别提如何借助云原生更好地释放云价值。从云原生(CloudNative)一词中我们看到&#xff0c…

【数据库】一个 rm -rf 把公司整个数据库删没了

云栖号资讯:【点击查看更多行业资讯】 在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! 经历了两天不懈努力,终于恢复了一次误操作删除的生产服务器数据。 对本次事故过程和解决办法记录在此&#xff0c…

elasticsearch-7.15.2 集成pinyin分词器

文章目录1. 下载拼音分词器2. es集成pinyin3. 启动es4. pinyin分词5. 效果图6. 开源项目1. 下载拼音分词器 链接:https://github.com/medcl/elasticsearch-analysis-pinyin 2. es集成pinyin 方式任选其中一种即可 第一种:在线安装 ./bin/elasticsear…

【智能AI】准确率97%的开源肺炎检测模型

云栖号资讯:【点击查看更多行业资讯】 在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! 最近,一位澳大利亚的人工智能博士候选人在 LinkedIn 上发布了一篇关于 SARS-CoV-2 病毒的研究文章。由于极具话题…

豪气!华为放话:3年培养100万AI人才!网友神回应了

大家经常把BAT挂在嘴边,但是可能有些人还不知道,华为的体量早已超越了这三巨头,只是迟迟不肯上市。华为的创始人任正非曾说表:上不上市不重要,最重要的是要让中国华为的技术能够称霸全球!华为对技术的重视&…

elasticsearch-7.15.2 配置IK中文分词器+拼音分词

文章目录1. 下载分词器2. es集成pinyin3. 启动es4. 自定义分词5. 映射模型6. 初始化数据7. 查询索引8. 效果图9. 开源项目1. 下载分词器 ik中文分词器 中文分词器:https://github.com/medcl/elasticsearch-analysis-ik 拼音分词器 链接:https://github.…

Gartner 容器报告:阿里云与 AWS 并列第一,领先微软、谷歌

近日,国际知名调研机构 Gartner 发布 2020 年容器公有云竞争格局报告,阿里云再度成为国内唯一入选厂商。Gartner 报告显示,阿里云容器服务在中国市场表现强劲,产品形态丰富,在如 Serverless 容器、服务网格、安全沙箱容…

每个程序员都必须知道的8种通用数据结构

云栖号资讯:【点击查看更多行业资讯】 在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! 数据结构是一种特殊的组织和存储数据的方式,可以使我们可以更高效地对存储的数据执行操作。数据结构在计算机科学…

ElasticSearch 从安装开始_01

文章目录1. windows 环境2. linux3. HEAD 插件安装4. 分布式安装5. Kibana 安装1. windows 环境 首先打开 Es 官网,找到 Elasticsearch: https://www.elastic.co/cn/downloads/elasticsearch 然后点击下载按钮,选择合适的版本直接下载即可。…

硅谷2020最新大数据学习路线:科学使用这一招,12周助你成为数据分析师

来源 | 智领云科技责编 | Carol数据科学到底是什么?数据科学是一门将数据变得有用的学科,它包含三个重要概念:统计、机器学习、数据挖掘/分析。《数据科学杂志》曾提出:“所谓的‘数据科学’,指的是那些任何与数据相关…

新基建带来新机遇!大数据产业发展需“四驱”推动

云栖号资讯:【点击查看更多行业资讯】 在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! 近段时间以来,“新基建”一次热度不断攀升,受到了科技、产业界的高度关注。实际上,新基建…

Spring Boot简单多线程定时任务实现 | @Async | @Scheduled

Spring Boot简单多线程定时任务实现 实现步骤 1 创建一个Spring Boot项目 2 定义定时任务: package com.jmd.timertasktest.task;import org.springframework.context.annotation.Configuration; import org.springframework.scheduling.annotation.Async; impor…

【机器学习】AI系统实时监测独居老人症状

云栖号资讯:【点击查看更多行业资讯】 在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! 老年人是疫情中的高危人群。美国疾病控制与预防中心3月18日发布的报告显示,在美国,约80%新冠肺炎死者…