Serverless往事(一):从零搭建一个web应用

Serverless往事

我想单独开一个叫《Serverless往事》的topic,讲述从2018年年初开始我们“艰难探索”新架构的一些故事。Topic会不定期更新,希望能一直更新到一个大型网站的面世。

背景

18年初,突然得到领导通知,要起一个serverless的web应用。当时并不清楚具体缘由,只是隐约听说原先架构成本过高已无力支撑产品上线。一番调研后,海外的某个组首次实践了serverless并获得巨大成功。大中华区CEO很快通知我们,要在中国推广aws serverless。

当时的情况极为尴尬:除了一些朴素的java知识,全组甚至全厂都没有粗通架构的后端;前端也极为原始,几乎没人接触过三大框架;CI/CD,更是无从谈起。最大的困难是:我厂只做B端,对Internet网络攻击毫无抵抗力。然后,我们接到了任务:搭建一个叫E-pub的互联网web应用。一个新时代就这样开始了。。。

业务分析

E-pub是我所在某招聘相关产品组的一个子模块,主要面向互联网端的应聘者。业务流很简单:应聘者通过E-pub录入个人信息,并向雇主申请Job。雇主在企业内部HR系(姑且叫IVF吧)能及时同步应聘者申请。主要页面其实就两个:1. 隐私条款 2. 用户信息录入页面

  • 性能

    设计之初,我们开发的是ST模式(single tenant)的E-pub。就单个Tenant来说设计用户不会超过1万人。以每天8小时计算,TPS峰值也就个位数,因此性能并不复杂。数据库的话,Dynamodb也能胜任了;Web服务用api gateway + lambda就搓搓有余。因此,我们不需要自找麻烦去讨论MQ、Redis、Zookeeper这类大型应用。

  • 可扩展性

    E-pub功能很简单,几乎不会再扩展了。

  • 可用性

    E-pub晚上几乎不会有人访问,即便是白天,宕机几个小时其实也不会有太大影响。复杂均衡、异地多活这类方案就免去了。但是数据丢失可能比较麻烦,因为雇主和应聘者之间本没有联系方式,数据丢失意味着永远失联了。所以搭建数据库的话必须考虑主备方案。

  • 安全性

    E-pub包含应聘者个人信息,有一定的隐私性;但是不会包含密码、银行账户等信息。只需要控制访问权限并及时清除线上数据就行了。

  • 成本

    系统很简单,有一个主备从的数据库和一个简单的服务器就能搞定。

技术栈

业务确定后我们立马讨论了技术栈的选择。

  • ExpressJS

    我果断放弃了java,主要原因就是冷启动太慢了。E-pub只是先期项目,我们后续有更复杂的业务。当时lambda会在无响应5分钟后自动关机(现在已变)。从我们已有的IVF项目中得出的经验是,Java服务调用➕冷启动很容易突破这个限制。于是我果断选择了node js。其实说来也惭愧,组里除了会java和js,没人会别的语言了orz

    Nodejs最出名的框架是Express,它的启动时间极端;后来在生产实践中也得到验证:最慢一次lambda冷启动时间也就800ms。在同期实践的其他serverless项目中,竟然有几十秒冷启动的服务。

  • NuxtJs

    前端框架的选择没有争议,国内vuejs具火,我们也不免俗套。由于当时缺少技术积累,我选择了NUXT——VUE的SSR框架。NUXT集成了VUE全家桶里主要的插件,自带webpack,几乎零配置就可以上手。不过后来也被NUXT坑了一把,这是后话了。

  • DynamoDB

    DB是Department Manager指定的。IVF系统用了NoSql的cassandra,转到serverless后竟也保持了这种传统(虽然cassandra作为主数据库已被无数人吐槽)。

Technical stack

Architecture Review

两个礼拜后,我旁听了组里领导和arc team的Review,依稀记得对方来了两日本人和一个印度人。不得不佩服我领导,他和对方leaders谈笑风生,独留我一人茫然无知,大概是我听力实在是太差了吧。两次review会议后,E-pub得出了大体如下的框架。

Architecture

架构很直白,服务部署在lambda上,应聘者只能通过api gateway读取Job信息,并录入个人信息;IVF(对的,是我们的那个内部HR系统)轮询E-pub,同步信息后删除Dynamodb和S3里的记录。

回过头来看,这个设计甚至不如一个学生管理系统复杂,不过在E-pub场景里却是一个很务实的选择。

说点闲话,汉语语境里保守激进都带明显的贬义性质。很多人喜欢评论别人的技术选型太保守或是太激进,然后沾沾自喜一番。但是评价者自身没有技术判断力呢?架构的选择也是如此,其实并没有保守或是激进之说,简单务实才是最正确的选择。

小结

到此为止我们的E-pub正式进入开发阶段,虽然系统简单但是五脏俱全。之后我们仅仅用了一个多月就搭起了这个web应用,对比IVF年复一年的跳票,不得不说serverless带给了我们巨大的惊喜。总结起来大约有这么几点优势:

  • 开发环境:我记得当年首次启动IVF环境花了整一周;E-pub的话,傻瓜操作 yarn dev
  • 开发体验:启动快、热加载、部署简易
  • 开发成本:第一月的消耗只有十几刀,对比IVF系统空跑的成本就是大几千刀每月

不久之后,我们迅速开启了另一个新项目——M-pub。这次挑战更胜从前,更复杂的web安全、DB读写限制、MT、微服务治理、CI/CD……世上并没有一劳永逸的框架,更没有放之四海皆准的技术。我们又该如何抉择,to be continue...

后话

有一次我向某日本领导请教技术栈的问题,她道出了一些很有趣的事。领导们并不关心技术,更不关心开发体验,他们只想要一个低成本的产品。这些话让我茅塞顿开:对于底层小职员来说,我们追求新技术是因为技术是安身立命的本钱;但领导们不是,他们讲的是管理,要的是可控。从某种意义上来说,正确理解领导的意图其实也是我们底层小职员安身立命的技能。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容