【转】交易系统在分布式环境下的问题探讨

前几天跟朋友聊到这个话题,当时没有想到分布式锁,后在google上查询,发现这篇文章逻辑比较清楚——交易系统在分布式环境下的探讨

众所周知在互联网公司,如果你没有对你的系统进行分库分表,那你怎么好意思跟人打招呼?但是分库分表带来的难题也是众所周知的,除了多机查询(分批查询、合并结果等等)等问题,最重要的就是保障事务问题,这一点在交易系统中尤为重要。

最为简单的解决方式就是使用分布式事务,业界已经有了规范–XA,他使用两阶段提交来保证分布式下的事务,具体的规范我就不说了,可以到维基百科上详细了解,看似完美,但是这个解决方案在分库分表的环境下有些“重”。我们完全可以退一步来想,我们既然不能保证强一致性,那么我们保证最终一致性也可以达到理想的结果。我们主要依托如下两个理论来构建一个最终一致性的系统:CAP理论、BASE模型。

让我们举个栗子来说明:假如一个用户在亚马逊上买了一本书,用户需要做的就是点击生成订单,而后付款最后等待收货,此时从技术的角度来看,我们大致有四个系统:用户系统,账户系统,订单系统,物流系统,而订单的状态变化大致如下:初始–已支付–已发货–完成。正常情况下订单状态会依次变更,而后亚马逊收到钱款后组织发货。但是在现实中就没有那么幸福了,用户付款后亚马逊没收到钱,收到钱后没有告知用户发货。因为这四个系统所使用的DB、JVM甚至机房都不一样。对于用户系统,习惯上对于整个交易系统来讲它是用户展示结果的所有我们暂时不去讨论,那么对于账户系统,不管用户使用账户余额支付还是使用网络支付,最终的结构都是用户的余额减少而商家的余额增加。

那么对于这个局部的交易过程(用户余额减少–商家余额增加),我们同样不敢肯定其是否同处一个DB,所以我们使用分布式锁保证同一时间对该资源(账户余额)的其他操作是不可用的(比如同一时刻对该余额做减少操作)。这样我们保证了用户余额减少–商家余额增加这一过程结果的可控性,在分布式这方面,memcache和Redis等都可实现分布式锁。

下面我们讨论当用户的支付过程完成之后的事情,顺利的情况下订单系统拿到支付成功的结果后将订单状态更新为支付成功。可是假如在这个过程,因为超时抑或其他原因,导致用户支付成功,而订单状态已然是未支付该怎么办?这时候我们有两种选择:轮训查询几次支付结果而后更新订单状态,此为同步过程。引入消息中间件,将此过程解耦成异步过程。显然我们应该使用异步方式更优雅,并且解耦之后的扩展性更强。那么如何实现呢,我简单说下:支付成功之后账户系统发送消息到MQ,订单系统轮询MQ获取最新消息,根据消息更新订单状态。这样的结果就是用户系统首先依然认为订单未支付并展示给用户,而后台处理完后可以等待用户主动获取订单状态(刷新页面,京东上就是如此),也可以更高端的主动推送信息给用户。那么物流状态依然引入MQ来完成异步化的操作。

看似我们的这个过程已经“优雅”的完成了,用户看到了支付状态又看到了发货提醒,安心的等待中。

后记:还需继续思考的点

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

推荐阅读更多精彩内容