漫画 | 一口气搞懂 Serverless !

简介: 第二届云原生编程挑战赛为热爱技术的年轻人提供一个挑战世界级技术问题的舞台,希望用技术为全社会创造更大价值。

作者 | 刘欣

呃,我可能是别人眼中所说的不用奋斗的一代。

大家喜欢听的什么多姿多彩的生活,我都经历过一些些。

Dingtalk_20210923095755.jpg

我家里开的是连锁超市,主要集中在几个二线城市。

在我上小学的时候,各连锁店里开始装电脑,购置并安装了完整的收银设备。

我爸说要向那些大的连锁超市学习,提高生产效率。

Dingtalk_20210923095826.jpg

那个时候我对那些灰色界面的收银软件很感兴趣,可惜爸妈不让我碰。

后来他们给我买了电脑,当时小镇上有电脑的人家不多,亲戚的小孩也常常跑到我这儿来玩电脑。

Dingtalk_20210923095842.jpg

也正由于和电脑接触得早,上大学时就选了计算机专业。

我才刚上大学没几个星期,我爸就问我:

Dingtalk_20210923095902.jpg

那个时候我连数据库什么的都还没有个概念,还在学反码补码,我告诉他:能,但现在不行,等我一两年。

我爸说不要紧。按照他的思维,我们不需要完全会写,只要明白怎么写出来就行,具体的实现我们可以交给软件公司做。

但搞明白软件是怎么造出来的很重要,因为这能够帮助我们在购置软件时站在供应商的角度思考,知己知彼,缩小我方信息差。

做买卖本质上玩的就是这一套。

Dingtalk_20210923095924.jpg

2005年,我大三,学校要搞一次软件开发大赛,一共有三个命题,其实基本涵盖了所有场景,学生可以自由发挥。于是我就想到了超市的收银软件。

当时淘宝刚火起来,我想为啥不学习一下呢, 彻底革新我爸的商业模式,从线下转到线上!

整个网上商城, 浏览商品,购物车,下单,配送,但我们主要卖的是自己的货源。

Dingtalk_20210923100013.jpg

当时用到的技术是 MySQL+ Java + JSP,然后自己买了服务器让服务跑起来。

在学校演示这套系统时,我拿了最高的成绩。

Dingtalk_20210923100034.jpg

满心欢喜之余,我尝试把这套系统用到实际业务中,先从自家的总店开始试点。

没想到我爸给我泼了一盆冷水,他说我们这里的用户没有上网购物的习惯,送货问题没法解决。

Dingtalk_20210923100053.jpg

我不服,非要尝试,果然理想与现实间存在着巨大的差异,我跌了一个大跟头。

虽然我搞了很多活动,发传单宣传商城,但真正上网购物的寥寥无几。

有些愿意尝鲜的,在网上买了东西,都是我亲自开车送货的。

Dingtalk_20210923100109.jpg

毕业回家,我本想出国留学,但被我爸拽了回来, 我先跟着信息部的负责人老张学习,然后慢慢接班。

当时家里的每个超市都很大,都有一二十台 POS 机, 每个超市有一台服务器,一个数据库。

POS 机直接连到本超市的服务器上, 典型的客户端/服务器结构。

在那个时代,我估计大家都是这样的吧!

Dingtalk_20210923100123.jpg

说实话,这样的软件架构表面看似挺稳的,只要机器不出问题,稳定供电,整套收银系统就没有问题。但实际上面临着许多缺陷:

1. 机器是真的会坏的,而且真的有坏过的案例

2. 每次有商品数据要更新都要通知每一家店的管理人员进行更新,出现纰漏是很正常的

3. 更新软件的时候,工程师需要到各个现场配置,更新4. 各个店面统一数据困难,每个月统计数据的时候需要统一汇总,不能随时随地得知当前各分店的数据5. 等等......

每一家店单独运作一套系统,这缺点要是列下去就没完没了了

我建议老张搞个中央机房,把软件集中化,每个门店都连接到统一的机房服务器,这样就把上面的问题给解决了:

Dingtalk_20210923100136.jpg

后来的系统改造,经过投标、招标,我们选了本地一家颇有实力的公司来做。

我发挥了计算机专业的优势,帮助老张发现了不少问题。

看来我爸说的是对的,缩小信息差很重要。

Dingtalk_20210923100200.jpg

中央机房运作了几年,效果不错, 不过自家的机房管理起来非常麻烦。

