当前位置: 首页 > 编程日记 > 正文

饿了么交易系统5年演化史

作者 | 挽晴

来源 | 阿里巴巴中间件(ID:Aliware_2018)

个人简介:

2014年12月加入饿了么,当时参与后台系统的研发(Walis+Javis=>Walle),主要面向客服和BD。

2015年5月开始接触订单系统的研发,7月负责订单研发组;度过单体应用到服务化这个阶段。

2016年初搭建订单的测试团队,订单拆分为正逆向后,主要负责正向和交付部分。

2017年做了一些平台搭建的探索。

2018年初负责整个订单正逆向和交付,年中将下单、购物车部分一起归并,年底和商户订单部分整合,形成交易中台。

2019年10月从交易中台转出,近期做了一小段时间的组织效能和架构。

我为什么会写这篇文章,究其缘由:

一是自己在交易域做了 4 年,有很多只有我才知道,才能串起来的故事,想把这些记录并保留下来。

二是发现后边的很多同学看交易体系时,一接触就是分布式、SOA、每日百万、千万数据量,只知道它是这个样子,很难理解背后的思考和缘由。伴随自己这几年的经验,想让大家能够更容易的理解这个演化过程的原因和历程,有甘有苦。

三是很多总结也好,方法论也好,更多是去除了“糟粕”呈现在大家面前,这里可能会稍微加一点“毒鸡汤”,现实不一定那么美好,我们有很多抉择,现在回过头来看,也许是庆幸,也许是错误。

这篇文章希望通过一些发展的故事和思考来给读者呈现整个历程,大家可以看到非常多野蛮生长的痕迹,并会附带一些思考和总结,但不会像快餐式的总结很多大道理。

那我们就从2012年的太古时期讲起。

太古


http://www.taodudu.cc/news/show-118414.html

