首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    一个简单的分布式事务系统的实现(订单系统)

    背景:公司最早的一个版本的订单管理,是通过PHP+mysql的方案去实现的,这样会有什么问题呢,假设如果放到一个实例里面,全部用一个单机事务去解决,这样是能比较方便的解决数据一致性问题。但是存在两个问题,一是无法进行多实例部署,用户量增长以后,无法快速应对。二是,PHP中做事务,如果PHP遇到异常,有时并不会自动终止事务,导致DB被锁住,这是第一个版本。之后,我们推出了第二个版本V2,这个版本的时候,我们已经开发好了,库存管理系统,优惠券管理系统,PHP中,已经不直接通过DB去修改库存和优惠券,而是通过接口访问的方式去请求SERVER进行修改。这个版本,实际上已经从逻辑上,把订单系统和库存管理,优惠券管理系统已经独立出来了。数据层面已经可以独立部署,不再依赖一个单机事务去实现数据一致性功能了。但这个版本虽然解决了数据分布的问题,但同时引入了一个新的问题,就是数据在订单,库存,优惠券之间无法保证一致性。举个例子:下个订单,调用库存成功,锁定优惠券失败,生成订单失败。这时候就会导致优惠券数据不一致性情况出来,未下单的优惠券也被锁住了。有同事可能会问:订单如果创建失败,那直接回滚优惠券操作,即去解锁优惠券系统即可实现数据一致性。不错,很多时候,是可以这么操作,但如果你回滚的时候,失败了呢?你是继续在这等着直到成功,还是继续等着?呵呵。。

    02

    决赛名单&赛题公布!云开发公益编程赛聚焦三大真实公益需求

    近日,云开发技术峰会·公益编程挑战赛正式公布了决赛名单及赛题。经过层层筛选的18支队伍,将使用云开发/云托管/微搭低代码等一系列平台和工具,围绕来自公益组织的真实需求进行定向开发。详细名单见文末海报 公益编程挑战赛由腾讯云、微信云开发及腾讯技术公益联合举办,通过招募开发者组队参赛,引导技术与公益的结合,为公益事业提供长期价值。 此次遴选出的18支队伍,除了都拥有过硬的开发实力外,队伍背景也各有特点。既有初中生组成的“后浪”队伍,也有一直致力于用技术改善盲人生活的公益小队,还有自发开发核酸检测点地图而被媒体报

    02
    领券