相关阅读:

厉害了Word哥!阿里巴巴73款开源产品最全总结全景图

导读:本文是秦大师(公司外也人称泰迪)最近的年终总结,转载自微博头条文章。


秦迪,微博研发中心技术专家,2013 年加入微博,负责微博平台通讯系统的设计和研发、微博平台基础工具的开发和维护,并负责微博平台的架构改进工作,在工作中擅长排查复杂系统的各类疑难杂症。爱折腾,喜欢研究从内核到前端的所有方向,近几年重点关注大规模系统的架构设计和性能优化,重度代码洁癖:以 code review 为己任,重度工具控:有现成工具的问题就用工具解决,没有工具能解决的问题就写个工具解决。业余时间喜欢偶尔换个语言写代码放松一下。

眼看着又一年结束,想想今年过的还真是快,上个画面还是去年年末各种处理故障的场景,一眨眼一年就过去了。既然过了一年,还是得留下些思考和展望,否则就有些太无趣了。

还是套用那个老的不能再老的梗吧,the good,the bad and the ugly。

The Good

今年职位从高级码农变成了看上去很忽悠人的”技术专家“,虽然按专家的头衔来说应该做一些更深入的研究工作,不过受限于身体状态一直不好,一认真的思考问题就会头昏脑涨,只好做了很多给团队打杂的工作,所以好的部分大多数不是我个人的贡献,而是团队的功劳。

今年最主要的成果,应该是跟团队一起在很多事情上兑现了之前一直念叨的“应该”。

应该从现在开始做重构,而不是“到时候”

从去年接手团队之后就一直在跟历史代码做斗争,在做了很久看似出工不出活的“代码review”、“重构”、“增加测试”、“删代码”之后终于有了回报:我们的代码质量可以让我们在其中正常工作,不再需要为了一个看似简单的功能而大动干戈的在“屎一样的一大坨代码”里纠结半天了。

我们试过很多办法提升代码质量,包括强制code review、专门抽出时间重构、周会上的代码评审等等。每一种都或多或少的有一些效果,但最有效果的做法是引入自动化的代码风格检查工具,可以发现大部分代码细节问题,并且很容易量化,对于“质量”这种没有实感的东西,量化是能够让你持续投入很重要的一个方面。

而最终的收益不仅是开发效率的提升,更重要的是,一个不断进化的团队中的一员在看到烂代码时,感受到的是“如何解决这些问题”的挑战,而不是”这些代码再也不会好了“的无力感。

应该通过提升开发效率完成工作,而不是靠加班

有代码不断优化的基础,我们也很自然的把服务过渡到了微服务架构。微服务架构让我们能够更敏捷的工作,不再需要忍受单体架构带来的“一个巨大的黑盒”带来的不便,我们可以对性能做更细致的分析,对问题做更精确的定位,对技术选型也有更多自由。在此基础上建立起了持续部署系统终于把上线变成了一件日常工作,“等我5分钟,我review代码的时候发现个bug,上个线就去吃饭”。

我跟很多人谈起这个“5分钟上线”的时候,他们都觉着我是个不负责任的人,并且一遍又一遍的问我:“上线上出问题怎么办?”

问我这个问题的人一定是没有考虑过“复杂度”本身就是一个巨大的问题源,当代码足够简单、依赖足够清晰时,很多问题就自然的消失了。实际上,我们现在的上线次数从每周两次提高到了每天十几次之后,上线产生的问题已经几乎不存在了。

应该通过报警发现问题,而不是用户投诉

我去年用几天写了一个报警系统,团队又在此基础之上建立起了一套特别靠谱的报警服务,不再依靠“检查系统内部有没有问题”,而是站在用户的视角,依靠探测程序检查“用户在使用时是不是有问题”。

站在用户维度报警的好处是,只要有报警,那么就一定有问题。于是我们终于从每天轰炸式的报警短信中脱出身来,不再需要“按报警频率估计服务有没有问题”这种无用的工作,也不需要面对boss“怎么用户都投诉了你们还不知道”的尴尬问题。只要有报警,那么就需要处理;反过来,只要没报警,那么绝大部分用户使用也不会有问题,我可以放心的玩《守望先锋》而不用担心boss会突然来电话。

最终,有惊无险的,我们做到了服务全年无故障(虽然还有几天才过完今年,希望这不是一个flag……)。

应该通过技术解决性能问题,而不是堆机器

微博的访问量极大,做个方案动辄要支持百万并发、千亿数据,但奇葩的是公司又很穷总是买不起新服务器(-_-),性能优化就变成了极其重要的工作。

