go-zero 微服务实战系列(一、开篇)

简介: go-zero 微服务实战系列(一、开篇)

前言

在社区中经常看到有人问有没有基于 go-zero 的比较完整的项目参考,该类问题本质上是想知道基于 go-zero 的项目的最佳实践。完整的项目应该是一个完整的产品功能,包含产品需求、架构设计、关键流程的编码、表设计以及各种性能优化和数据一致性等,是一个真正贴近生产级的项目,是可以直接拿来在自己的生产项目中进行参考的,而目前社区并没有类似的比较完整的开源项目参考,因此决定和大家一起从零开始基于 go-zero 构建一个完整的贴近生产的项目。

该系列的主题是基于 go-zero 构建一个高并发的系统,为神马要选择这个主题呢?我猜大家一定感受到了 CRUD 的枯燥,而是希望项目是高并发的是带有一定挑战的,可能我们工作中的项目请求量比较低,主要以实现功能为主。但是,现代的互联网产品随时都有面对突发大流量的可能,比如我们的商城平时可能业务流量比较平稳,但某一天运营突然说要做一次秒杀活动来推广,如果没有提前做好应对高并发的准备,我们的服务很可能是扛不住的,结果也就可想而知。所以我们平时就需要提前储备足够多的高并发的知识,当遇到高并发需求的场景的时候就能够从容应对。

该系列为实战系列,过于基础的知识可能会比较少涉及,所以需要大家具备以下基础能力:

  • 了解go语言语法和基本使用姿势,请参考文档
  • 本系列项目数据库使用Mysql,请参考文档
  • 本系列项目缓存使用Redis,请参考文档
  • 本系列项目消息队列使用Kafka,请参考文档
  • 了解go-zero基本使用,请参考文档

为什么选择go-zero?

go-zero 为我们提供了许多高并发场景下的实用工具,比如为了降低接口耗时我们往往需要并发的请求依赖的服务,这个时候我们可以使用 mapreduce 并行的处理请求;面对海量请求为了降低Redis压力和提高响应时间,我们可以使用 collection 构建本地缓存;避免用户连续请求造成服务压力可以使用 limit 做用户级别的限流等等。好的框架能够给我的项目开发带来事半功倍的效果,Go-zero的简洁易用性与内置的开箱即用的工具和服务治理能力助力我们构建一个高并发高可靠的系统。

产品需求

为了更加贴近我们真实的项目开发,项目会基于真实的产品需求进行构建。商城是我们平时接触比较多而又比较复杂的系统,所以我们决定通过构建商城系统来和大家一起学习如何基于 go-zero 构建高并发系统。商城的功能点非常多,我们没有办法把所有的功能点都一一演示,但会实现一个 mvp版本,我们会在mvp版本中把 go-zero 的核心功能和构建高并发商城系统的核心点都演示出来。

如下思维导图列出了该电商系统主要实现的功能:

产品原型图

原型图是我们实现功能的主要参考,下面列出了商城系统主要的页面UI,通过这些UI在心中可以大致构建出系统的架构,构建不出来也木有问题,跟随文章一点点前进即可,奥利给!!!

首页和分类原型图

可以看到首页功能比较复杂,包含了搜索功能、Banner轮播图、抢购入口、排行榜、推荐等,分类中包含了不同分类的推荐商品

购物车和我的订单原型图

购物车展示了当前登录用户的购物车商品列表,除了商品基本信息还包括了商品数量。我的订单列表中展示了处于不同状态的商品列表

商品详情和商品评价原型

商品详情展示了商品的详情信息,同时在该页面可以添加购物车以及立即购买等,用户还可以点击收藏对该商品进行收藏,商品的评价功能是必不可少的,你是不是在购买某件商品的时候也会先看看该商品的用户评价呢?

