玩转 Spring 全家桶
丁雪丰
美团研究员,《Spring Boot 实战》、《Spring 攻略》译者,腾讯云 TVP。
97978 人已学习
新⼈⾸单¥68
课程目录
已完结/共 123 讲
第十一章:Spring Cloud及Cloud Native概述 (5讲)
玩转 Spring 全家桶
登录|注册
留言
59
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 17 | 开始我们的线上咖啡馆实战项目:SpringBucks
00:00 / 00:00
高清
  • 高清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.75x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看
01 | Spring课程介绍
02 | 一起认识Spring家族的主要成员
03 | 跟着Spring了解技术趋势
04 | 编写你的第一个Spring程序
05 | 如何配置单数据源
06 | 如何配置多数据源
07 | 那些好用的连接池们:HikariCP
08 | 那些好用的连接池们:Alibaba Druid
09 | 如何通过Spring JDBC访问数据库
10 | 什么是Spring的事务抽象(上)
11 | 什么是Spring的事务抽象(下)
12 | 了解Spring的JDBC异常抽象
13 | 课程答疑(上)
14 | 课程答疑(下)
15 | 认识Spring Data JPA
16 | 定义JPA的实体对象
17 | 开始我们的线上咖啡馆实战项目:SpringBucks
18 | 通过Spring Data JPA操作数据库
19 | Spring Data JPA的Repository是怎么从接口变成Bean的
20 | 通过MyBatis操作数据库
21 | 让MyBatis更好用的那些工具:MyBatis Generator
22 | 让MyBatis更好用的那些工具:MyBatis PageHelper
23 | SpringBucks实战项目进度小结
24 | 通过Docker辅助开发
25 | 在Spring中访问MongoDB
26 | 在Spring中访问Redis
27 | Redis的哨兵与集群模式
28 | 了解Spring的缓存抽象
29 | Redis在Spring中的其他用法
30 | SpringBucks实战项目进度小结
31 | Project Reactor介绍(上)
32 | Project Reactor介绍(下)
33 | 通过Reactive的方式访问Redis
34 | 通过Reactive的方式访问MongoDB
35 | 通过Reactive的方式访问RDBMS
36 | 通过AOP打印数据访问层的摘要(上)
37 | 通过AOP打印数据访问层的摘要(下)
38 | SpringBucks实战项目进度小结
39 | 编写第一个Spring MVC Controller
40 | 理解Spring的应用上下文
41 | 理解请求的处理机制
42 | 如何定义处理方法(上)
43 | 如何定义处理方法(下)
44 | Spring MVC中的视图解析机制(上)
45 | Spring MVC中的视图解析机制(下)
46 | Spring MVC中的常用视图(上)
47 | Spring MVC中的常用视图(下)
48 | 静态资源与缓存
49 | Spring MVC中的异常处理机制
50 | 了解Spring MVC的切入点
51 | SpringBucks实战项目进度小结
52 | 课程答疑
53 | 通过RestTemplate访问Web资源
54 | RestTemplate的高阶用法
55 | 简单定制RestTemplate
56 | 通过WebClient访问Web资源
57 | SpringBucks实战项目进度小结
58 | 设计好的RESTful Web Service(上)
59 | 设计好的RESTful Web Service(下)
60 | 什么是HATEOAS
61 | 使用Spring Data REST实现简单的超媒体服务(上)
62 | 使用Spring Data REST实现简单的超媒体服务(下)
63 | 分布式环境中如何解决Session的问题
64 | 使用WebFlux代替Spring MVC(上)
65 | 使用WebFlux代替Spring MVC(下)
66 | SpringBucks实战项目进度小结
67 | 认识Spring Boot的组成部分
68 | 了解自动配置的实现原理
69 | 动手实现自己的自动配置
70 | 如何在低版本Spring中快速实现类似自动配置的功能
71 | 了解起步依赖及其实现原理
72 | 定制自己的起步依赖
73 | 深挖Spring Boot的配置加载机制
74 | 理解配置背后的PropertySource抽象
75 | 认识Spring Boot的各类Actuator Endpoint
76 | 动手定制自己的Health Indicator
77 | 通过Micrometer获取运行数据
78 | 通过Spring Boot Admin了解程序的运行状态
79 | 如何定制Web容器的运行参数
80 | 如何配置容器支持HTTP/2(上)
81 | 如何配置容器支持HTTP/2(下)
82 | 如何编写命令行运行的程序
83 | 了解可执行Jar背后的秘密
84 | 如何将Spring Boot应用打包成Docker镜像文件
85 | SpringBucks实战项目进度小结
86 | 简单理解微服务
87 | 如何理解云原生(Cloud Native)
88 | 12-Factor App(上)
89 | 12-Factor App(下)
90 | 认识Spring Cloud的组成部分
91 | 使用Eureka作为服务注册中心
92 | 使用Spring Cloud Loadbalancer访问服务
93 | 使用Feign访问服务
94 | 深入理解服务发现背后的DiscoveryClient
95 | 使用Zookeeper作为服务注册中心
96 | 使用Consul作为服务注册中心
97 | 使用Nacos作为服务注册中心
98 | 如何定制自己的DiscoveryClient
99 | SpringBucks实战项目进度小结
100 | 使用Hystrix实现服务熔断(上)
101 | 使用Hystrix实现服务熔断(下)
102 | 如何观察服务熔断
103 | 使用Resilience4j实现服务熔断
104 | 使用Resilience4j实现服务限流(上)
105 | 使用Resilience4j实现服务限流(下)
106 | SpringBucks实战项目进度小结
107 | 基于Git的配置中心(上)
108 | 基于Git的配置中心(下)
109 | 基于Zookeeper的配置中心
110 | 深入理解Spring Cloud的配置抽象
111 | 基于Consul的配置中心
112 | 基于Nacos的配置中心
113 | SpringBucks实战项目进度小结
114 | 认识Spring Cloud Stream
115 | 通过Spring Cloud Stream访问RabbitMQ
116 | 通过Spring Cloud Stream访问Kafka
117 | SpringBucks实战项目进度小结
118 | 通过Dapper理解链路治理
119 | 使用Spring Cloud Sleuth实现链路追踪
120 | 如何追踪消息链路
121 | 除了链路还要治理什么
122 | SpringBucks实战项目进度小结
123 | 结课测试&结束语
本节摘要