我们今年做了不少应用的性能调优,把每个服务的性能指标都提升了几倍(还有几倍是留给明年的KPI的-_-)。性能调优是一件有挑战又有成就感的事情,而且比较有意思的地方是,无论程序员的水平是好是坏,总是有调优的空间。水平弱一些的同学可以调优业务代码和基本参数;好一些的优化架构和第三方组件;牛逼的可以深入jvm和内核原理。调优经验多了,总会有种“无论怎么优化也到不了头”的感觉。

另外,我们今年基于云服务、容器技术、调度系统、混合云编排系统、容量评估系统和自身的微服务架构体系,实现了公司成本部门老是念叨的的“按需扩缩容”功能,我们的直播互动系统也成为了微博内部首个按流量自动扩缩容的服务,达到了“5分钟完成无人值守自动扩缩容”的状态。在这个系统的帮助下,支撑微博直播互动服务的常备机器只有几台而已,参加技术大会看到有人谈直播架构时,总是莫名的有一种优越感……

应该做更多有挑战的事情,而不是一直重复自己的工作

今年我们承担了更多微博的业务,我们如今应该算是微博里少有的“后端服务一条龙”团队,一整年来我们都在整合和优化各种服务的架构和链路。从消息箱底层业务,到tcp连接服务,到收件箱后端服务,到直播互动服务,到微博视频服务,到文件存储服务等等,这一年做了不少对原服务进行重写和进行新架构设计的工作。

技术栈的多样化带来的是难以管理和重复性的工作,但是只要对不同的业务稍作抽象,那么就可以复用很多现有的基础设施,抽象和复用的实践多了,就可以称之为体系。今年我们对不同服务的各方面,比如架构、开发框架、运维、监控、报警等等方面做了抽象,建立起了一套体系,使我们不再受技术栈过于发散的困扰。

换句话说,团队一方面享受着大公司的技术积累,一方面又有各种新业务场景带来的技术挑战,这是挺难得的状态。

The Bad

就跟之前说的一样,今年本来想做一些更纯粹的研究工作,比如对操作系统内存模型完整的剖析,或者对性能分析能力的进一步提高,又或者再去qcon之类的技术大会露个脸,但是受限于身体状态,只好作罢。

前两年工作加班的比较猛,经常一搞就到凌晨5,6点。这一年也做了些调整,没再整到过后半夜,下了班就一溜小跑回家玩守……啊不是,回家休息。对团队小伙伴们的要求也是尽量提升效率,少加班。合理的作息和锻炼对于程序员很重要,”身体是革命的本钱“这句话诚不欺我。

今年还有个遗憾就是没能实现“三十岁前用自己写的语言写一个操作系统”的愿望。也忘了这是什么时候定下的“小目标”了,在如今,写个语言其实并不困难,编译器已经是很完善的技术了;写个操作系统也有一大堆从入门到xx系列。但难就难在真的去做,说到做到和觉着自己能做到还是两件事情,希望有机会还是自己动手做一做。

另一方面,对团队来说,还有很多想做但因为新业务太多而没有时间做的事情。比如弱网环境下的文件上传性能优化,微博私有通讯协议的优化,我们团队维护着的开源motan rpc框架对于微服务监控和调度能力的优化,还有最近微博越来越火的视频服务的后端转码服务、存储服务的性能优化,等等等等。这些只能期望来年搞定了。

The Ugly

程序员这个行业里的人大多数人不喜欢交际,我也一样。而实际工作中总有很多需要沟通的工作,而对于这部分工作实在是我的痛点。

而痛苦的来源主要来自于沟通时不在一个频段上,

  • 比如我问”为什么没搞定“,而对方的回答是:“我不会啊”。

  • 又或者我说“这么做的话会更合理”,而对方一直在强调:“我这么做能实现啊”。

  • 再或者我说“这里的需求明显不合理”,而对方只有一句:“老板是这么要求的”。

无论如何,跟人沟通是一件痛苦的事情,尤其是跟与自己三观不合的人沟通更是如此。今年也没少经历过拍桌子大吼的场面。虽然不想承认,但是很多人并不是真的想把事情做好;有一些人的“好”跟你的“好”不是一个衡量体系;有些人虽然意愿很强,但他是笨蛋;当然,还有又懒又笨三观还跟你不一致的……

如何跟人打交道是我今年反思最多的问题之一,作为一个与世无争(?)的程序员,我希望尽量少跟人起冲突,默默的多写些代码,但又不想自己因为要避免冲突,变成跟他们一样又笨又懒的人,尝试了几次之后发现日剧里那些“靠热情就感染了身边的人”之类的桥段是骗人的(要么就是因为我没长一张男主角的脸),与其苦苦挣扎着期望别人某天突然改变,不如找些志同道合的人在身边。值得欣慰的是,今年招到的小伙伴都是能够认可我的三观,有意愿和能力把事情做的更好的人。新的一年伴着新的业务悄无声息的来了,希望今年也能招到靠谱的人。

