为了账号安全,请及时绑定邮箱和手机立即绑定

软件架构-解密电商系统营销-会员模块业务

标签:
Java

很多人都在淘宝购买过东西,基本得流程都是一致的。

https://img1.sycdn.imooc.com//612c4d400001354812110665.jpg

(一)订单

https://img1.sycdn.imooc.com//612c4d41000166b819060828.jpg

  • 购物车

例如:jd分为自营和多家店铺的,它的购物车比较复杂些。
购物车如果保存在session中的话,用户量比较大的情况下,tomcat承受不住。比较合理的方式是保存在redis中,来一起说下redis保存的数据格式。
针对购物车结构

  1. CartGroup(一个店铺一个CartGroup)

  2. CartPkg(一个订单就是一个包裹)

  3. 一个订单里面就是一个List

购物车分两种,登录前购物车和登录后购物车

  1. 登录前是通过redis内部保存的,key=ip_类型(pc,ios,android)

  2. 登录后是通过用户的userid,key=userId

  3. 登录前到登录后他们两者通过redis进行对比,获取最新的合并结果。

https://img1.sycdn.imooc.com//612c4d420001c17d11640799.jpg

https://img1.sycdn.imooc.com//612c4d430001fefc03000978.jpg

  • 下单

买个索尼电视,佳能的相机,这是2个店铺,配送方式不同,仓库也不一样,每个商家的优惠力度也不一样,有打五折的,有打七折的。例如:苹果打5折,我买10个,地址是在郑州,配送方式是从武汉,武汉仓库只有9个苹果,但是河北那边有2个,长沙有3个。按照订单理论如果武汉有11个,买10个刚刚够你买。但是现在武汉只有9个,所以直接就给你发了武汉的9个,河北的1个,够你的10个,这个就是就近原则。但是这样有个问题退单怎么办,整体退单要退一起退,反之不要退。 设计到订单的拆分合并。

订单号生成?订单防重。只要保证分布式下不重复就可以

  1. redis incr 自增

  2. 时间戳+自增变量

  3. UUID

  • 电商订单的流程梳理

https://img1.sycdn.imooc.com//612c4d430001bdb317290866.jpg

t_order 订单表

https://img1.sycdn.imooc.com//612c4d4300016e2309290849.jpg

https://img1.sycdn.imooc.com//612c4d44000140c809020564.jpg

t_orderdetail订单明细表

https://img1.sycdn.imooc.com//612c4d440001c32d08970534.jpg

t_orderpay 支付记录表

https://img1.sycdn.imooc.com//612c4d450001164108960426.jpg

t_ordership 订单配送表

https://img1.sycdn.imooc.com//612c4d4500010f5b09010602.jpg

t_orderlog订单日志表

https://img1.sycdn.imooc.com//612c4d5c0001495908940278.jpg

t_express快递配送表

https://img1.sycdn.imooc.com//612c4d5d000111b108870235.jpg

  • MQ实现最大特点:异步和解耦。(付款,订单状态,发布状态)

https://img1.sycdn.imooc.com//612c4d5d0001453408990463.jpg

(二)统一配置文件神器-Disconf

百度disconf是一套完整的基于zookeeper的分布式配置统一解决方案。
一个分布式环境中,同类型的服务往往会部署很多实例。这些实例使用了一些配置,为了更好地维护这些配置就产生了配置管理服务。通过这个服务可以轻松地管理成千上百个服务实例的配置问题.

  • 官网介绍

https://github.com/knightliao/disconf
虽然3年没维护了,但是依然很给力

https://img1.sycdn.imooc.com//612c4d5d0001256912100740.jpg

  • 文档

http://disconf.readthedocs.io/zh_CN/latest/

https://img1.sycdn.imooc.com//612c4d5e0001cc6311730751.jpg

  • 介绍
    https://img1.sycdn.imooc.com//612c4d5e0001f19407280465.jpg

  • disconf的模块架构图
    https://img1.sycdn.imooc.com//612c4d5f0001ac3c06790455.jpg

  • 快速开始

这里直说pom里面的配置,具体看disconf文档写的更清楚

<dependency>
    <groupId>com.baidu.disconf</groupId>
    <artifactId>disconf-client</artifactId>
    <version>2.6.36</version></dependency><dependency>
    <groupId>org.apache.httpcomponents</groupId>
    <artifactId>httpclient</artifactId>
    <version>4.5.5</version></dependency><dependency>
    <groupId>org.apache.httpcomponents</groupId>
    <artifactId>httpcore</artifactId>
    <version>4.4.6</version></dependency>

PS:订单交易的流程和在web开发中如果多项目通过统一配置文件来进行处理。


点击查看更多内容
1人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
全栈工程师
手记
粉丝
1.7万
获赞与收藏
1318

关注作者,订阅最新文章

阅读免费教程

感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消