相关文章:

  • 生产型机器学习已经没那么困难了?
  • 干货 | 时间序列预测类问题下的建模方案探索实践
  • 挑战王者荣耀“绝悟” AI,我输了!
  • 开源一年,阿里轻量级AI推理引擎MNN 1.0.0正式发布
  • 深度解析MegEngine亚线性显存优化技术
  • 不知道这 7 大 OpenCV 函数怎么向计算机视觉专家进阶?
  • 学会这些Python美图技巧,就等女朋友夸我了
  • 智能驾驶L2的黄金时代,打磨地图是关键
  • 一次对语音技术的彻底批判
  • 百度翻译Q1 DAU增长40%,疫情期学生在线学习率猛增
  • 赠书 | 从阿里到Facebook,一线大厂这样做深度学习推荐系统
  • 20行Python代码实现视频字符化
  • AI修复100年前晚清影像喜提热搜,这两大算法立功了
  • 在商业中,如何与人工智能建立共生关系?
  • 再见 Python,Hello Julia!
  • 真没想到,Python还能实现5毛特效
  • 4场直播,哈工大、亚马逊等大咖为你带来机器学习与知识图谱的内容盛宴
  • iRobot的30年成长史
  • 《评人工智能如何走向新阶段》后记(再续25)
  • 《评人工智能如何走向新阶段》后记(再续26)
  • 《评人工智能如何走向新阶段》后记(再续27)
  • AWS 中国宁夏和北京区正式上线 Amazon SageMaker,中国用户终于能用到新工具和功能!
  • 云从完成超过18亿元新一轮融资,加快上市步伐
  • 清华孵化,打造智能驾驶感控平台,超星未来获千万A轮融资
  • 82年 AI程序员征婚启示火了!年薪百万,女生神回复
  • 16分钟优化mRNA疫苗稳定性! 百度AI算法LinearDesign问世
  • 美翻朋友圈:用Python生成蒙太奇马赛克图片
  • 成为计算机视觉工程师的第一个月,我都学会了什么?
  • 深度学习基础总结,无一句废话(附完整思维导图)
  • DeeCamp 2020 赛题大公开!快来看你想选哪个
  • 相关文章:

    Python迁移MySQL数据到MongoDB脚本

    MongoDB是一个文档数据库,在存储小文件方面存在天然优势。随着业务求的变化,需要将线上MySQL数据库中的行记录,导入到MongoDB中文档记录。 一、场景:线上MySQL数据库某表迁移到MongoDB,字段无变化。 二、Python模块&am…

    使用valgrind分析C程序调用线路图

    Valgrind可以检测内存泄漏和内存违例,但是用Valgrind生成的日志信息结合kcachegrind就可以查看C程序的执行线路图,调用时间,是做性能优化和查看代码的非常好的工具。 1.下载安装 Valgrind 安装 到www.valgrind.org下载最新版valgrind # wg…

    纯CSS实现蓝色圆角下拉菜单

    代码简介: 这个菜单没有使用任何的图片,完全是用CSS实现的,包括圆角效果也同样是,而且还考虑了多浏览器的兼容性,可以说非常不错,既兼容性好,又外观漂亮,下拉导航菜单目前比较流行&a…

    生产型机器学习已经没那么困难了?

    作者 | Caleb Kaiser译者 | 香槟超新星出品 | CSDN(ID:CSDNnews)封面图源自视觉中国在软件工程的诸多领域内,生产用例是相当标准化的。以Web开发为例,要在Web应用中实现身份认证,你不会去创造一个数据库,自…

    poj1330Nearest Common Ancestors 1470 Closest Common Ancestors(LCA算法)

    LCA思想:http://www.cnblogs.com/hujunzheng/p/3945885.html 在求解最近公共祖先为问题上,用到的是Tarjan的思想,从根结点开始形成一棵深搜树,非常好的处理技巧就是在回溯到结点u的时候,u的子树已经遍历,这…

    干货 | 时间序列预测类问题下的建模方案探索实践

    作者 | 陆春晖责编 | Carol出品 | AI科技大本营(ID:rgznai100)背景时间序列类问题是数据分析领域中一类常见的问题,人们有时需要通过观察某种现象一段时间的状态,来判断其未来一段时间的状态。而时间序列就是该种现象某一个统计指…

    Redis安装与源码调试

    linux版本:64位CentOS 6.5 Redis版本:redis-3.0.6 (更新到2016年1月22日) Redis官网:http://redis.io/ Redis常用命令:http://redis.io/commands 1.安装Redis # wget http://download.redis.io/releases/redis-3.2.6.tar.g…

    system pause in C#

    方法一: Console.Write("Press any key to continue . . . "); Console.ReadKey(true); 注:也可用ReadLine()或Read(),但是只能对回车进行响应,不能达到anykey的效果。 方法二: 1) 在源文件using处加入using…

    C#设置当前程序通过IE代理服务器上网

    注意:以下设置只在当前程序中有效,对IE浏览器无效,且关闭程序后,自动释放代码。 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Runtime.InteropServices;public static …

    计算机科学精彩帖子收集

    linux源码 LXR 源自“the Linux Cross Referencer”,中间的“X”形象地代表了“Cross”。与 Source Navigator 类似,它也是分析阅读源代码的好工具。不同的是,它将源代码借助浏览器展示出来,文件间的跳转过程成了我熟悉的点击超链…

    挑战王者荣耀“绝悟” AI,我输了!

    作者 | 马超责编 | 伍杏玲出品 | CSDN(ID:CSDNnews)腾讯 AI Lab 与王者荣耀联合研发的策略协作型AI,“绝悟”首次开放大规模开放:5月1日至4日,玩家从王者荣耀大厅入口,进入“挑战绝悟”测试&…

    java 注解类说明

    一、类中注解 SuppressWarnings ("serial"); 关键字 用途deprecation使用了不赞成使用的类或方法时的警告unchecked执行了未检查的转换时的警告,例如当使用集合时没有用泛型 (Generics) 来指定集合保存的类型。fallthrough当 Switch 程序块直接通往下一种…

    《ArcGIS Runtime SDK for Android开发笔记》——(13)、图层扩展方式加载Google地图...

    1、前言 http://mt2.google.cn/vt/lyrsm225000000&hlzh-CN&glcn&x420&y193&z9&sGalil 通过图层扩展类的方式加载Google地图的是我们通常获取Google地图的一种方式,根据这种方式我们可以通过拼接地图瓦片Url字符串获取瓦片数据,关…

    调试JDK源码-一步一步看HashMap怎么Hash和扩容

    调试JDK源码-一步一步看HashMap怎么Hash和扩容 调试JDK源码-ConcurrentHashMap实现原理 调试JDK源码-HashSet实现原理 调试JDK源码-调试JDK源码-Hashtable实现原理以及线程安全的原因 还是调试源码最好。 开发环境 JDK1.8NetBeans8.1 说明:调试HashMap的 publ…

    开源一年,阿里轻量级AI推理引擎MNN 1.0.0正式发布

    在经过充分的行业调研后,阿里淘系技术部认为当时的推理引擎如TFLite不足以满足手机淘宝这样一个亿级用户与日活的超级App。于是,他们从零开始自己搭建了属于阿里巴巴的推理引擎MNN。1年前,MNN在Github上开源,截止目前获得了3.9k S…

    人生在成败中进步

    参考文献《佛经》 人生在成败中进步佛经中有云:“菩萨者,福慧深利,道观双流。”“福慧双修”、“福慧双全”是众生成佛的必由之道,也是众生修行的理想追求。人生中,虽然不可能人人都能成佛,但是佛经有云&am…

    【原】YUI压缩与CSS media queries下的bug

    大概是上个月,使用YUI压缩一个css文件后,发现只要是被压缩后的css文件有部分根本无法工作,一直都不知啥问题引起的,让我感到头疼。 今天发现了只要是在媒体查询中的样式无法起作用,于是才开始怀疑是media被压缩后引起的…

    Spring源码分析【4】-Spring扫描basePackages注解

    org.springframework.beans.factory.support.DefaultListableBeanFactory 重要数据结构 /** Map of bean definition objects, keyed by bean name */private final Map<String, BeanDefinition> beanDefinitionMap new ConcurrentHashMap<String, BeanDefinition&…

    c语言c++语言中静态变量,函数详解

    静态变量&#xff0c;静态函数对于一些c&#xff0c;c的初学者来说&#xff0c;造成了不少的困扰。昨晚和寝室的室友讨论到这 个问题&#xff0c;想了一下&#xff0c;作了一下总结&#xff1a;虽然说c和c在很多人的眼里就是孪生姐妹&#xff0c;其实还是有很大区别的。在这里分…

    深度解析MegEngine亚线性显存优化技术

    基于梯度检查点的亚线性显存优化方法[1]由于较高的计算/显存性价比受到关注。MegEngine经过工程扩展和优化&#xff0c;发展出一套行之有效的加强版亚线性显存优化技术&#xff0c;既可在计算存储资源受限的条件下&#xff0c;轻松训练更深的模型&#xff0c;又可使用更大batch…

    2016-04-28

    2019独角兽企业重金招聘Python工程师标准>>> 1.提交form表单之前的函数(校验不错):onsubmit"return A();".2.解析XML的方式:2.1.DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准,基于"树"(DocumentBuilderFactory).2.2.SAX的优点类似于…

    Spring源码分析【8】-MyBatis注解方法不能重载

    代码如下&#xff1a; 这是不可以的&#xff0c;会报错&#xff1a; 2016-08-18 11:36:00,267 [main] ERROR [org.mybatis.spring.mapper.MapperFactoryBean] - Error while adding the mapper interface com.unix21.mapper.UserMapper to configuration.java.lang.IllegalArgu…

    不知道这 7 大 OpenCV 函数怎么向计算机视觉专家进阶?

    作者 | Lazar Gugleta译者 | Arvin&#xff0c;责编 | 夕颜头图 | CSDN付费下载自视觉中国出品 | CSDN&#xff08;ID:CSDNnews&#xff09;计算机视觉和计算机图形学现在非常流行&#xff0c;因为它们与人工智能息息相关&#xff0c;它们主要的共同点是使用同一个OpenCV库&…

    MySQL5.5复制新特性

    MySQL5.5复制新特性一.MySQL5.5复制改进MySQL5.5版本对MySQL Replication进行了多项的改良&#xff0c;以提供数据的完整性&#xff0c;性能和应用灵活性更高水平。1.Semisynchronous Replication&#xff1a;主从之间的等待机制2.Slave fsync tuning:调整slave fsync包括sync-…

    GitLab 8.7发布

    日前&#xff0c;GitLab 8.7版发布。该版本中&#xff0c;添加了新功能和优化&#xff0c;并小幅提升了性能。\\8.7版本发布于8.6版本整整30天之后&#xff0c;跟上了每月22日次版本的进度。最新的版本增加了在单个问题上设置到期日期的支持以及以用户所在时区而不是UTC来显示所…

    Java飞行记录器 JRockit Flight Recorder JFR诊断JVM的历史性能和操作

    需要展开子树&#xff0c;复制堆栈跟踪&#xff0c;就可以查看到代码调用链&#xff0c;看到自己的业务代码&#xff0c;从而定位到最耗时的代码位置&#xff1a;

    vi/vim: 使用taglist插件

    本节所用命令的帮助入口&#xff1a; :help helptags :help taglist.txt 上篇文章介绍了在vim中如何使用tag文件&#xff0c;本文主要介绍如何使用taglist插件(plugin)。 想必用过Source Insight的人都记得这样一个功能&#xff1a;SI能够把当前文件中的宏、全局变量、函数等t…

    学会这些Python美图技巧,就等女朋友夸我了

    来源 | ZackSock&#xff08;ID: ZackSock&#xff09;Python中有许多用于图像处理的库&#xff0c;像是Pillow&#xff0c;或者是OpenCV。而很多时候感觉学完了这些图像处理模块没有什么用&#xff0c;其实只是你不知道怎么用罢了。今天就给大家带了一些美图技巧&#xff0c;让…

    Linux下的softlink和hardlink(转)

    Linux中包括两种链接&#xff1a;硬链接(hard link)和软链接(soft link)&#xff0c;软链接又称为符号链接&#xff08;symbolic link&#xff09;创建命令&#xff1a;ln -s destfile/directory softlink #建立软连接 ln destfile hardlink #建立硬连接in…

    ubuntu安装之后的最初几天一路杂记

    我就随便写了啊&#xff0c;没那么正式&#xff0c;想到什么就写什么。 由于大四的毕业设计要做一个牵扯到linux的项目&#xff0c;最近不得不再次玩起了ubuntu&#xff0c;其实前一次&#xff08;大二的时候吧&#xff09;就已经在电脑上安装过一个ubuntu了&#xff0c;只不过…