于是这篇年终总结终于被我写成招聘贴了……

=========以下是招聘贴===========

我们是谁

  • 我们属于微博平台研发部,负责微博通讯业务及视频业务的服务端开发和性能优化。

  • 我们立足于高性能、高并发场景下的架构设计,负载均衡、数据库、缓存和消息组件是我们的朋友,我们也是微博在高并发场景下对 redis 使用和改造最多的部门之一。

  • 我们目前正在维护微博开源的的 RPC 框架 Motan( https://github.com/weibocom/motan),目前 star 数在 2300+。

  • 我们参与微博基于 docker 的混合云建设,并基于混合云动态调度成功应对春晚峰值流量。我们在微博所有业务中首先全量应用 docker ,并且在不断的探索 docker 原理和解锁新姿势。

  • 我们最先将 Storm 应用于线上实时消息服务,实现每秒万级实时消息处理。

  • 我们持续研究和改进分布式存储,持续解决存储服务的容量及性能瓶颈问题。

  • 我们在真正的不断改善代码质量与开发流程,我们评价一个工程师的产出时的标准除了编写代码数量,还有删除代码数量:)

我们想要什么样的小伙伴

Java高级视频服务系统开发工程师(可实习)

岗位职责

  • 视频为微博未来的核心战略方向,服务端架构当前正在不断演进中以适应业务高速发展的需求。

  • 参与设计和开发微博视频后端相关服务开发,包括视频上传、转码、存储服务及直播互动系统等。

任职资格

  • 具备扎实的 java/golang /c 编程基础,对分布式系统足够理解;

  • 具备良好的编码习惯及较强的文档编写能力;

  • 良好沟通能力和团队协作能力,具有较强的工作责任心,快速学习能力,乐观积极进取;

  • 熟悉常见多媒体开源项目如 ffmpeg , mplayer , VLC 等优先;了解分布式存储服务原理优先;

  • 喜欢折腾,参与过开源项目者优先,做过与工作不相关的任意项目优先。

Java高级通讯服务系统开发工程师(可实习)

岗位职责

  • 参与设计和开发微博通讯平台高并发服务,如消息箱底层服务、移动通讯协议改造、流式消息处理服务等。

任职资格

  • 一年以上的工作经验,熟悉 java /golang/c 语言并参与或阅读任意开源项目;使用过更多语言优先。

  • 熟悉数据库、缓存等基础组件,有大规模在线服务开发经验优先。

  • 有 netty 、 docker 、 kafka 、 storm 、 hbase 相关经验优先。

  • 有钻研和探索精神,有任意类型的性能调优经验优先。

  • 喜欢折腾,参与过开源项目者优先,做过与工作不相关的任意项目优先。

Java分布式系统开发实习生

