Go项目(订单微服务)
创始人
2024-05-30 00:45:01
0

文章目录

  • 简介
  • handler
    • UT
  • web
  • 支付服务
    • Notify
  • 小结

简介

  • 这部分开始梳理订单微服务的关键点
  • 这里仿京东,订单结算在购物车进行,所以用户的操作是加入商品到购物车,进入购物车付款
  • 从页面分析需求
    • 点击添加到购物车,删除车中商品,更新商品数量和选中状态(其实就是购物车内的增删改),选中商品,创建订单,付款结算
      1
    • 订单列表及详情
      2
  • 表设计
    • 包含三张表,订单商品表需要注意一下
      // 订单商品表,可以查订单内商品,可以根据商品查订单
      type OrderGoods struct {BaseModelOrder int32 `gorm:"type:int;index"`Goods int32 `gorm:"type:int;index"`// 把商品的信息保存下来了,字段冗余,但能够减少服务之间的调用,高并发系统中的常见做法,而非遵循三范式// 还有一个作用是镜像,记录当时订单的商品价格,因为商品服务里的价格是变动的GoodsName  string `gorm:"type:varchar(100);index"`GoodsImage string `gorm:"type:varchar(200)"`GoodsPrice float32Nums       int32 `gorm:"type:int"`
      }
      
    • 建库建表
      _ = db.AutoMigrate(&model.ShoppingCart{}, &model.OrderInfo{}, &model.OrderGoods{})
      
  • 接口设计(定义proto)
    • 分为购物车和订单两部分
      service Order {//购物车rpc CartItemList(UserInfo) returns(CartItemListResponse); //获取用户的购物车信息rpc CreateCartItem(CartItemRequest) returns(ShopCartInfoResponse); //添加商品到购物车rpc UpdateCartItem(CartItemRequest) returns(google.protobuf.Empty); //修改购物车商品信息rpc DeleteCartItem(CartItemRequest) returns(google.protobuf.Empty); //删除购物车商品//订单rpc CreateOrder(OrderRequest) returns (OrderInfoResponse); //创建订单rpc OrderList(OrderFilterRequest) returns (OrderListResponse); // 订单列表rpc OrderDetail(OrderRequest) returns (OrderInfoDetailResponse); // 订单详情rpc UpdateOrderStatus(OrderStatus) returns (google.protobuf.Empty); // 修改订单状态
      }
      
    • 生成 stub 代码
  • 更改 nacos 的本地和远程配置,启动服务看能否注册成功

handler

  • srv 层重点就是数据库操作,基本分三步
    1. 准备返回值(proto.struct)
    2. 根据请求参数操作数据+判空/判满,注意数据类型
    3. 填充返回值各字段
  • 重点在新建订单 CreateOrder接口,有一些要注意的地方
  • 要调用商品微服务和库存微服务,srv 层互相调用
    • 这个模仿商品微服务调用库存微服务即可,需要新增配置,拷贝过来 goods 和 inventory 的 stub
  • 具体步骤
    1. 从购物车中获取到选中的商品
    2. 商品的价格要在这里再次查询 - 访问商品srv服务
    3. 库存的扣减 - 访问库存服务
    4. 往订单信息表/订单商品表里插入数据,批量插入 CreateInBatches
    5. 从购物车中删除已购买的记录
  • 注:这里要操作两个表:订单信息表,订单商品表
  • 还有一个主要的问题,数据库操作应该使用事务
    • 包含两方面,操作本地订单表时使用 MySQL 事务;库存扣除调用的是其他服务,应该用分布式事务(不是分布式锁)
    • TODO
  • 注意问题发生的场景,解决方案有哪些优缺点,这些都是积累经验哈

UT

  • 一定要做接口测试,这是后端基本素养,至于产品的自动化测试比较复杂,整个系统上线后会做
    • 每个公司自动化测试的架构不一样,有很多东西可学
  • 这里后端测试暂时没有用 go 内置的单元测试,效果一样哈(go 也没有内置断言,依赖第三方包),后续会有专门的章节写 UT
    var orderClient proto.OrderClient
    var conn *grpc.ClientConnfunc TestCreateCartItem(userId, nums, goodsId int32){rsp, err := orderClient.CreateCartItem(context.Background(), &proto.CartItemRequest{UserId: userId,Nums: nums,GoodsId: goodsId,})if err != nil {panic(err)}fmt.Println(rsp.Id)
    }func Init(){var err errorconn, err = grpc.Dial("127.0.0.1:50051", grpc.WithInsecure())if err != nil {panic(err)}orderClient = proto.NewOrderClient(conn)
    }func main() {Init()// 启动两个依赖的微服务:商品和库存//TestCreateCartItem(1,1,422)//TestCartItemList(1)//TestUpdateCartItem(1)//TestCreateOrder()//TestGetOrderDetail(20)TestOrderList()conn.Close()
    }
    

web

  • 快速开发订单服务 web 层
  • 查找替换为 order-web,修改 nacos 的配置,复制 stub 文件,修改接口,修改路由,启动测试
  • API 层要响应前端请求,调用 srv 的接口,接口还是根据前端界面分析
    • 订单相关:新建订单(form表单验证,传递用户信息),订单详情,订单列表
    • 支付相关:先看支付服务
    • 购物车相关:商品列表,加入商品(定义form表单传参)
  • 测试
    • yapi 新建订单服务的测试环境
  • 这块还需要结合支付服务,返回给用户支付的 url,先去梳理支付逻辑
    • 但是申请支付宝的支付服务需要网站域名,且要公司性质才可以,个人无法申请
    • 但总不能服务上线公司创建才能开发吧?于是它提供了沙箱环境,只需切换配置即可上线

