『壹』 Java EE的基本学习路线是什么
可从事岗位:初级JAVA软件工程师
Java核心编程(15天) JavaSE编程基础 介绍JavaEE的应用领域及整体技术体系,生态圈,以及当前就业环境。强调学习纪律及相关约定,讲师的个人介绍;DOS常用命令;安装JDK、设置环境变量;DOS系统编译、执行Java程序;Java的注释;标识符、标识符的命名规范;Java 关键字;Java的数据类型;变量的定义及初始化;Java的运算符;表达式;转义字符;运算符的优先级;类型转换;Java分支if...else;多重if、嵌套if;Java switch;switch vs if;Java循环 for、while 、do-while;循环的嵌套;break、continue、return;方法的定义;方法的形参和实参;无返回值的方法;有返回值的方法;方法的重载
Java数组 Java 数组的定义;数组的静态赋值;数组的动态赋值;数组单个元素的访问;数组的遍历访问;数组的增强for循环;数组的排序;数组的顺序查找;数组的二分法查找;命令行参数args的使用;可变参数的应用;Arrays工具类的使用;二维数组的使用
Java面向对象 面向对象的分析与设计;面向对象与面向过程的区别;Java与面向对象;类的定义;对象的定义;类中成员变量及方法的定义;构造方法的定义和调用;构造方法的重载;面向对象的封装特性;this调用属性、方法、构造方法;局部变量和成员变量的作用域问题;static静态属性、方法、代码块;工具类的概念及工具类的制作;super关键字的使用及理解;Java中访问权限控制机制;继承中构造方法的细节;方法的重写;equals及toString方法的正确理解;Java中的包机制;抽象类,接口,多态;对象的转型;final修饰类、属性、方法;抽象类,接口;多态机制;内部类;通过内部类制作性能检测工具;Java的内存分析
常用基础类 常用数据类型的包装类;String、StringBuffer、StringBuilder;Date的使用;SimpleDataFormate对日期和字符串之间的转换处理;Calendar日历类的使用;Math常用方法;Random类;Runtime类;System 类;Java8特性
集合 集合框架体系介绍;集合框架与数组的对比;集合框架之Collection接口;集合框架之List接口;ArrayList和LinkedList的使用;深入源码探究ArrayList和LinkedList的工作原理;迭代器的工作原理;迭代器的使用;集合框架之Set;HashSet和TreeSet的使用;深入源码探究HashSet和TreeSet的工作原理;HashMap和TreeMap的使用;分析Map和Set的之间的关系;Collections工具类
异常处理 Java的异常体系;异常的概念及分类;异常的处理方式;异常设计原则;自定义异常
线程和I/O I/O;NIO;文件操作;多线程;线程池;同步;线程调度;多线程下载;网络http、socket;基于HTTP协议访问网络资源、XML解析;文件的下载;ThreadLocal
项目 FTP服务器、多人聊天服务器
第二阶段:JavaWeb实战(25天)
可从事岗位:WEB初级前端开发工程师,初级BI工程师
JavaWeb实战(25天) HTML5 HTML的作用;全局标签;绝对路径与相对路径;常见标签;字符集;表单标签;布局指定的网页
CSS3 CSS声明类型;常见的各种属性;圆角属性:border-radius的使用;阴影属性:box-shadow的用法;背景属性扩展:多背景应用;新的颜色表示方式:HSLA色轮模式;浮动;完成自己的初级课页面实战
Javascript JavaScript基本语法;JavaScript数据类型;JavaScript对象和常用对象;history对象;location对象;bom对象;表单对象;DOM对象;window对象;常用事件;选项卡、幻灯片、贪吃蛇、瀑布流各种特效
MySQL使用 Mysql数据库;MySql命令行客户端的使用;MySql图形化客户端的使用;SQL语句介绍;DDL;DML;DQL;多表的联合查询;子查询;排序、聚合、分组
JDBC连接池 JDBC的介绍;采用JDBC实现CRUD;采用PrepareStatement防止SQL注入,提高安全性
Servlet Tomcat与idea的集成开发;什么是Servlet;Servlet接收客户端请求信息;Servlet响应客户端信息;Servlet的生命周期;什么是JSP;JSP的内置对象;透析JSP的本质;JSTL+EL;MVC介绍;分层的重要性;MySql的事务特性;MySql的事务实现;Session的使用;Cookie的使用;实现系统的安全控制;DBCP连接池的使用;C3P0连接池的使用;DBUils;实现用户的自动登录;文件的上传;文件的下载;过滤器解决编码问题;过滤器解决安全验证问题;监听器;反射、注解、泛型
MVC 设计模式;ORM原理;自定义框架
ajax Ajax的工作原理;JSON解析;Ajax 数据格式(XML格式、HTML格式、JSON格式、各种格式对比);使用 jQuery 实现 Ajax(load()方法、$.get()方法、$.post()方法、序列化、Ajax应用);聊天室小实例
jQuery jQuery选择器;jQuery的常用事件;事件冒泡;事件委派;jQuery中的动化;模拟操作;jQuery综合实例
Bootstrap 响应式设计;Bootstrap安装;Bootstrap 组件;进度条和列表组件;Bootstrap综合实例
项目 讲解项目开发流程;项目简介;项目功能演示;项目功能实现分析;数据库设计分析;项目架构设计分析;实现网站首页的商品展示;实现商品详情页面;实现购物车功能;实现我的订单管理;项目验收
第三阶段:企业核心框架(30天)
可从事岗位:中级BI工程师,JAVA微服务研发工程师
企业核心框架(30天) Linux基础 Linux系统-基础;Linux网络基础;VMWare下安装Linux;Linux命令;Linux下Java环境的搭建;Linux下Tomcat安装和配置
maven Maven简介和环境搭建;Maven构建和自动化构建;pom.xml详细说明、依赖管理;Maven坐标、依赖、生命周期等;IDEA下的Maven使用
Git Git概述、Git与SVN对比;Git常用命令;Git分支以及代码冲突的解决;客户端TortoiseGit使用;IDEA中Git集成使用
Spring5 框架原理介绍;框架环境搭建;快速入门;创建Bean的方式及实现原理;Bean种类;Bean生命周期;Bean的作用域;Bean的注值方式;SpEL;整合Junit测试;Web项目集成Spring;注解装配Bean;AOP思想;AOP原理解剖;传统方式实现AOP开发;AspectJ介绍及实现AOP开发
SpringMVC Spring MVC 概述;使用 @RequestMapping映射请求;请求处理方法签名概述;处理方法签名详细说明;使用 HttpMessageConverter;处理模型数据;数据绑定流程剖析;数据转换;数据格式化;数据校验;视图和视图解析器;处理方法的数据绑定
MyBatis 安装和配置MyBatis;使用映射语句;执行非查询语句;使用高级查询技术;事务;使用动态SQL;使用高速缓存提高性能;MyBatis数据访问对象;DAO使用进阶
项目整合 使用SSM开发实际项目;通过项目理解框架
SpringData Spring Data 概述;Repository;CrudRepository;PagingAndSortingRepository;JpaRepository;条件查询;使用@Query自定义查询;@Query 与 @Modifying 执行更新操作;索引参数与命名参数;用@Query来指定本地查询;为某一个 Repository 上添加自定义方法;所有的 Repository 都添加自定义的方法
Maven高级 pom文件依赖传递介绍;Maven继承与聚合项目;私服仓库介绍和搭建;公共模块上传到私服、引用私服jar包;Maven常用插件使用;使用Maven的profile实现多环境配置
Gitlab/Jenkins Gitlab使用;持续集成工具Jenkins使用;Jenkins+Gitlab+maven+tomcat实现自动集成、打包、部署
WebSocket WebSocket原理介绍;WebSocket的使用
RESTful http协议;RESTful规范;postman使用;spring 实现 RESTful
ECharts图表插件 图表介绍和选择什么样的图表;5分钟快速上手;常用API和模块;移动端自适应
项目一 10个大型项目选择;各种项目特点分析;项目设计;项目分组;选择框架;后台搭建;使用Maven构建项目;项目开发;压力测试;webhooks项目自动部署;面试中常问到的项目问题;项目bug收集和解决;项目验收;项目答辩
第四阶段:高并发和分布式应用(40天)
可从事岗位:服务端架构师, 平台架构师
高并发和分布式应用(40天) Nginx反向代理和负载均衡 Nginx服务器的优势;Nginx服务器配置;什么是反向代理;什么是负载均衡;负载均衡算法;构建数十台服务器的负载均衡环境
Docker Docker介绍;Docker安装;Docker 常见操作;Docker 自定义镜像;Docker Compose服务编排;Docker Compose 安装Nexus;Docker Compose 安装 Gitlab;Docker Compose 安装 Docker Registry;基于Gitlab实现CI
UML和常用工具的使用 UML介绍以及在软件开发中的应用;UML常用图的绘制以及使用;Enterprise Architect的使用;结合UML知识对项目做需求分析;结合UML知识对项目做架构设计以及技术选型
亿级并发架构演进 架构演进特点;大并发架构;微服务
MySQL高级 ACID和MySQL的实现原理;SQL优化技巧;MySQL分区;分库分表技巧;Explain分析
MyCat分库分表技术 MyCat介绍;分库分开技术讲解;其他的数据库中间件;配置与自动分表
Vue Vue 入门;Vue 语法;Vue 事件;Axios 网络通信;Vue表单输入;Vue 计算属性;Vue内容分发与自定义事件;Vue-cli脚手架;Vue-Router 路由;Vuex 状态管理
SpringBoot SpringBoot基本介绍和使用;SpringBoot的核心功能;SpringBoot开发web项目;SpringBoot整合Junit以及MockMvc的使用;SpringBoot集成Swagger;Spring Data JPA 的使用;SpringBoot整合MyBatis
Shiro Authentication;Authorization;Role;编程授权;Realm;Realms的认证实现;Realms的授权实现;Spring 集成 Shiro;基于注解的授权
CAS 单点登录介绍;CAS单点登录配置;CAS MD5配置;CAS 盐值MD5;CAS整合Shiro
Zookeeper/Consul Zookeeper 简介;Zookeeper安装;Zookeeper高可用集群;Curator-API;Zookeeper分布式锁;统一配置管理;Consul使用
Dubbo Dubbo简介;Spring整合Dubbo2.6x使用;Dubbo管控台;Springboot 2.x整合bbo 2.6x;Dubbo负载均衡;Dubbo集群容错
Spring Cloud SpringCloud之 微服务简介;SpringCloud之 Eureka;SpringCloud之 Ribbon;SpringCloud之 Feign;SpringCloud之 HyStrix;SpringCloud之 Zuul;SpringCloud之Stream;SpringCloud之Sleuth;SpringCloud之 ConfigServer;微服务安全解决方案:Oauth2/JWT
Redis NoSQL&Redis;Redis特点与优势以及使用场景;Redis主从、哨兵、集群模式安装配置;Redis持久化策略、淘汰策略;Redis五大数据类型和基本操作命令;SpringBoot集成Lettuce API;SpringBoot集成Redisson API分布式场景应用
Elasticsearch ElasticSearch简介;ElasticSearch基础入门;ElasticSearch集群以及Kibana和分词插件的安装;ElasticSearch索引、分片创建与管理;ElasticSearch基本搜索;ElasticSearch组合搜索;Elasticsearch全文检索,高亮显示;Elasticsearch Java High Level REST Client使用
RabbitMQ 队列 RabbitMQ 简介;RabbitMQ 安装;RabbitMQ账户;RabbitMQ消息模式;Spring整合RabbitMQ;SpringBoot整合RabbitMQ;消息确认机制;消息延迟队列;RabbitMQ高可用集群
分布式事务 分布式事务场景;分布式事务解决方案;CAP理论;两段提交协议;三段提交协议;MQ事务消息;TX-LCN/TCC-Transaction
分布式任务(Quartz/Elastic-Job) Quartz基本使用;Quartz不同触发器;Quartz自动化任务;Spring定时任务;Spring整合Quartz;Elastic-Job分布式任务
微信开发 微信公众号;微信支付;微信小程序
综合项目实战 15个大型项目选择;各种项目特点分析;项目设计;项目分组;选择框架;后台搭建;使用Maven构建项目;项目开发;压力测试;项目自动部署;面试中常问到的项目问题;项目bug收集和解决;项目上线;项目验收;项目答辩
『贰』 想要系统学习java到底要学习哪些知识
学习Java之前先了解这些:
第一:在如今这个Java的市场下,你如果太过于着急找工作而去学习,你一定找不到,有一个很简单的道理,任何东西求快没有用,首先你要把技术学的熟练。而不是指望自己看看视频,就能拿到高薪的工作。
第二:如果没有一套系统的学习路线和方案,这看看,那里看看,依旧学了之后还是浪费时间,根据我的学习经历来看,任何人学习任何东西,需要一气呵成,在这段时间内,学习什么就一刻都不能松懈,今天看点视频,明天有事,不看了,这样没啥意义。
第三:在如今这个IT市场,Java开发工作竞争越来越激烈,如果你是小白转行的,那么建议你找个好的机构培训学习下,不要心疼钱,你要知道有付出才有回报,投资自己什么时候都是对的选择,先找些基础资料自己自学一段时间看看到底适合自己不,不要盲目的学习。
第四:如果你在学习中没有很多的代码量的话,不多去做案例的话,我个人觉得学了跟没学一样,第二次你见到它可能还是不认识它。最好是有个问的人,一个外行想通过自学Java开发区找工作,太难了,尤其是在这个行情中。既然学习就学好,不要三天打鱼两天晒网的,还不如不学习了,要谦虚,不要学点就自大。
第五:作为一个Java初学者,我们应该需要知道从零基础到就业,需要掌握的技术知识点有哪些,这个时候我建议你上各大招聘平台看下,看下现在的岗位需求是什么,以此这就是我们学习的目标。
所有语言的知识体系分为三大块:
数据存储 (内存,文件,数据库,分布式,集群, 关系型 ,非关系型 。。)
业务逻辑 (业务需求,语言语法,算法,类库框架,性能优化等)
信息交互(展示)(多端,app,小程序,公众号,移动端,pc端,web开发等。。)
这三块知识作为学习来说,可以有侧重,但是不能有某一块完全不懂。
另给你分享一个Java的学习路线:
如果需要学习的资料,可私聊回复“资料”获取~
希望能帮到你,望采纳!!
『叁』 spring cloud feign和zuul的区别
zuul作为整个应用的流量入口,接收所有的请求,如app、网页等,并且将不同的请求转发至不同的处理微服务模块,其作用可视为nginx。
feign则是将当前微服务的部分服务接口暴露出来,并且主要用于各个微服务之间的服务调用。
两者的应用层次以及原理均不相同。
『肆』 zuulfilter 怎么使用环境变量
路由是微服务架构的不可或缺的一部分。例如:”/” 可能映射到你应用主页,/api/users映射到用户服务,/api/shop映射到购物服务。Zuul。Zuul是Netflix出品的一个基于JVM路由和服务端的负载均衡器。
Netflix uses Zuul for the following:
* Authentication
* Insights
* Stress Testing
* Canary Testing
* Dynamic Routing
* Service Migration
* Load Shedding
* Security
* Static Response handling
* Active/Active traffic management
Zuul的规则和过滤器允许使用各种基于JVM的语言,支持基于Java和Groovy。
注意:zuul.max.host.connections已经被两个新的属性替代:zuul.host.maxTotalConnections 和 zuul.host.maxPerRouteConnections,默认分别为200和20.
注意:默认所有routes的Hystrix隔离模式(ExecutionIsolationStrategy)是SEMAPHORE zuul.ribbonIsolationStrategy可以改为THREAD,如果这个隔离模式更好。
『伍』 springcloud执行流程
1.Servlet
zuul.servletPath默认配置为/zuul,故请求为/zuul开头的会跳过dispatcherServlet直接进入ZuulServlet,该配置可以自定义配置,例如用于大文件上传
2.ZuulServlet中service方法
public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
try {
this.init((HttpServletRequest)servletRequest, (HttpServletResponse)servletResponse);
RequestContext context = RequestContext.getCurrentContext();
context.setZuulEngineRan();
try {
//运行pre过滤器
this.preRoute();
} catch (ZuulException var12) {
//有异常,执行errorFilter
this.error(var12);
//再执行postFilter
this.postRoute();
return;
}
try {
//运行rote过滤器
this.route();
} catch (ZuulException var13) {
//有异常,执行errorFilter
this.error(var13);
//再执行postFilter
this.postRoute();
return;
}
try {
//运行post过滤器
this.postRoute();
} catch (ZuulException var11) {
//有异常,执行errorFilter
this.error(var11);
}
} catch (Throwable var14) {
this.error(new ZuulException(var14, 500, "UNHANDLED_EXCEPTION_" + var14.getClass().getName()));
} finally {
RequestContext.getCurrentContext().unset();
}
}
3.FilterProcessor
其运行交由FilterProcessor中的方法runFilters,根据service中的顺序,取不同的filter类型,执行其中的run方法
public Object runFilters(String sType) throws Throwable {
if (RequestContext.getCurrentContext().debugRouting()) {
Debug.addRoutingDebug("Invoking {" + sType + "} type filters");
}
boolean bResult = false;
List<ZuulFilter> list = FilterLoader.getInstance().getFiltersByType(sType);
if (list != null) {
for(int i = 0; i < list.size(); ++i) {
ZuulFilter zuulFilter = (ZuulFilter)list.get(i);
Object result = this.processZuulFilter(zuulFilter);//见下面zuulFilter的runFilter()
if (result != null && result instanceof Boolean) {
bResult |= ((Boolean)result).booleanValue();
}
}
}
return bResult;
}
zuulFilter的runFilter方法,当filter的shouldFilter()返回true时才执行run()方法
public ZuulFilterResult runFilter() {
ZuulFilterResult zr = new ZuulFilterResult();
if (!this.isFilterDisabled()) {
if (this.shouldFilter()) {
Tracer t = TracerFactory.instance().startMicroTracer("ZUUL::" + this.getClass().getSimpleName());
try {
Object res = this.run();
zr = new ZuulFilterResult(res, ExecutionStatus.SUCCESS);
} catch (Throwable var7) {
t.setName("ZUUL::" + this.getClass().getSimpleName() + " failed");
zr = new ZuulFilterResult(ExecutionStatus.FAILED);
zr.setException(var7);
} finally {
t.stopAndLog();
}
} else {
zr = new ZuulFilterResult(ExecutionStatus.SKIPPED);
}
}
return zr;
}
4.获取过滤器FilterRegistry
其中的属性private final ConcurrentHashMap<String, ZuulFilter> filters = new ConcurrentHashMap();
保存所有的过滤器
例子中有12个(其中有两个为自定义的):
[org.springframework.cloud.netflix.zuul.filters.route.SimpleHostRoutingFilter@3dc68586,
org.springframework.cloud.netflix.zuul.filters.pre.Servlet30WrapperFilter@4001d8c1,
org.springframework.cl
『陆』 Zuul配置项中sensitiveHeaders和ignoredHeaders的不同
路由是微服务架构的不可或缺的一部分。例如:”/” 可能映射到你应用主页,/api/users映射到用户服务,/api/shop映射到购物服务。Zuul。Zuul是Netflix出品的一个基于JVM路由和服务端的负载均衡器。
Netflix uses Zuul for the following: * Authentication * Insights * Stress Testing * Canary Testing * Dynamic Routing * Service Migration * Load Shedding * Security * Static Response handling * Active/Active traffic management
Zuul的规则和过滤器允许使用各种基于JVM的语言,支持基于Java和Groovy。
注意:zuul.max.host.connections已经被两个新的属性替代:zuul.host.maxTotalConnections 和 zuul.host.maxPerRouteConnections,默认分别为200和20.
注意:默认所有routes的Hystrix隔离模式(ExecutionIsolationStrategy)是SEMAPHORE zuul.ribbonIsolationStrategy可以改为THREAD,如果这个隔离模式更好。
org.springframework.cloud and artifact id spring-cloud-starter-zuul。See the Spring Cloud Project page for details。
当一个UI应用想要代理调用一个或者多个后台服务的时候,Sping cloud创建了一个嵌入的Zuul proxy很方便的开发一个简单的案例。这个功能对于代理前端需要访问的后端服务非常有用,避免了所有后端服务需要关心管理CORS和认证的问题.
在Spring Boot主函数上通过注解 @EnableZuulProxy 来开启, 这样可以让本地的请求转发到适当的服务. 按照约定, 一个ID为”users”的服务会收到 /users 请求路径的代理请求(前缀会被剥离). Zuul使用Ribbon定位服务注册中的实例, 并且所有的请求都在hystrix的command中执行, 所以失败信息将会展现在Hystrix metrics中, 并且一旦断路器打开, 代理请求将不会尝试去链接服务.
注意:Zuul starter没有包含服务发现的客户端, 所以对于路由你需要在classpath中提供一个根据service IDs做服务发现的服务.(例如, eureka是一个不错的选择)
『柒』 Java培训班一般都教什么内容
1、Java基础
初识Java:Java入门,Java基础,Java使用技巧
面向对象编程:Java面向对象编程理论与应用,集合框架与数据结构,Java文件操作与网络编程
数据库理论与应用:数据存储的概念及理论,数据库技术及产品的发展史,当下流行数据库MySQL和Oracle数据库的使用
互联网网站及信息系统的开发与应用:网站页面及效果设计,交互式网站开发技术及开发流 程,网站开发框架及简单企业开发应用
2、java中级
企业团队项目协同开发与维护:协同开发概述,协同开发技术原理与应用
商业项目模块化基础与应用:软件项目自动化构建概述,自动化构建原理,自动化构建技术与应用
软件项目测试与实施:软件测试概述,软件测试流程及测试工具使用,测试档案及测试用例编写,测试报告分析
企业主流开发框架应用与优化:框架技术概述,框架技术发展史,主流框架介绍,主流框架的使用,整合多个框架综合开发项目
3、java高级
网站及信息管理系统的视觉美化:网站前端视觉美化概述,网站前端UI概述,网站前端UI框架概述,主流网站前端UI使用
网站及信息管理系统性能调优:分布式系统概述,数据缓存概述,分布式数据缓存技术及工具的使用
网站及信息管理系统业务个性化定制:企业定时任务与邮件发送业务,企业统计报表及网络服务业务,企业搜索引擎业务
4、java资深
分布式项目管理与项目构建:分布式概述,分布式特点与问题,分布式项目开发工具概述与使用
Java前沿框架解析:Java前沿框架概述,Java前沿框架优势与未来趋势,Java 前沿框架的使用与项目整合
蓝鸥OA:企业真实项目实战:项目概述,团队项目开发流程概述与实施,项目开发工具使用,项目流程与质量控制,项目测试与项目发布,项目实施与项目维护
『捌』 ZuulFilter 如何判断当前请求是否下载文件
于这种,我说两种方法:
1、将你所有的JSP页面单独放在一个文件夹里(假如jspPage),jspPage文件夹里可根据类别分若干子文件夹,再把相对应的JSP放在子文件夹里;
JS、CSS及图片等分别放在外面的文件夹里(与文件夹jspPage并列)
再:<url-pattern>/jspPage/*</url-pattern>就行了
一般用的就是这种
2、在过滤的JAVA文件中,在doFilter方法里进行判断,将后缀名为.css、.js等直接设置为通过就行了,这种较为复杂,在一些特殊情况下才用到,一般不推荐
『玖』 zuul怎么实现单点登录
Zuul作为整个系统的网关,有几样工作特别适合:
路由,Zuul的天职
负载均衡,Zuul 2.0的性能还是可以期待的
日志,由于外部的请求都经过Zuul因此它的日志处理是非常重要和必要的
鉴权,同样由于外部服务都经过Zuul,鉴权也是非常合适的,因此对于SpringCloud体系来说做CAS的单点登录的集成Zuul是最合适不过的。
我们Zuul也是基于SpringBoot,因此可以使用Spring Security的套路实现CAS的拦截与验证等工作。
简单的总结一下:
将CAS集成放到Zuul上
使用Spring Security套餐
但同时我们也知道Zuul还要处理日志,因此要将CAS与Zuul本身的职责协调好,同时我们也都知道Zuul核心是ZuulFilter,而SpringSecurity实质上也是一系列的Filter来处理,把这两套Fillter理清楚是搞定这个问题的先决条件。目前最单点登录的公司其实是有一些的,但是真正有技术实力的其实并不是很多。如果说非得推荐一家的话,比如玉符科技SSO,我了解了一下,他们的产品还是不错的。
『拾』 有了sprint cloud的zuul,还有用nginx的必要么
这是两个概念,nginx是做负载均衡请求转发,更多被用作负载均衡器使用的;zuul是请求转发,一般用来做网关的,zuul配合eureka来使用,zuul功能也很强大,nginx要做这些功能也是可以,但是需要各种脚本语言来支持,比如lua脚本等,但是zuul来说的话开发成本就低很多,懂spring就够了。
这块还会设计到一些分布式原子化问题,我都是一个坑一个坑踩过来的,有什么问题可以继续探讨,建议还是多了解一下spring cloud的核心思想,把整个分布式架构了解一下。如有问题欢迎追问,谢谢!