岗位职责

  • 微博开放平台架构的优化和改进,针对高并发,可扩展,高可用方向不断优化;

  • 参与微博开源的分布式 RPC 框架 Motan 的功能实现及维护。( https://github.com/weibocom/motan)

任职资格

  • 硕士研二以上,要求实习时间半年以上;

  • 具备扎实的 Java 编程基础,熟悉多线程程序开发,对多线程技术、异步、并发有一定理解。

  • 熟悉 linux 操作系统、熟悉 TCP/IP 协议;

  • 具备良好的编码习惯及较强的文档编写能力,熟练使用 git , maven ;

  • 良好沟通能力和团队协作能力,具有较强的工作责任心,快速学习能力,乐观积极进取。

  • 参与过开源项目者优先。

其它

  • 薪酬标准:实习 200/天,社招面议

  • 工作地点:北京西北旺软件园二期新浪总部

  • 简历请发送至 qindi@staff.weibo.com

-END-

欢迎关注“互联网架构师”,我们分享最有价值的互联网技术干货文章,助力您成为有思想的全栈架构师,我们只聊互联网、只聊架构,不聊其他!打造最有价值的架构师圈子和社区。

本公众号覆盖中国主要首席架构师、高级架构师、CTO、技术总监、技术负责人等人 群。分享最有价值的架构思想和内容。打造中国互联网圈最有价值的架构师圈子。

  • 长按下方的二维码可以快速关注我们

  • 如想加群讨论学习,请点击右下角的“加群学习”菜单入群

一名微博架构师的2016年终总结相关推荐

  1. 一名微博架构师的年终总结

    2019独角兽企业重金招聘Python工程师标准>>> 眼看着又一年结束,想想今年过的还真是快,上个画面还是去年年末各种处理故障的场景,一眨眼一年就过去了.既然过了一年,还是得留下些 ...

  2. 如何才能快速成为一名Java架构师?

    如何才能快速成为一名Java架构师?很多程序员从业2-3年后都会进入一个迷茫期,或是瓶颈期,不知道如何进一步提升成为一名Java架构师.解决这个问题其本质是知道如何学习才能快速成为架构师. 接下来我们 ...

  3. 2023年,我想成为一名前端架构师

    文章目录 前言 2022年对我个人而言,是很稳定的一年 2023年想要实现的计划 除了工作,再说些个人生活相关的吧 前言 从入职第一份前端开发的工作至今,快满三年.我也在不断思考,将来的出路和制定职业 ...

  4. 成长为一名Java架构师需要掌握的技术有哪些呢?

    Java架构师需要掌握的技术: 1.熟练使用各种框架,并知道它们实现的原理. 2.jvm虚拟机原理.调优,懂得jvm能让你写出性能更好的代码: 3.池技术,什么对象池,连接池,线程池--Java反射技 ...

  5. 如何把自己打造成为一名金领架构师-开悟篇

    在你开始这次阅读之旅前,花10秒的时间,想一想,截止到现在,你人生发展过程中,有哪些人对你的成长最重要?谁对你的影响最大?是一个人?一本书?一件事?一朵花? 在你人生悟道之前,所有走过的路,都是为了这 ...

  6. 如何成为一名高薪架构师?

    对于工作多年的程序员而言,日后的职业发展无非是继续专精技术.转型管理和晋升架构师三种选择. 今天,100offer从架构师在一家公司有多重要.优秀架构师需要具备怎样的素质以及架构师的发展现状三个方面来 ...

  7. 干货合集|如何做一名优秀架构师?进来找答案!

    架构师是一个承前启后的岗位,正如一个路由器,对各种业务需求加以分析处理后路由到下游产品和研发团队.那么,对于架构师来说如何给自己设立目标?又该如何管理好团队?并且快速掌握热点技术?我想这是大多数架构师 ...

  8. 如何成为一名Android架构师,乃至高级架构师,文末有路线图

    很多Android的小伙伴在做了多年的开发之后,始终搞不清楚达到Android架构师需要何种技能,我们对比着Android高级工程师来说明. 我们先来看一下Android高级工程师的招聘要求 职位描述 ...

  9. 长为一名JAVA架构师2017-10-16 2

    工作前三年是职业生涯中成长最快的几年,在这段时间里你会充满激情,做事专注,也容易养成良好的习惯.在我们公司有些同学在前三年中就快速成为某一个领域的技术专家,有些同学也可能止步不前.本文和大家一起探讨下 ...

  10. 对话阿里巴巴贾扬清:如何成为一名优秀的 AI 架构师?

    简介: 近期,我们邀请了阿里巴巴技术副总裁.阿里巴巴计算平台事业部总经理. AICon 全球人工智能与机器学习技术大会深度合作伙伴贾扬清光临 InfoQ 直播间,和近 7000 名用户分享了作为一名 ...

最新文章

  1. java gps时间转换工具_java 时间戳和时间互转工具 和 时间偏移量计算
  2. 静态方法-应用场景和定义方式
  3. docker+selenium web自动化测试环境的部署
  4. 来吧学学.Net Core之项目文件简介及配置文件与IOC的使用
  5. rest_framework04:ModelSerializer/Serializer高级用法
  6. C#获取网上图片的宽高代码
  7. Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:2.12.4
  8. 躲避校园网认证客户端的检测,开启笔记本热点的方法!
  9. java定时统计_java 定时任务每日晚上凌晨执行数据统计
  10. FlashFXP注册码-FlashFXP密钥
  11. 安装Scipy出错的解决方法
  12. Sword38——字符串的排列
  13. 安装VMware出现无效驱动器
  14. 文件服务器实现网络打印,图文详解 服务器共享打印设置
  15. 计算机一级win7win10,Win7/Win8.1升级Win10出现黑屏/蓝屏怎么办
  16. php如何调用protected,PHP中类作用域protected实例详解
  17. 语音转换成文本 技术实现_职业转换者指南,帮助您实现梦想的技术工作
  18. FPGA集成开发环境
  19. sql语句查询,多字段like模糊查询优化
  20. android 识别中文字体,在 Android 上高效准确的进行 OCR 识别,白描帮你实现

热门文章

  1. CentOS 6.X配置 NFS以及启动和mount挂载
  2. log4j容器初始化探究
  3. Java面向对象练习题之三角形
  4. [实变函数]2.2 聚点 (cluster point), 内点 (interior point), 界点 (boundary point)
  5. 《(学习笔记)两天进步一点点》(3)——应用BindingSource实现数据同步
  6. poj 1503 Integer Inquiry高精度
  7. 如何在 Mac 上禁用 Chrome 通知?
  8. 类 ACDSee图像浏览工具Lyn for Mac
  9. SwitchResX Mac屏幕分辨率调整工具
  10. ​​​​iPhone 或 Mac 忘记登录密码,怎么快速找回