PDF 课件和源代码下载地址:

https://gitee.com/geektime-geekbang/geektime-spring-family

猜你喜欢

unpreviewunpreview

登录 后留言

全部留言(59)

  • 最新
  • 精选
Francis_Lee
置顶
老师,在对象实体图中,order和coffee是1对多,但是在代码里面为什么是@ManyToMany呢

作者回复: 抱歉,这里Keynote的一对多应该是多对多,应该是n而不是1,图上标的不对,我联系极客时间的同学修改下视频中的Keynote。感谢反馈。

2019-02-22
22
扇子
老师您好!经查阅网络,共享相关资料如下:   子类继承基类后,使用@Data注解会有编辑器底色警告,告知你在生成hashcode等过程中,基类的内容不会被生成。此时,要添加@EqualsAndHashCode(callSuper=true)即可手动标记子类hash时要调用父类的hash方法对属于父类的部分内容生成哈希值。此时就不会报警告了。(包括下面那句@ToString(callSuper = true)也是一样)   如果觉得此方式比较麻烦的话(每个类都要),可设置lombok的配置文件lombok.config来解决:   ①lombok.config文件需要放在src/main/java文件夹下的目录中(也可以放在实体同级目录下),其它位置无效。内容如下: config.stopBubbling=true lombok.equalsAndHashCode.callSuper=call   ②然后,在pom加入插件: <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin>   此时,可见@Data编辑器警告底色消失。

作者回复: 多谢分享。

2019-02-22
45
Link大魔王
使用joda.money 对比直接使用BigDecimal来描述金额 有什么更突出的优点呢?