以上贴出了商城项目主要实现的功能点和主要页面的原型图,我们的项目也会围绕这些主要的功能点展开。比较核心的功能点,比如请求量非常高的首页Banner我们如何优化,抢购商品如何保证不超卖,交易过程中分布式事务的实现等我们都会重点介绍。

系列文章目录

第一篇即为本篇文章,主要对项目做一个概览。

第二篇文章会介绍我们的微服务的划分以及工程目录结构的定义和使用 goctl 做一些项目代码的初始化工作。

第三篇文章会先定义项目的 API,只有定义好 API 协议之后才能真正的开始写代码,如何协议定义的不清楚会大大增加项目返工的几率,定义好API后紧接着我们需要进行表结构设计,数据库我们使用 MySQL。

第四篇文章主要是和大家一起熟悉下 go-zero 的基本使用,主要包括数据库的增删改查,缓存的操作,自定义中间件,常用工具包比如 mapreduce 的使用等等。

第五六七篇我们着重介绍缓存的使用姿势,在高并发系统中缓存的地位不言而喻,不夸张的说如何缓存设计的不好,那高并发系统也就不复存在。我们会介绍如何利用缓存优化请求量巨大的首页Banner,商品列表缓存实现,以及常见的Cache Aside模式代码该怎么写,还有缓存的一致性、击穿、穿透、雪崩等优化等等。

第八篇和第九篇会介绍如何实现一个简单的秒杀功能,秒杀功能可谓是高并发读和高并发写的典型代表,通过这两篇可以了解到秒杀功能的优化技巧和基本姿势。

第十篇介绍在微服务架构下经常遇到的分布式事务的问题,经过微服务拆分后,微服务间独占数据库,没法利用本地事务,通过该篇文章可以了解到在 go-zero 中的分布式事务的实现方式。

第十一篇介绍我们的业务代码如何写单元测试。

第十二篇服务的可观测性,上线后的服务需要具有可观测性,包括日志、指标监控、链路追踪等。

第十三篇我们会把服务部署上线并进行功能测试。

结束语

本篇文章首先介绍了该系列由来的背景以及我们为什么会选择构建高并发系统这个主题,接着介绍了我们需要构建的高并发的商城系统的主要功能点以及主要的页面原型图,最后列出了本系列的文章标题列表,通过标题列表可以快速了解整个系列的知识体系。

构建一个高并发的系统并不是一件容易的事情,涉及的知识点非常多,但我相信只要我们一起努力就一定能克服这些困难,让自己的技术能力更上一层楼。好在我们可以站在巨人的肩膀上,go-zero 为我们提供了非常强大的构建高并发服务的能力,为我们的系统保驾护航。

希望本篇文章对你有所帮助,谢谢。

每周一、周四更新

参考

https://github.com/zhoushuguang/lebron

项目地址

https://github.com/zeromicro/go-zero

