收藏

基于 Spring Cloud 微服务架构下

广告系统设计与实现(新版)

掌握广告系统的人才,必将成为各大公司高薪争抢的对象

基于Spring Cloud微服务架构 设计并实现广告系统(新版)

难度 中级 时长 26小时30分钟 学习人数 1893 综合评分 9.97

基于Spring Cloud微服务架构 设计并实现广告系统(新版)

  • 第1章 课程简介【终于等到你,快来认识我】 试看 3 节 | 12分钟

    本章对这门课程进行说明,包括:广告系统的介绍、课程使用的技术介绍、课程的学习规划等。

    收起列表

    • 视频: 1-1 课程导学 (11:21) 试看
    • 图文: 1-2 ***学前必读***(助你平稳踩坑,畅学无忧,课程学习与解决问题指南)
    • 作业: 1-3 【讨论题】广告系统是如何工作
  • 第2章 广告系统概览与准备工作【看一看我们将要做什么】 试看 4 节 | 21分钟

    本章会介绍广告系统的思想、广告系统的技术实现架构、学习本课程之前的准备工作和广告系统的代码目录结构。

    收起列表

    • 视频: 2-1 广告系统概览 (10:12) 试看
    • 视频: 2-2 广告系统架构 (05:23)
    • 视频: 2-3 【整体看一看】准备工作与系统目录结构 (05:02)
    • 图文: 2-4 【总结与作业】关于广告系统与准备工作的介绍及作业
  • 第3章 广告系统骨架开发【要想上梯子,必须从底下爬起】 试看 10 节 | 68分钟

    广告系统使用SpringCloud微服务框架开发,并使用Maven做多模块管理。这一章完成项目骨架的开发,包括搭建注册中心和服务网关,同时也会对Maven的重要特性做介绍。

    收起列表

    • 视频: 3-1 Maven 基础知识 (04:53)
    • 视频: 3-2 Maven 相关特性 (06:04)
    • 视频: 3-3 【动手编码】广告系统主工程 (11:43)
    • 视频: 3-4 【边学边做】单节点 Eureka Server 的开发 (09:28)
    • 视频: 3-5 【让代码跑起来】Eureka Server 的部署 (12:03)
    • 图文: 3-6 【总结与作业】关于 ad-eureka 的介绍及作业
    • 视频: 3-7 微服务架构及网关组件介绍 (06:43)
    • 视频: 3-8 【边学边做】网关启动程序的开发 (05:57)
    • 视频: 3-9 【注重理解】自定义网关过滤器的开发 (10:15) 试看
    • 图文: 3-10 【总结与作业】关于 ad-gateway 的介绍及作业
  • 第4章 微服务通用模块开发【企业级开发常见抽象】 5 节 | 36分钟

    本章实现广告系统微服务通用的功能,例如:统一响应格式、全局异常处理、通用代码定义、通用配置定义等。

    收起列表

    • 视频: 4-1 【理解它的作用】关于通用模块功能的介绍 (06:21)
    • 视频: 4-2 【跟我一起编码】统一响应处理的开发 (18:01)
    • 视频: 4-3 统一异常处理的开发 (06:00)
    • 视频: 4-4 统一配置的开发 (05:34)
    • 图文: 4-5 【总结与作业】关于通用模块的说明及作业
  • 第5章 广告投放系统的开发【打好基础,才能迎接将来的挑战】 26 节 | 234分钟

    本章的核心目标是实现投放系统,投放系统即实现对广告数据的存储。课程中会对表结构设计进行介绍,使用 JPA 实现对各个数据表的增删改查。同时,由于会涉及Spring相关的知识点(Spring IOC、Spring MVC、SpringBoot),也会对这些做基础介绍。...

    收起列表

    • 视频: 5-1 【回顾下Spring特性】Spring IOC和MVC基础知识 (09:20)
    • 视频: 5-2 【简单好用的SpringBoot】SpringBoot 常用功能特性介绍 (10:49)
    • 视频: 5-3 【理解业务思想】广告投放系统数据表设计 (11:41)
    • 图文: 5-4 【总结与作业】关于广告投放系统的介绍及作业
    • 视频: 5-5 【开始编码】创建广告投放系统子模块 (13:13)
    • 视频: 5-6 【Model层设计】数据表实体类定义(1) (12:29)
    • 视频: 5-7 数据表实体类定义(2) (14:22)
    • 视频: 5-8 数据表实体类定义(3) (08:17)
    • 视频: 5-9 数据表实体类定义(4) (14:43)
    • 视频: 5-10 【Dao层设计】数据表Dao接口的定义(1) (10:58)
    • 视频: 5-11 数据表Dao接口的定义(2) (04:50)
    • 视频: 5-12 【实战应用】用户账户服务功能实现 (13:41)
    • 视频: 5-13 推广计划服务功能实现(1) (10:11)
    • 视频: 5-14 推广计划服务功能实现(2) (17:44)
    • 视频: 5-15 推广单元服务功能实现 (10:27)
    • 视频: 5-16 推广单元限制服务功能实现(1) (07:40)
    • 视频: 5-17 推广单元限制服务功能实现(2) (13:59)
    • 视频: 5-18 创意服务功能实现 (07:39)
    • 视频: 5-19 创意与推广单元关联服务功能实现 (10:00)
    • 视频: 5-20 服务Controller的编写(1) (10:36)
    • 视频: 5-21 服务Controller的编写(2) (09:56)
    • 视频: 5-22 投放系统在网关中的配置 (07:05)
    • 视频: 5-23 数据库与数据表的创建 (04:07)
    • 图文: 5-24 【扩展与练习】关于 MySQL 慢查询的介绍及作业
    • 图文: 5-25 【扩展与练习】关于 MySQL 索引的介绍及作业
    • 图文: 5-26 【扩展与练习】关于 MySQL 事务隔离级别的介绍及作业
  • 第6章 广告检索系统 - 微服务调用【基础打好了,难度也要加点了】 4 节 | 33分钟

    本章会介绍使用 Ribbon 与 Feign 组件实现微服务之间的调用。

    收起列表

    • 视频: 6-1 【搭建微服务】创建广告检索系统子模块 (10:26)
    • 视频: 6-2 【跟我一起编码】基于 Ribbon 实现微服务调用 (12:12)
    • 视频: 6-3 【注重领会】基于 Feign 实现微服务调用 (09:43)
    • 图文: 6-4 【总结与作业】关于微服务调用的介绍及作业
  • 第7章 广告检索系统-广告数据索引的设计与实现【难度在逐步上升】 12 节 | 97分钟

    广告检索系统的核心是实现广告检索服务,为加快广告检索的速度,良好的索引设计是不可缺少的。本章首先对索引的设计与维护进行介绍,之后,实现广告数据的索引服务。

    收起列表

    • 视频: 7-1 【理解设计好开发】广告数据索引设计介绍 (05:15)
    • 视频: 7-2 【理解设计好开发】广告数据索引维护介绍 (04:11)
    • 视频: 7-3 【跟我一起编码】推广计划索引对象定义与服务实现 (11:37)
    • 视频: 7-4 推广单元索引对象定义与服务实现 (08:22)
    • 视频: 7-5 关键词索引对象定义与服务实现 (16:38)
    • 视频: 7-6 兴趣索引对象定义与服务实现 (11:30)
    • 视频: 7-7 地域索引对象定义与服务实现 (08:46)
    • 视频: 7-8 创意索引对象定义与服务实现 (07:48)
    • 视频: 7-9 创意与推广单元关联索引对象定义与服务实现 (11:52)
    • 视频: 7-10 【实战技能提升】索引服务类缓存的实现 (10:56)
    • 图文: 7-11 【总结与作业】关于广告数据索引的设计与实现的介绍及作业
    • 作业: 7-12 如何将JVM 中构建的广告数据索引迁移到 Redis
  • 第8章 广告检索系统 – 加载全量索引【对业务的理解要透彻,才能一气呵成】 12 节 | 99分钟

    本章介绍广告数据导出的实现,之后介绍各层级索引操作的实现,最后完成全量索引的加载操作。

    收起列表

    • 视频: 8-1 【边学边做】导出表数据字段定义(1) (08:16)
    • 视频: 8-2 导出表数据字段定义(2) (05:03)
    • 视频: 8-3 表数据导出到文件功能实现(1) (07:01)
    • 视频: 8-4 表数据导出到文件功能实现(2) (10:21)
    • 视频: 8-5 表数据导出到文件功能实现(3) (13:36)
    • 视频: 8-6 【在理解的基础上编码】索引操作Handler的定义与说明 (09:26)
    • 视频: 8-7 第二层级索引操作的实现 (07:02)
    • 视频: 8-8 第三层级索引操作的实现 (12:38)
    • 视频: 8-9 第四层级索引操作的实现 (10:43)
    • 视频: 8-10 【试试举一反三】全量索引加载的实现(1) (09:02)
    • 视频: 8-11 全量索引加载的实现(2) (05:23)
    • 图文: 8-12 【总结与作业】关于加载全量索引的介绍与说明
  • 第9章 广告检索系统 – 监听 Binlog 构造增量数据【技能提升:难度指数5颗星】 14 节 | 134分钟

    本章首先会介绍什么是MySQL Binlog,它有哪些作用和特性;再去介绍怎样实现监听Binlog构造增量数据。

    收起列表

    • 视频: 9-1 【认识一下吧】MySQL Binlog 的介绍 (11:51)
    • 图文: 9-2 【总结与作业】关于 MySQL Binlog 的介绍
    • 视频: 9-3 【先来个栗子】使用开源工具监听 Binlog 的演示 (09:56)
    • 图文: 9-4 【总结与作业】mysql-binlog-connector-java介绍及作业
    • 视频: 9-5 【注重领会】构造解析 Binlog 使用到的模板文件 (11:31)
    • 视频: 9-6 【边学边做】实现对模板对象的解析 (09:57)
    • 视频: 9-7 【技能逐步提升】载入模板文件并实现列索引到列名的映射 (13:34)
    • 视频: 9-8 【注重理解】关于 Binlog 监听与解析的说明 (07:54)
    • 视频: 9-9 【跟我一起编码】Binlog 监听与解析的实现(1) (15:07)
    • 视频: 9-10 【跟我一起编码】Binlog 监听与解析的实现(2) (11:40)
    • 视频: 9-11 【边学边做】根据 Binlog 对象构造增量数据的准备工作 (17:22)
    • 视频: 9-12 【边学边做】根据 Binlog 对象构造增量数据的实现 (11:46)
    • 视频: 9-13 【多做总结与思考】启动对 Binlog 的监听 (12:36)
    • 图文: 9-14 【总结与作业】关于监听 Binlog 构造增量数据的介绍及作业
  • 第10章 广告检索系统 – Binlog 增量数据的投递【企业级开发必备技能】 6 节 | 54分钟

    Binlog 增量数据可以有多种用途,也就对应着多种数据投递方案。本章会实现增量数据投递构建增量索引,以及投递到 Kafka 用于扩展工作。

    收起列表

    • 视频: 10-1 【良好的代码设计】增量数据投递前的准备工作 (10:41)
    • 视频: 10-2 【跟我一起继续编码】第二层级增量数据的投递 (16:39)
    • 视频: 10-3 第三层级增量数据的投递 (07:53)
    • 视频: 10-4 第四层级增量数据的投递 (10:23)
    • 视频: 10-5 【这里有内涵】将增量数据投递到Kafka (07:39)
    • 图文: 10-6 【总结与作业】关于 Binlog 增量数据投递的介绍及作业
  • 第11章 广告检索系统 – 广告检索服务【技能与业务思想再提升:难度指数5颗星】 10 节 | 90分钟

    广告系统最重要的功能当然是实现广告的检索,本章首先定义媒体方请求数据的格式和检索服务返回广告数据的格式,再去根据多种筛选策略实现对索引数据的筛选,最终完成广告检索服务。

    收起列表

    • 视频: 11-1 【注重理解与思考】广告检索服务功能的介绍 (05:25)
    • 视频: 11-2 【请求条件封装】媒体方请求对象的定义 (14:14)
    • 视频: 11-3 【结合业务去看响应】检索服务响应对象的定义 (08:47)
    • 视频: 11-4 【跟我一起编码】根据流量类型实现对推广单元的预筛选 (18:49)
    • 视频: 11-5 根据匹配信息实现对推广单元的再筛选 (14:23)
    • 视频: 11-6 通过推广单元获取关联的创意实现 (08:23)
    • 视频: 11-7 填充检索服务响应对象 (13:48)
    • 视频: 11-8 【完成功能】完善广告检索服务 (05:28)
    • 图文: 11-9 【总结与作业】关于广告检索服务的介绍及作业
    • 作业: 11-10 【讨论题】JVM 中构建分级索引的优势
  • 第12章 Kafka 的安装与使用【不仅能应用在工作与面试中,还会用于架构优化】 10 节 | 99分钟

    Kafka作为消息队列可以实现消息的传递,目前已经被各大互联网公司应用到实际的企业级开发。这一章将会介绍怎样安装Kafka、简单的使用Kafka。同时,为了更好的理解它的工作过程,会以编码实践的方式展示其原生API的使用方法。...

    收起列表

    • 视频: 12-1 【理清概念】Kafka 基础知识的介绍 (09:03)
    • 视频: 12-2 【一起环境搭建】Kafka 的安装与使用 (14:07)
    • 视频: 12-3 【边学边做】使用原生API发送消息(1) (11:05)
    • 视频: 12-4 使用原生API发送消息(2) (10:41)
    • 视频: 12-5 自定义分区分配器 (13:00)
    • 视频: 12-6 消费者与消费者组的概念 (04:10)
    • 视频: 12-7 使用原生API消费消息(1) (13:31)
    • 视频: 12-8 使用原生API消费消息(2) (10:16)
    • 视频: 12-9 使用原生API消费消息(3) (12:16)
    • 图文: 12-10 【总结与作业】关于 Kafka 的介绍及作业
  • 第13章 熔断监控Hystrix Dashboard【添加监控,完善系统】 3 节 | 14分钟

    微服务之间可以通过Feign实现调用,但是可能由于存在微服务不稳定的情况,导致调用失败。可以定义Hystrix实现断路器功能,并利用Hystrix Dashboard监控熔断情况。

    收起列表

    • 视频: 13-1 Hystrix Dashboard 的介绍 (05:48)
    • 视频: 13-2 Dashboard 模块的实现 (07:56)
    • 图文: 13-3 关于 Hystrix Dashboard 的介绍及作业
  • 第14章 广告系统的可用性测试【开发完功能,验证下是否好用】 8 节 | 54分钟

    通过测试用例和PostMan检验投放系统与检索系统的可用性。

    收起列表

    • 视频: 14-1 【构建测试环境】广告系统测试前的准备工作 (09:21)
    • 图文: 14-2 【总结与作业】mock 数据的内容
    • 视频: 14-3 【功能上的测试】编写广告投放系统的测试用例 (09:09)
    • 视频: 14-4 编写广告检索系统的测试用例(上) (13:07)
    • 视频: 14-5 编写广告检索系统的测试用例(下) (10:20)
    • 图文: 14-6 【总结与作业】关于广告系统可用性测试的介绍及说明
    • 视频: 14-7 【接口上的测试】投放系统的 HTTP 接口测试 (11:20)
    • 图文: 14-8 【总结与作业】关于广告系统可用性测试的介绍及说明 - HTTP 接口测试
  • 第15章 课程总结 3 节 | 7分钟

    对课程所介绍的内容做总结,列出所涉及到的知识点,回顾广告系统,并提出问题以及扩展方案。

    收起列表

    • 作业: 15-1 【讨论题】本课程的重难点
    • 作业: 15-2 【总结】SpringCloud 微服务开发框架组件
    • 视频: 15-3 课程总结 (06:00)
  • 第16章 (彩蛋番外篇一)Spring事务处理机制【工作与面试,你都会遇到】 11 节 | 66分钟

    课程上线后,综合同学们的群讨论以及问答区提问,老师新增本章节。希望帮助同学们能够正确的理解Spring 的事务处理机制,更加准确的编写有关数据库增删改查的业务代码。当然,Spring 的事务处理机制也是面试考察的重点呦~~(未完待续@_^)...

    收起列表

    • 视频: 16-1 异常和事务基础 (04:16)
    • 视频: 16-2 Spring 事务的属性和使用入口 (08:12)
    • 视频: 16-3 Spring 事务管理接口的介绍 (06:16)
    • 图文: 16-4 @Transactional 注解解析
    • 图文: 16-5 Spring 事务管理接口
    • 图文: 16-6 阶段练习
    • 视频: 16-7 Spring 事务机制验证前的准备工作 (09:13)
    • 视频: 16-8 Spring 事务对主动捕获异常和checked异常的处理 (14:32)
    • 视频: 16-9 Spring 事务对指定异常和RollbackOnly异常的处理 (12:41)
    • 视频: 16-10 Spring 事务对调用事务方法的处理 (10:25)
    • 图文: 16-11 Spring 中 @Transactional 注解的限制
  • 第17章 (彩蛋番外篇二)重构检索系统微服务【架构重新设计,优化系统性能】 9 节 | 84分钟

    企业级开发中,随着版本的逐步迭代,代码重构不可避免。代码重构包含对代码的整理、架构的重新设计、性能优化等等。这一章里,我将对检索系统微服务的架构做出调整,功能结构更加清晰的同时,系统性能也有很大的提升

    收起列表

    • 视频: 17-1 章节说明 (02:54)
    • 视频: 17-2 【主动思考,提升架构能力】怎样组织微服务的包结构 (12:39)
    • 视频: 17-3 【理论知识融会贯通】再谈 MySQL 的 Master Slave 协议 (06:47)
    • 图文: 17-4 微服务包的设计思想
    • 视频: 17-5 【能力提升】广告检索微服务架构设计优化 (09:28)
    • 视频: 17-6 【服务拆分】实现 ad-binlog-common 模块 (09:23)
    • 视频: 17-7 【服务拆分】实现 ad-binlog-kafka 模块 (18:53)
    • 视频: 17-8 【注重理解】实现对 ad-search 模块的重构 (13:00)
    • 视频: 17-9 【正确性检验】广告检索微服务重构后的可用性测试 (09:59)
  • 第18章 (彩蛋番外篇三)分布式日志收集系统【全方位的开发过程,扩充自身知识面】 10 节 | 78分钟

    对于任何一个系统来说,特别对于多实例部署环境,日志收集都是不可或缺的。这一章里,我将完整的搭建 ELK(包括下载、安装、配置)实现分布式环境下的日志收集工作。

    收起列表

    • 视频: 18-1 【初识 ELK】ELK 的概念、功能和组织结构 (08:19)
    • 视频: 18-2 【更好的方案】Logstash 替换为 Filebeat (15:16)
    • 视频: 18-3 【边学边做】SpringBoot 项目的日志配置 (12:15)
    • 图文: 18-4 日志收集系统的说明
    • 图文: 18-5 SpringBoot 项目的日志配置
    • 视频: 18-6 【完整的构建过程】ELK 的下载、安装和配置 (20:20)
    • 视频: 18-7 【玩转ELK】启动 ELK 收集微服务日志 (11:05)
    • 视频: 18-8 【优化预处理】给 ES 创建 pipeline 实现对日志的预处理 (10:08)
    • 图文: 18-9 ELK 的下载、安装和配置
    • 图文: 18-10 给 ES 创建 pipeline
  • 第19章 (彩蛋番外篇四)常见问题解答【第一季】 7 节 | 45分钟

    本章中结合同学们在问答区以及讨论群中的问题,针对四大类常见问题进行了解答梳理,分别是SpringCloud 相关的问题、数据表与数据相关的问题、Binlog 相关的问题、Spring 与基础工具相关的问题。

    收起列表

    • 视频: 19-1 SpringCloud 相关问题(1) (06:34)
    • 视频: 19-2 SpringCloud 相关问题(2) (08:29)
    • 视频: 19-3 数据表与数据相关的问题(1) (06:08)
    • 视频: 19-4 数据表与数据相关的问题(2) (07:14)
    • 视频: 19-5 数据表与数据相关的问题(3) (05:26)
    • 视频: 19-6 Spring 与基础工具相关的问题(1) (04:05)
    • 视频: 19-7 Spring 与基础工具相关的问题(2) (06:07)
  • 第20章 (彩蛋番外篇五)关于 JPA,你知道多少 11 节 | 186分钟

    JPA 的出现,大大简化了对数据库/表的 CRUD 操作过程,其简单、便捷的特性已经深入人心,且获得了广大程序员的支持与肯定,使用范围也是非常广泛。在本课中对于数据库/表的操作,也都使用了 JPA。综合同学们在问答区与讨论区中关于JPA的疑问,也为了帮助大家能够更加优雅全面地认识JPA,特将彩蛋奉上,带你与JPA进一步...

    收起列表

    • 视频: 20-1 你需要知道 Spring Data Jpa 的概念和思想 (14:26)
    • 视频: 20-2 Jpa 应用前的准备工作(1) (12:59)
    • 视频: 20-3 Jpa 应用前的准备工作(2) (24:55)
    • 视频: 20-4 实体类定义 (15:33)
    • 视频: 20-5 给实体类定义 Repository 接口 (11:18)
    • 视频: 20-6 Repository 简单条件查询 (14:53)
    • 视频: 20-7 Repository 多条件与关键字查询 (08:52)
    • 视频: 20-8 使用 Query 注解自定义 SQL 查询 (21:53)
    • 视频: 20-9 原生查询并完成字段值到实体类的映射 (25:07)
    • 视频: 20-10 高效更新数据的方法 (13:29)
    • 视频: 20-11 使用 Sort 和 Pageable 完成排序和分页 (22:24)
本课程已完结

试看

全部试看小节



讲师

张勤一 资深架构师

高级技术专家,曾就职于微软、腾讯,目前就职于知名电商互联网公司,拥有丰富的大型项目开发经验。多年IT从业经验,一线软件设计、研发,熟悉C、CPP、Java等开发语言,对Web框架、数据存储、架构设计等有深入的理解和实践。

讲师其他课程

课程预览

检测到您还没有关注慕课网服务号,无法接收课程更新通知。请扫描二维码即可绑定
重新观看
意见反馈 帮助中心 APP下载
官方微信

学习咨询

选课、学习遇到问题?

扫码添加指导老师 1V1 帮助你!

添加后老师会第一时间解决你的问题