平时需要仔细规划、购买服务器,需要安装软件, 需要负责运维,我们还专门建立了一个团队来应对这些事情。

Dingtalk_20210923100238.jpg

更可气的是黑客攻击无处不在

Dingtalk_20210923100317.jpg

还有就是宕机、断网,一出事就是大事,影响所有的超市,我在半夜不知道被叫醒了多少次。

这还不算啥,有一年为了配合超市双11 期间促销,我让我爸一下子买了好多服务器,双11 过后,全部闲置了,把我爸气得够呛。

Dingtalk_20210923100349.jpg

所以当阿里云出现的时候,我两眼放光,这简直就是为了解救我而设置的。 

马上、立刻、全面上云。

Dingtalk_20210923100409.jpg

操作系统会按照你的要求自动给你安装好。网络自然不用操心, 要多大带宽直接买就行。

安全问题也不用操心,如果出了问题,我就可以理直气壮地给我爸说:你看,这不是我的问题,是阿里云的问题,哈哈。

而且机器能很方便地扩容,CPU 核心从 4 核到 8 核,内存从 16G 到 64G......

从此以后,我们的机房中的服务器要下岗了。

Dingtalk_20210923100427.jpg

转眼间,十多年过去了,伴随着超市 IT 系统的发展, 我也从一个用 JSP 写网上商城的少年成长为公司的技术领头人。

技术在不断变迁, 小程序兴起,我们也跟着做了小程序,用优惠信息吸引顾客扫码关注、注册,慢慢地积累了几百万粉丝。

每个月我们都在小程序给会员发送优惠券,可以在线下门店消费。

没想到这下可惨了,抢购优惠券的请求量很难准确估算,也就很难预估需要准备多少台虚拟机来应对。

Dingtalk_20210923100444.jpg

Dingtalk_20210923100458.jpg

我赶紧发动我所有的关系去解决这个问题,一个偶然的机会,我发现了一个新技术:函数计算, 即 Serverless。

Dingtalk_20210923100553.jpg

平台会根据请求的数量来创建对应的函数实例来执行,无需人工干预,瞬间弹性扩容,应对流量爆发。

在中国,谁家的 Serverless 技术最强呢?

权威咨询机构 Forrester 发布的报告显示, 阿里云函数计算凭借在产品能力、安全性、战略愿景和市场规模等方面的优势脱颖而出,产品能力位列全球第一,这也是首次有中国云厂商进入 FaaS 领导者象限。

Dingtalk_20210923100624.jpg

正好我们之前用的也是阿里云的虚拟机,就是它了!

Dingtalk_20210923100702.jpg

除了函数计算外,由于业务需要查询会员数据库,我们希望它也能无缝弹性扩展,于是就使用了阿里云的表格存储。

上了这套 Serverless 的系统, 再也不用考虑服务器,虚拟机用多少 CPU,多少内存了,弹性十足!

函数部署也特别简单,完全不需要考虑底层的细节,一键更新函数就搞定。

当年的双十一度过得非常平稳,事后进行成本估算:以前买云服务器的时候,会按照可能遇到的最高并发量进行性能评估,由于 Serverless 是按量计费,用多少花多少,最终评估下来,当年在成交量增加 120%的情况下,成本比往年节省了 45%!研发交付效率提升也超过 30%!

Dingtalk_20210923100723.jpg

从那以后,我爸对我刮目相看,看我的眼光都温柔了不少。

Dingtalk_20210923100736.jpg

当然,除了技术之外我还是很关心业务的,贴合各种当代的新潮玩法。前不久给公司搭了个直播间,在平台上促销自己的商品。

Dingtalk_20210923100745.jpg

后来想了想,自己玩没意思,我尝试联系了超市附近各行各业的商家,邀请他们加入我的直播间,一起唠嗑卖货。其实当时没多少店家搭理我,唯独一家洗浴中心的老板对这个感兴趣。不得不说,那洗浴中心的老板唠嗑能力极强,和我算是棋逢敌手。

第一次直播时,我们连锁超市和洗浴中心各家分店搞了一次联合优惠活动,但当晚直播竟然从卖货推销变成了讲相声。

Dingtalk_20210923100756.jpg

直播我们每周举办一次,越来越多网友闻声而来,成交的订单数也越来越多。直播当晚的成交量甚至能抵上过去一周的总量。

直播过程中总有热心的网友主动连麦, 从技术上来说,就需要把多个网友的画面接入,和主播的画面合成一个新画面, 这叫“混流”。

