老兵不死,只是凋零:前九枝兰架构师王晓辉
他曾是以一位人民教师,他是程序开发界的一名老兵,你可能没有听过他,他有着十多年的开发经验,先后在做过计算机老师,并且在私企、外企、互联网公司、创业公司里做程序开发和技术管理工作。
“惟正己可以化人,惟尽己可以服人。”他就是本期程序员客栈专访前九枝兰架构师:王晓辉,https://www.proginn.com/wo/60090
程序员客栈王鑫:我还是叫你老师吧,您先做个自我介绍
王晓辉:大家好,我是王晓辉,毕业后当过两年的高中老师,于2006年辞职到北京从事专业程序开发工作,至今已10年,先后在私企、外企、互联网公司、创业公司里做程序开发和技术管理工作。做过的项目包括个人PC安全软件、自然语言处理(KNLP)、移动电信联通网关业务、数字证书认证系统、安全数据代理软件、自动化营销SaaS系统,在Windows和Linux下均积累了丰富的开发和项目管理经验。
程序员客栈王鑫:像您应该很早就接触到开发了吧?能说说当时你们的大学生活吗?
王晓辉:现在想想还是很还念那时候的时光啊,我毕业于信阳师范学院计算机科学与技术专业,信阳师范学院只属于二本院校,所以名气不大,但学风很好,大学四年为我打下了扎实的计算机理论功底,再加上当时跟同学经常一起泡在学校外面的电脑培训班(学校里面的上机课严重不够啊)里学习各种编程技巧,从Basic到Pascal,再到C、Visual Basic、Visual FoxPro,到最后的C++/MFC,都自学自画的捯饬过。
程序员客栈王鑫:您都在哪些公司就职过,能分享一下吗?
王晓辉:2006年辞去老家高中老师的工作,只身来到北京,开始第一份纯技术开发工作,这是一家私企:北京卡斯特信息技术有限公司,既有自己的产品(个人PC安全软件),又做外包业务。我在公司里做了大半年自己公司的产品后,就被外派到日企佳能(Canon)公司,开始做一个韩文自然语言处理(KNLP)的项目,这一做就是两年多。
在这里,我首次经历了一个完整的项目周期——需求分析、概要设计、详细设计、编码、单元测试、系统测试、验收测试。我的C/C++/MFC技能在那里得到了一次质的提升,虽然之前看了很多的书和做了很多练习,但都跟实际的项目经验差别甚大。核心的底层模块都是用C语言完成的,而且要求跨平台运行,所以在这里也首次开始在Linux系统下做开发,首次使用VIM+GCC+GDB的组合方式来开发调试程序。
上层的UI是用C++/MFC/ATL完成的,以库的方式调用底层核心的模块。这个项目整整做了两年,在当时的我看来,这是一个很大的项目,用到了C/C++/MFC/ATL等编程技术,使用了模块化的设计,采用了典型的瀑布开发模式,从需求、设计、编码、单元测试、验收测试,到最终的产品发布,都给了我全新的体验。
KNLP项目完成后,我回到原公司,公司的情况已经不容乐观,本身的产品没有很好的市场,外包业务也在萎缩,再加上公司上层的组织架构发生了很大的变化,导致很多老同事纷纷离开。我在公司只呆了半年,零零星星的又做了一些小项目,也选择了离开。
后来就去了亿阳信通。亿阳信通有自己的软件园,有自己的办公大楼,有自己的餐厅,有自己的班车,算是一家很大的公司。
我当时去的部门,是做电信、移动、联通等网关业务数据分析,就是把硬件设备采集到的业务数据进行分析、存储、汇总、页面展现等。底层模块中很大一部分都是做数据分析处理的,但看了之后才发现,如此庞大的一个数据处理系统,全部构架在Perl语言之上的,可能当时架构设计者认为Perl是动态语言,易于开发,易于维护,易于扩展。这个想法原本也是不错的,但任何系统,当达到一定的规模后,易于扩展和易于维护都变得不再容易。我到现在仍然认为Perl语言并不是很适合构建大规模的软件系统,特别是在处理性能上存在瓶颈。在亿阳信通的两年里,除了后来为了特性性能做的一些C/C++分析模块,大部分都还是跟Perl语言打交道。
后来公司领导也觉得原先的数据处理系统在性能上差强人意,就让我们组针对特殊项目开发独立的数据处理模块,使用C/C++语言来完成。当时开发的数据解析程序是运行在Solaris系统上,我先在自己的Ubuntu系统上开发完成,然后再移植到Solaris系统上调试运行。因为Solaris系统跟我们平时使用的计算机CPU架构是不一样的,我们通常使用的x86架构的计算机,硬件编码的方式是小端(Little-Endian),而Solaris系统是大端(Big-Endian)。这也是当时开发过程中特别注意的一个方面,所以至今记忆深刻。
在亿阳信通的两年里,我开始接触开源项目,自己也尝试写一些开源的程序,比如Linux下GNOME/GTK图形库,就是在写开源程序的过程中掌握的,实际工作中并没有用到。当时还没有github,还是Google code的代码仓库。因为当时我醉心于Linux/Ubuntu, 所以开发的开源软件都是运行在Linux/Ubuntu之上的。
后来,公司要跟IBM进行战略合作,但雷声大雨点小。我们项目组按照部署要跟IBM进行合作,对他们的业务质量管理产品做二次开发,满足国内业务的需求。但合作进展缓慢,有一段时间几乎无所事事,浪费青春啊,是时候要离开了。
我接着加盟的公司叫吉大正元信息技术股份有限公司,总部在长春,我入职的是它的北京研究院。当时吉大正元正准备开发一款数字证书身份认证与数据代理网关的产品,刚好在搜罗人才,而我也刚好从亿阳信通离职,很快就受邀加盟了吉大正元的北京研究院。我入职的第二个星期,整个研发团队就被拉到怀柔雁栖湖畔山脚下的一个小楼开始了封闭开发,没想到一呆就是五个多月。提起封闭开发,可能很多人会觉得很苦很枯燥,但后来跟一起封闭开发过的兄弟谈起,都很怀念那段时光。封闭开发相当于给程序员们提供了一个理想的编程环境,尽量排除外界因素的打扰,全身心地专注在产品研发上。这对于程序员的职业成长来说,实际上是一件幸事啊。
产品主要是使用C、C++和Java完成——服务端核心代理模块使用C完成,后台管理和登录会话管理模块使用Java完成,客户端使用C++/MFC/ATL完成。当时公司决定在这次封闭开发中采用敏捷开发模式,还专门从外面请了敏捷教练进行全称培训,这也是我首次接触敏捷开发理念和敏捷实践,像迭代开发、故事墙、每日站立早会、结对编程,代码集体所有权、自动化构建,自动化部署,自动化测试等等,都为我们打开了一个全新的视野,让我看到跟之前传统的瀑布开发模式完全不一样的开发流程。所以说,在封闭的这半年里,是我职业生涯中又一个快速提升的关键期,可以跟在佳能研发中心的那两年相媲美。
封闭开发结束后,网关产品的核心功能都已完成,之后就是对产品不断完善和修复bug的过程。在这一个过程的开始,就已经把产品推向了市场,然后不断的完善功能,修复Bug,以快速迭代的方式发布新版本。这就是敏捷中快速发布,而不像传统的软件发布那样等一切就绪了再发布产品。传统的软件发布反应迟缓,错失机会。而敏捷的发布模式却可以在核心功能和最小需求完成的情况下,快速推向市场,让市场和用户来检验产品,提出新需求,发现问题,从而快速有效的完善产品,持续不断的发布新版本。
在吉大正元北京研究院的三年零五个月的职业生涯中,我又一次收获了很多。我接触和学习了敏捷开发理念,掌握和实践了敏捷开发活动,分析和掌握了很多的网络协议,对网络编程的理解和实践达到了一个新的高度,对Linux下的大并发多线程高性能的服务器开发有了深刻的理解和项目积累,对Linux的防火墙iptables的使用开始得心应手,对一些开源软件——apache, openssl, openvpn的借鉴让我的设计能力得到了很大的提升。是吉大正元又一次把我推上了一个新的高度,我很感谢这家公司。
后来,产品推向市场后,经过多次的迭代开发,趋于完善和稳定。而我又一次选择了离开,我就像永远走在路上的朝拜者一样,只在某处逗留几天,但终会再一次出发,走向远方。
这一次,我决定再给自己一个新的挑战——进入纯粹的互联网领域,加入纯正基因的互联网公司。我离开吉大正元的时候,北京九枝兰信息技术有限公司刚成立三个月,做互联网的自动化、一站式营销平台,刚好当时的CTO找到了我,邀请我加入。CTO是个很有情怀的人,跟他谈的很投机,可谓一拍即合,于是就选择了加入九枝兰。
我时常对自己说:只要用心去追求,总会收获不一样的风景。在生活中如此,在职业生涯中也是如此。在九枝兰这两年里,我完成了我职业生涯的三级跳:
第一跳是在佳能研究院做KNLP项目时,让我经历了完整的瀑布开发模型;
第二跳是在吉大正元北京研究院做G3000产品时,让我经受了敏捷开发模式的洗礼;
第三跳就是在九枝兰,让我融入了互联网的基因,全程设计和开发了基于微服务架构的云服务平台。
在这两年里,我首次使用并熟练掌握了新的编程语言——Go,之前的产品和项目主要都是基于C和C++进行开发,而Go语言作为互联网时代的C语言进入了我的视野,而且让我欲罢不能,这两年开发的大部分代码都是使用Go完成的。我首次在大规模云服务平台上使用微服务(Micorservices)的架构模型,紧跟了互联网时代的设计思想。我们的团队也在云服务中引入Docker的实例管理,让云服务的构建和部署更加的轻巧和灵活。还有公司扁平化和自组织的管理模式,也让开发管理变得更为简单高效。所有这些,都是九枝兰带给我的丰收硕果。
以上就是我差不多十年工作的一个经历和总结,现在回顾那段激情燃烧的岁月,我只想说:“不后悔。”
4,程序员客栈王鑫:你参与的项目能否做一些简单的介绍?
王晓辉:
MarketinGoS一站式营销系统—— 集成了搜索引擎投放、搜索引擎优化、微信、微博、H5模板、着陆页、邮件、短信、DSP、广点通、APP 消息推送等多个推广渠道,结合用户管理、营销活动管理、营销自动化、渠道分析、用户分析、数据分析等功能,帮助企业主提高效率,节省营销成本。
项目使用的主要编程语言有: Golang、Python、Java、PHP、Javascript。
项目使用的关键技术有:RESTful API、Thrift、Apache Kafka、NSQ、Docker、MySQL、MEAN等。
身份认证与数据代理网关G3000—— 吉大正元自主研发的基于数字证书身份认证和安全数据代理的内网安全产品,主要针对国内对内网安全要求比较高,需要进行身份鉴别和权限控制,而且对数据在传输过程的安全有极高要求的企事业单位。
项目使用的编程语言:C、C++、Java。
项目使用的关键技术:TCP/IP/SSL/HTTP、Sock5、Apache、Openssl、Openvpn、Netfilter/Iptables、TUN/TAP、MFC/ATL/STL、Windows NDIS驱动等。
自然语言合成系统KNLP—— 该项目是佳能自主研发的一个韩文自然语言处理系统,要对韩文的语言文字做语音合成处理,最终要用于佳能的硬件设备上,如相机、复印机等。
项目使用的编程语言:C、C++。
当时做项目还很少使用开源库,所有的功能模块全都是用代码纯手工打造出来的,所谓的软件匠艺,在早期的项目中反而有更好的体现。
5,程序员客栈王鑫:对你来说一名优秀的项目经理需要具备什么样的硬实力?
王晓辉:作为一个项目经理,我觉得首先要了解技术,不要求对技术多么精通,那是程序员做的事情,但作为一个项目管理者,如果对自身项目使用的技术领域不了解的话,可能就会两眼摸黑、盲人摸象,在管理过程中沟通的效果就会大打折扣。
其次就是要对项目的风险因素有一个清晰的把控。项目的时间安排上是不是充足?人员安排上是不是到位?关键技术上是不是有瓶颈?团队成员的工作状态是不是很好?把这些因素一一的考虑到,如果有风险要及时的进行调整。比如项目实际的进度慢了,是什么原因造成的?是开始的时候时间估算就不准确,还是因为遇到技术瓶颈进展缓慢,还是因为团队成员士气不振出活不多?根据实际的情况分析出原因找到解决的办法。
其次就是团结的能力。项目经理就是项目的粘合剂,把所有的项目成员粘结在一起,把一个共同的目标完成。这个过程中,团队成员之间可能会出现各种各样的沟通问题,甚至跟你这个项目经理之间也会产生分歧,这时候怎么办?就需要项目经理放低姿态,不要自认为是一个管理者,而是一个兄长、一个朋友的身份,设身处地的为对方考虑,沟通到位,把问题说开辨明。大家最终的目标都是一致的,在路途中某些人稍微偏离了一点,就要及时的把他们拉回大家一起的道路上,共同向目标进发。
6,程序员客栈王鑫:在外包公司工作和在互联网公司工作最大的区别你觉得在哪里?
王晓辉:外包公司和做自己产品的互联网公司我都经历过,所以我就谈一下自己的感受吧。
作为一个程序员的职业成长来说,并不能说在什么样类型的公司发展孰好孰坏,没有一个绝对的标准。关键还是看你自己在这个过程中是不是得到了成长,学到了有价值的技能。而这一点在两种类型的公司中都可以做到。
就比如我在佳能做KNLP项目时,就属于外包性质的,但那两年却是我职业发展提升很快的一段时期,让我至今受益匪浅。再比如我在吉大正元和九枝兰,都是做自己公司的产品,同样也是成长最快的一段职业发展时期。
但总体上,在互联网公司做自己的产品还是要强过做外包项目,主要的原因是做自己的产品,你基本上可以更深入、更持久、更全面的进入这个项目,自然而然学到的东西就会更多一些。而外包项目要看项目,如果你碰到一个好的项目,就像我在佳能参与的KNLP项目,而且外包方对你非常信任,让你接触核心的技术领域,那也是很不错的。
7,程序员客栈王鑫:就以你个人而言,比较擅长哪方面项目开发?你都有哪些优势?
王晓辉:我比较擅长云服务、数据安全和代理、微信公众号平台、企业微服务等类型的项目开发,在这些方面都有过实战经验。我个人的优势在于做过多年的安全产品,对数据安全和网络协议栈非常了解,这两年又专门做基于微服务的云服务平台,所以对后端服务的技术架构也非常了解。因为做过的项目类型比较多,所以在项目的实施过程中就可以参考借鉴别的项目中的长处,好的技术架构,好的管理模式。
8,程序员客栈王鑫:你平时除了项目开发还有哪些兴趣爱好?
王晓辉:我除了本职的技术开发和技术管理工作外,平时还喜欢跑步、游泳、骑行、爬山和读书,现在基本上要求自己每周跑两次步、游一次泳,至于读书每年会选择一些优秀的书籍读上10本左右。
9,程序员客栈王鑫:在这么多年的职业开发生涯中,都遇到过哪些巨大的挑战?
王晓辉:经历过这么多的项目开发,总会遇到这样那样的困难和挑战,现在想来很多都不是什么大不了的事情了,但在当时还是需要咬咬牙关挺一挺。
我记得在吉大正元做G3000产品封闭开发期间,封闭了5个多月,前期按部就班还算正常,但到了后半段,因为封闭时间太长,有些同事情绪上就出现了一些问题。有一个小伙伴刚好因为家里也出现了一些状况,就突然提出了辞职,要求退出封闭开发,他是客户端开发团队的成员,而当时客户端开发正处于紧张的时期,人手本来就不富足。这样一来肯定会影响整个开发进度,后来就决定征调一名服务端开发团队的人来顶上。
我当时就属于服务端开发团队的,而服务端开发进度正常,本来可以轻轻松松地完成封闭开发任务。我跟另一个哥们就被征询意见:看谁同意调到客户端来?那哥们是死活不同意,说是对客户端开发不熟悉。好吧,那我就上吧。反正记得刚接手客户端那阵搞得晕头转向啊,已经开发了很多代码,首先要先熟悉这些代码,才能继续在上面做开发,在加上本来任务就重,就只能加班加点的赶啊。反正最终呢,还算是皆大欢喜,封闭开发的任务基本都完成了,公司后来对封闭开发的人员都做了奖励,也算是我们的辛苦有了回报。
其它项目中遇到的困难和挑战不一而足,总体上属于临危受命性质的,反正困难来了,你硬着头皮,咬紧牙关顶住,总会柳暗花明的。而这种时候也正是你成长最快的时候,正所谓百炼钢才能化为绕指柔,不经过千锤百炼,怎么能够成为无坚不摧的利器呢。
10,程序员客栈王鑫:你如何看待未来共享经济环境下程序员自由工作的前景?
王晓辉:共享经济就是将闲置的资源共享给别人,提高资源的利用率,并让共享资源的人从中获得回报,共享经济的本质就是互助+互利。
未来的工作模式将是由独立的个体相互自由连接而成的一个既松散又紧密相连的网络。正如凯文-凯利在他的《失控》中所阐述的思想:有机的活系统,依赖于分布式的自管理的子系统,而各个子系统又依赖于分布式的自管理的个体,没有中枢,没有一个统一的自上而下的管理,每个个体相互联系,相互反馈,相互协作,创造了一个生机勃勃、充满活力的有机活系统。看似杂乱,却有条不紊地运转。
而作为共享经济下时代的弄潮儿——程序员,有着自身独特的价值优势。首先程序员的知识技能非常有利于在互联网环境下分享;其次程序员这种群体的气质非常独特——追求自由独立而又相依相存,恰好符合共享经济的特质。
再有就是互联网的发展阶段已经为共享经济的繁荣提供了基础设施。共享经济并不是什么独创性的概念,也很容易理解,但为什么前二十年、前十年没有喊得这么响,没有这个突飞猛进?那是因为原先的个体互联互通的基础设施——互联网还不够完善,还不足以支撑起共享经济这个平台的搭建。而现在互联网的发展已经渗透到社会发展的方方面面,任何人不接入互联网就相当于跟时代隔绝了,所以共享经济的基础设施已经完备。
应运而生的,各种共享经济平台如雨后春笋般纷纷出现,程序员客栈正是这里面的优秀代表——针对程序员的共享经济平台。程序员不再局限于自己的公司、自己所处的区域,在任何时间、任何地点,只要你有了闲置的时间,又愿意把自己的技能分享出去服务于别人,就可以接入这个共享经济平台,获得回报。同时你的视野将放眼全球,你所做的项目可能在异国他乡,你一起的工作的队友可能在千里之外,你们之间通过这绵绵不绝的网络相互连接,同时连接这个世界。
这就是未来工作的前景,我期待着美好生活的到来!