支付服务

  • 理解支付宝沙箱环境,进入沙箱应用
    • 沙箱环境是独立的,每一个应用都会有一个商家账号和买家账号
  • 为了保障信息安全,这里需要配置两套公私钥,当然,也可以用证书,目的是一样的,客户端和服务器之间的互信
    1
  • 我们生成一对公私钥,公钥给支付宝;支付宝也有一对公私钥,需要把它的公钥拿过来
  • 增加配置
    type AlipayConfig struct {AppID        string `mapstructure:"app_id" json:"app_id"`PrivateKey   string `mapstructure:"private_key" json:"private_key"`AliPublicKey string `mapstructure:"ali_public_key" json:"ali_public_key"`NotifyURL    string `mapstructure:"notify_url" json:"notify_url"`ReturnURL    string `mapstructure:"return_url" json:"return_url"`
    }
    
  • 支付宝 AliPay SDK for Go,导包即用
    • 看一下 创建 Wap 支付 部分即可
  • 回到订单服务,集成生成支付URL的代码,并准备函数 Notify 让支付宝回调
    • 订单创建和订单详情都应该返回支付 URL,如果创建时未支付,后续可以在订单详情里继续支付
    • 订单列表只显示支付状态即可

Notify

  • 这里服务器需要验证支付宝的消息,使用支付宝的公钥Z
    • 这部分在 GetTradeNotification 的 VerifySign 中完成
  • 获取支付状态,更新订单表
  • 返回给支付宝状态,否则支付宝会进行最大努力通知

小结

  • 这部分快速实现了订单微服务的 srv 层和 API 层
  • 接下来快速开发用户操作微服务,前后端联调

相关内容

热门资讯

东方电子跌2.04%,成交额7... 5月14日,东方电子盘中下跌2.04%,截至11:00,报9.59元/股,成交7109.97万元,换...
龙利得涨2.30%,成交额24... 5月14日,龙利得盘中上涨2.30%,截至10:59,报5.79元/股,成交2494.39万元,换手...
国台办回应民进党当局加紧采购爱... 转自:财联社【国台办回应民进党当局加紧采购爱国者导弹】财联社5月14日电,国台办举行例行新闻发布会。...
格林精密跌2.04%,成交额5... 5月14日,格林精密盘中下跌2.04%,截至11:00,报14.92元/股,成交5458.96万元,...
晶华微跌2.06%,成交额17... 5月14日,晶华微(维权)盘中下跌2.06%,截至10:50,报25.66元/股,成交1777.62...
必得科技跌2.05%,成交额1... 5月14日,必得科技盘中下跌2.05%,截至10:56,报12.90元/股,成交1339.76万元,...
立方制药涨2.02%,成交额9... 5月14日,立方制药盘中上涨2.02%,截至10:57,报23.77元/股,成交9439.78万元,...
兰州市城关区首次开展公共服务政... 城关区首次开展公共服务政策健康影响评估  5月13日,兰州市城关区召开公共服务政策健康影响评估会议暨...
哪吒汽车关联公司超10亿人民币...   5月14日上午消息,天眼风险信息显示,哪吒汽车关联公司合众新能源汽车股份有限公司有10亿人民币、...
瀚川智能跌2.05%,成交额1... 5月14日,瀚川智能盘中下跌2.05%,截至10:51,报13.88元/股,成交1667.10万元,...
2024年上海宝山绿色低碳产业... 5月14日,界面新闻从上海宝山获悉,2024年宝山区绿色低碳产业规模已达1003.69亿元,首次突破...
美股三大指数涨跌不一 标普50... 来源:环球网 【环球网财经综合报道】当地时间周二,美股市场呈现分化走势,三大指数收盘涨跌互现。其中,...
瑞凌股份跌2.05%,成交额2... 5月14日,瑞凌股份盘中下跌2.05%,截至10:58,报10.03元/股,成交2729.60万元,...
研究称中国痴呆人数激增 【#研究称中国痴呆人数激增#】最近,上海复旦大学的一项研究显示,过去30年间,中国痴呆患者数量从19...
青少年阅读,筑就生命基石——来... 青少年红色阅读接力活动。 主办方供图当人工智能(AI)的浪潮扑面而来,全民阅读迎来变革之年,如何让阅...
技能之星丨赵慧仪:破茧成蝶的舞... 转自:邯郸网络广播电视台2025年河北省职业院校技能大赛舞蹈表演(中职组)现场,邯郸科实中等专业学校...
【研报推荐】华润微:25Q1盈... 转自:新华财经华润微季报点评_25Q1盈利同比高增,汽车和AI应用持续带来需求增量.pdf
费高云卸任安徽副省长,此前已任... 转自:长安街知事据安徽日报消息,5月14日上午,安徽省十四届人大常委会第十六次会议通过人事任免案,决...
电子烟概念股集体上扬 华宝国际... .ct_hqimg {margin: 10px 0;} .hqimg_wrapper {text-a...
中自科技跌2.03%,成交额4... 5月14日,中自科技盘中下跌2.03%,截至10:51,报22.64元/股,成交4916.13万元,...