Dingtalk_20210923100807.jpg

由于连麦的观众不固定,我得考虑一定的并发和弹性,我们的相声直播一周才一次,不可能去储备大量服务器去应对业务的高峰期。

Dingtalk_20210923100815.jpg

之前尝过 Serverless 的甜头,这次我立刻让研发部采用阿里云函数计算来处理混流的需求。

当并发量上升时,函数计算自动扩容多个执行环境来处理实时数据流, 当业务高峰期过去后,自动缩减资源,非常爽。

Dingtalk_20210923100826.jpg

当然,Serverless 的应用不仅仅是这些,还有我们的“相声”视频需要做转码,优化推流,我也用了阿里的函数计算,节省了 60%以上的计算资源。

这两年,我是深刻地体验到了 Serverless 的好处:完全不用考虑服务器的事情,集中注意力实现自己的业务逻辑就好!

这么多年,一路走来,技术在不断变迁,今年我有幸被母校的计算机学院邀请去作分享,我给大家分享了这些年的技术历程

Dingtalk_20210923100838.jpg

演讲期间,我提起了当年大学的那个编程比赛,那也是我编程生涯的起点。

正好,我知道阿里云举办了一个云原生的编程大赛,我也想把这项赛事分享给朋友们:这个大赛 2015 年就有了,那时候叫做中间件性能挑战赛,已经有 7 年历史了, 去年升级为云原生编程挑战赛,共吸引了超过 23000 支队伍,覆盖 10 余个国家和地区。

Dingtalk_20210923100852.jpg

大赛为热爱技术的年轻人提供一个挑战世界级技术问题的舞台,希望用技术为全社会创造更大价值。

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

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

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

相关文章

OpenKruise v0.10.0 新特性 WorkloadSpread 解读

简介: 针对需求,OpenKruise 在 v0.10.0 版本中新增了 WorkloadSpread 特性。目前它支持配合 Deployment、ReplicaSet、CloneSet 这些 workload,来管理它们下属 Pod 的分区部署与弹性伸缩。下文会深入介绍 WorkloadSpread 的应用场景和实现原理…

CSS 状态管理,玩出花样了!

作者 | 零一来源 | 前端印象CSS用于交互的方式无非就那么几种:伪类::hover、:link、:active ...动画:animation过渡动画:transition这些交互方式组合起来,真的可以玩出一些花样,例如我们本文的主题&#xf…

告别Kafka Stream,让轻量级流处理更加简单

简介: 还在花精力去选型Kafka组件去做清洗转化?来试试Kafka ETL任务功能! 一说到数据孤岛,所有技术人都不陌生。在 IT 发展过程中,企业不可避免地搭建了各种业务系统,这些系统独立运行且所产生的数据彼此独…

元宇宙“性骚扰”现象频出,Meta推出“个人结界”能保护好女玩家吗?

作者 | 小码君来源 | 抓码青年元宇宙,可以说是最近最炙手可热的概念了。各大厂纷纷入局元宇宙,Faceebook甚至将总公司名字都改名为Meta。不过盯上元宇宙的可不止资本大鳄,还有一些不怀好意的色狼。据外媒报道称,在Meta的Oculus设备…

【CDS技术揭秘系列 01】阿里云CDS-OSS容灾大揭秘

简介: 本文主要阐述 CDS 产品中 OSS 服务在容灾方面的部署形态以及实现的其本原理。 容灾功能可以保证用户一份数据在多个地方存在冗余备份,当某个机房出现极端异常(比如物理损毁)情况下,数据也不会出现丢失&#xff1…

如何促合作共赢?技术人的一点经验分享

简介: 本文作者将通过与詹韦团队一起合作的《树懒平台》,分享在工作过程中,我们什么情况下会有合作诉求?有了合作诉求之后,如何寻找对的人?锁定候选人之后,如何打动对方促成合作?合作…

不记得 Git 命令? 懒人版 Git 值得拥有!

作者 | Eason来源 | 程序员巴士Git的强大是所有开发者都心知肚明的事情,但是其多样的命令令人很是难受。不过在Github上有着这么一个开源项目lazygit[1]。Lazygit是由Jesseduffield开发并维护的项目,其代码托管在Github。通过使用Lazygit,我们…

Dubbo3.0|阿里巴巴服务框架三位一体的选择与实践

简介: 服务框架就像铁路的铁轨一样,是互通的基础,只有解决了服务框架的互通,才有可能完成更高层的业务互通,所以用相同的标准统一,合二为一并共建新一代的服务框架是必然趋势。Dubbo3.0 是 Dubbo2.0 与 HSF…