作者回复: 金额不止是一个小数,它还有货币单位之类的东西,复杂的还有货币转换,各种汇率之类的问题。用Money类型可以明确地表示我这个属性是个货币,也更容易区分。

2019-02-22
26
苏健
BaseEntity虽然有@MapperSuperclass 注解,但是id等属性都是私有的,为何子类还是能够继承

作者回复: 这是Hibernate的注解,可以加在属性上,也可以写在Getter方法上,如果想深入理解可以查阅一下Hibernate的文档。如果我把注解写在Getter方法上,你是否可以理解Getter方法是public的,子类是能继承到的,对于Java POJO而言,getter/setter才是让别人看到属性的地方,而不是内部的field。不知道这么举例说明你能否明白。

2020-04-04
11
nickyang
请问下,为什么表示订单状态的ENUM的属性,在表里面该字段会变成int类型呢。谢谢。

作者回复: 就是这么转换的,枚举转成int,一直都这么用,好像我还真没想过为什么

2019-02-26
2
9
Jesus
老师,你好,我在使用Spring Data JPA 开发的过程中,遇到了一个没有主键,没有索引的表,这种实体类改如何写?我尝试过不配置主键,结果应用起不来;我尝试过配置第一个column为主键(用@Id注释第一个属性),结果findAll()时候会有重复数据出现(与sql工具查询出来的结果不一致),但是使用count()方法结果与数据库符合。麻烦老师帮忙解答,谢谢!

作者回复: JPA是要求实体要有ID的,不过也有绕过的办法,比如用复合主键IdClass,或者参考下这里给出的常见解决方案 https://en.wikibooks.org/wiki/Java_Persistence/Identity_and_Sequencing#No_Primary_Key

2019-05-13
6
日拱一兵
老师,项目中对于持久层框架的选择上是应用JPA还是Mybaits,您有相关的建议吗?

作者回复: 简单的东西就用JPA吧。一旦东西复杂了,两者的区别就不大了,而且一般大厂都希望对SQL的控制粒度更细一点,所以都选MyBatis,建议别裸用,结合些工具更好

2019-03-06
6
海罗沃德
有两个问题 首先使用hibernate自动drop表这种操作只能在本地或者测试环境,甚至测试环境都不适合drop表,那么如何区分不同环境中的配置,以保证不要一部署直接表就清空了的情况 第二个问题,如果利用hibernate的反向映射成表,那么在生产环境上要如何建表,总不能等着软件发布时候才通过hibernate建表吧,此外这种建表方式是否是区分数据库,如果换一个库要如何匹配对应的建表语句?

作者回复: 1. 是用来本地做测试用的,区分环境我们一般都是用Maven和Spring的profile,这个在讲Spring Boot的配置文件时我们会讲到不同profile的配置文件如何使用。 2. 产线都是实现建的,你也可以用一些类似Flyway的工具来帮助进行数据表的维护,但正常情况下这活都是DBA提前搞好的,不会等着让Hibernate在启动时干这些的。 如果是测试,就是想让它建,Hibernate的建表语句是它根据Dialect自己处理的,你不用操心具体的语法。

2019-07-06
5
天涯囧侠
你好,为什这使用两个注解@CreationTimestamp @UpdateTimestamp,在数据库中插入的时间比本地时间晚13个小时?请问默认使用的是什么时区?如何改成默认使用Utc时间?多谢

作者回复: 不是插的时间不对,而是JSON序列化输出时的时区不对,后面的例子里会有指定格式化TimeZone的例子的

2019-03-12
5
shaohsiung
为什么baseentity实现了序列化接口,子类还要再实现一遍呢?

作者回复: 抱歉,我是先写的子类,然后抽象上父类的,就全带上了,想都没想这个问题……不过话说回来,一般只有在需要序列化的情况下再去实现这个接口的,我们在写DO的时候其实并不需要序列化,那都是在Facade上或者Web上的。

2019-02-21
5
收起评论