目录
打赏
0
0
0
0
19
分享
相关文章
|
12天前
|
微服务——MongoDB实战演练——需求分析
本文档《5-MongoDB实战演练》聚焦于某头条文章评论业务的需求分析与功能实现。基于MongoDB,需完成以下功能:1)提供基本的增删改查API;2)支持通过文章ID查询相关评论;3)实现评论点赞功能。结合实际业务场景,演示MongoDB在数据存储与操作中的应用,附带示意图帮助理解业务结构。
17 2
微服务——MongoDB实战演练——需求分析
微服务——MongoDB实战演练——文章评论的基本增删改查
本节介绍了文章评论的基本增删改查功能实现。首先,在`cn.itcast.article.dao`包下创建数据访问接口`CommentRepository`,继承`MongoRepository`以支持MongoDB操作。接着,在`cn.itcast.article.service`包下创建业务逻辑类`CommentService`,通过注入`CommentRepository`实现保存、更新、删除及查询评论的功能。最后,新建Junit测试类`CommentServiceTest`,对保存和查询功能进行测试,并展示测试结果截图,验证功能的正确性。
25 2
|
12天前
|
微服务——MongoDB实战演练——文章评论实体类的编写
本节主要介绍文章评论实体类的编写,创建了包`cn.itcast.article.po`用于存放实体类。具体实现中,`Comment`类通过`@Document`注解映射到MongoDB的`comment`集合,包含主键、内容、发布时间、用户ID、昵称等属性,并通过`@Indexed`和`@CompoundIndex`注解添加单字段及复合索引,以提升查询效率。同时提供了Mongo命令示例,便于理解和操作。
24 2
微服务——MongoDB实战演练——MongoTemplate实现评论点赞
本节介绍如何使用MongoTemplate实现评论点赞功能。传统方法通过查询整个文档并更新所有字段,效率较低。为优化性能,采用MongoTemplate对特定字段直接操作。代码中展示了如何利用`Query`和`Update`对象构建更新逻辑,通过`update.inc("likenum")`实现点赞数递增。测试用例验证了功能的正确性,确保点赞数成功加1。
20 0
微服务——MongoDB实战演练——根据上级ID查询文章评论的分页列表
本节介绍如何根据上级ID查询文章评论的分页列表,主要包括以下内容:(1)在CommentRepository中新增`findByParentid`方法,用于按父ID查询子评论分页列表;(2)在CommentService中新增`findCommentListPageByParentid`方法,封装分页逻辑;(3)提供JUnit测试用例,验证功能正确性;(4)使用Compass插入测试数据并执行测试,展示查询结果。通过这些步骤,实现对评论的高效分页查询。
21 0
微服务——MongoDB实战演练——文章微服务模块搭建
本节介绍文章微服务模块的搭建过程,主要包括以下步骤:(1)创建项目工程 *article*,并在 *pom.xml* 中引入依赖;(2)配置 *application.yml* 文件;(3)创建启动类 *cn.itcast.article.ArticleApplication*;(4)启动项目,确保控制台无错误提示。通过以上步骤,完成文章微服务模块的基础构建与验证。
19 0
探索Go语言在微服务架构中的优势
在微服务架构的浪潮中,Go语言以其简洁、高效和并发处理能力脱颖而出。本文将深入探讨Go语言在构建微服务时的性能优势,包括其在内存管理、网络编程、并发模型以及工具链支持方面的特点。通过对比其他流行语言,我们将揭示Go语言如何成为微服务架构中的一股清流。
179 53
【环境】Rocky8使用gvm配置Go多版本管理的微服务开发环境(go-zero)
通过本文的介绍,我们详细讲解了如何在Rocky8上使用gvm来管理多个Go版本,并配置go-zero框架的开发环境。通过gvm的灵活管理,开发者可以轻松切换不同的Go版本,以适应不同项目的需求。同时,go-zero框架的使用进一步提升了微服务开发的效率和质量。希望本文能帮助开发者构建高效的Go语言开发环境,提高项目开发的灵活性和稳定性。
112 63
微服务——MongoDB实战演练——表结构分析
本文档来源于数据库articledb,展示了一张图片资源。图片宽度为1207像素,高度607像素,采用内联显示方式。内容涉及图像处理与样式设定,适用于文档或网页设计中多媒体元素的布局参考。图片来源为cdn.nlark.com,支持webp格式并附带水印处理。
16 1
微服务——MongoDB实战演练——表结构分析
微服务——MongoDB实战演练——技术选型
本节主要介绍技术选型中的两个重要工具:**mongodb-driver** 和 **SpringDataMongoDB**。其中,mongodb-driver 是 MongoDB 官方提供的 Java 驱动包,用于连接和操作 MongoDB 数据库,功能类似 JDBC 驱动。通过官方示例可快速上手。而 SpringDataMongoDB 是 Spring 生态的一员,封装了 mongodb-driver,提供了更简洁的 API,方便开发者在 Spring 环境中操作 MongoDB。两者各有优势,可根据实际需求选择合适的技术方案。
25 2
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等