全球首款乘云而来的存储产品CDS诞生!

9月22日,阿里云发布全球首款“云定义存储”(Cloud Defined Storage,CDS)产品。作为一款本地部署的分布式存储产品,阿里云CDS拥有与公共云存储相同的技术架构,让企业客户在本地也能部署和使用与公共云一致的…

性能提升3倍、时延降低70%,阿里云企业级存储ESSD云盘再升级!

9月22日,阿里云存储年度新品发布会上,阿里云基础产品资深产品总监陈起鲲发布了其全球领先的旗舰级块存储产品ESSD的两款新规格(ESSD Auto PL、ESSD PL-X),并宣布了新增的多项企业级能力。 据了解,ESSD是阿…

一图看懂,什么是“云定义存储”

世界的诞生是从盘古开天辟地开始 而数据的存储 则由在龟甲上刻下的第一个字开始 经过数千年发展 数据存储也从最初的 龟壳、竹简等材料逐步进化到磁带、硬盘甚至云上 在之前几千年里 人们对于数据存储的需求并没那么高 仅仅通过纸张就能将所有数据记录下来 随着第一台计算机面…

Android 13 第一个开发者版本来了,网友直呼:Android 12 还没玩透!

整理 | 苏宓出品 | CSDN(ID:CSDNnews)2 月 10 日,Google 宣布 Android 13 首个预览版面向开发者开放,此版本重点聚焦隐私和安全、提供开发者生产力、应用兼容性,并保持与 OpenJDK 11 更新一致、提供主题图标…

「技术人生」第6篇:技术同学应该如何理解业务?

简介: 本文以大量理论论述解析业务,并提供多种基于不同场景的实操方法,帮助技术同学以科学、合理的方式开展日常工作、指导团队开展业务建设,保障顶层设计的落地执行。 一. 背景 目前已经发布《技术一号位的方法论》系列文章其实…

参数设置_变频器基本参数设置

工业设备的使用如何达到最大效能以及最佳效果,需要使用人员充分了解设备性能以及工艺要求,所以变频器参数设置或者优化是非常重要的环节,古人云失之毫厘差之千里就是这个道理。一、变频器基本参数设置参数设置可以是手持编程器操作&#xff0…

Morphling:云原生部署 AI , 如何把降本做到极致?

简介: Morphling 本意是游戏 Dota 中的英雄“水人”,他可以根据环境要求,通过灵活改变自身形态,优化战斗表现。我们希望通过 Morphling 项目,实现针对机器学习推理作业的灵活、智能的部署配置改变,优化服务…

datax参数设置_DataX Web数据增量同步配置说明

一、根据日期进行增量数据抽取1.页面任务配置打开菜单任务管理页面,选择添加任务按下图中5个步骤进行配置1.任务类型选DataX任务2.辅助参数选择时间自增3.增量开始时间选择,即sql中查询时间的开始时间,用户使用此选项方便第一次的全量同步。第…

Node18 即将支持 import HTTP资源!

作者 | 零一来源 | 前端印象最近看到Node官方提交了一条commit ,并且已经合入 master分支 ,如下图所示:node master commit由此可见,Node18可能会支持一个非常 nice 的功能,那就是 支持 import 远程HTTPS资源和本地的H…

MYSQL深潜 - 剖析Performance Schema内存管理

简介: 本文主要是通过对PFS引擎的内存管理的源码的阅读,解读PFS内存分配及释放原理,深入剖析其中存在的一些问题,以及一些改进思路。本文源代码分析基于Mysql-8.0.24版本。 作者 | 之枢 来源 | 阿里技术公众号 一 引言 MYSQL Pe…

基于MaxCompute SQL 的半结构化数据处理实践

简介: MaxCompute作为企业级数据仓库服务,集中存储和管理企业数据资产、面向数据应用处理和分析数据,将数据转换为业务洞察。通过与阿里云内、外部服务灵活组合,可构建丰富的数据应用。全托管的数据与分析解决方案,可简…

file_get_contents请求失败处理_SpringCloud Gateway网关处理请求过程中遇到400Bad Request问题解决方案...

大家在使用springcloud自己的gateway作为网关服务时,可能会不小心遇到自定义的Filter处理请求Request报文时出现400的错误,而且这个错误还不是每次请求都必现,额什么意思?难不成你是说请求还时好时坏?bingo&#xff01…