回目录 《微服务架构》
首先微服务是啥,微服务首先是一种架构思想, 首先最初的很多产品都是单体monolithic架构,所有的服务都紧紧耦合在一个解决方案中,难以扩展,只能通过加cpu加内存的方式扩展,举例一个电商平台, 刚开始所有功能都放在一个解决方案,比如托管在Apache的一个war或者托管在iis的一个.net mvc程序或者一个jar包程序, 随着项目的发展,团队的壮大,单体会变得庞大,产生很多问题:
1.所有的功能都在一起,任何一处bug都会引起整个程序终止对外提供服务
2.所有团队都在同一个项目上开发,冲突难以避免
所以我们需要将功能拆分开,比如商家系统、买家系统、管理后台系统等,面向业务或者叫服务切分,分而治之,这种粒度的就是SOA架构,
其显著缺点:
1.从技术的角度,其实业务的切分在技术层面上仍然会有大面积的重叠,因此如果业务切割的不好,形成各种依赖,有可能在修改时牵一发而动全身
2.从业务角度来说,由于是业务的切分,所以当需要发展新的业务时就需要重新构建一个完全新的服务,不利于基于业务创新和发现
所以引入微服务的概念,微服务进一步将服务自底向上或自上到下做更细的切分,最下面是基础系统服务(短信、邮件、存储、缓存、消息推送等),中间是共享服务(支付系统、订单系统、仓储系统等), 最上面则是业务层(零售系统、团购系统、采购系统),比如我们要加一个闪购业务也是很轻松的,不用从底到上再来一遍,只需要基于基础服务和共享服务做业务开发
微服务的优点:
1.某个微服务down掉不会影响其他微服务(如果之间有调用关系,可以使用fallback机制)
2.可以在高峰时段对比较繁忙的微服务单独动态增加机器资源
3.更容易通过组合多个微服务来发现形成新的业务
在单体结构中,某个复杂的业务事务逻辑可能涉及到多个功能调用,由于是在同一个单体程序中比如单个JVM内部,可以使用传统的事务来处理,而在微服务中不同的微服务跑在不同的JVM,由于是跨微服务的调用,事务控制就要采用其他方法,
采用kafka的exactly once语义;
采用alibaba-seata 微服务分布式事务4种解决方案实战
不同的微服务之间如何交互,同一个微服务的多个副本如何协同分配任务
API调用+nginx反向代理
注册中心zookeeper+RPC调用; 注册中心nacos+restAPI调用+ribbon负载均衡+feign接口
基于消息的订阅
相关技术实现:
注册中心: zookeeper nacos
单体解决方案有单点故障我们都清楚,其实微服务也存在单点故障,比如机票预订系统,假设用户预订机票会调用BookingService, 然后BookingService会调用另外几个微服务:
//创建账单
orderService.createOrder();
//
//增加用户积分
userCreditService.increase();
//给用户发邮件
//给航班调度安排部门发信息
当然你可能说一般都是分几步做的,比如创建订单,付款,然后才会增加积分和后续操作,这里我们只是举例,并非真实业务场景;
下订单后调用加积分,如果积分服务挂掉,不应该影响下订单的主要业务, 单点故障: 1)启动多个相同服务,可以缓解单点故障 2)业务依赖的单点故障, 最简单做法try catch加积分的调用,更好方法是采用sentinel(可以用feign加fallback)
1)认证授权:
传统基于session: 传统的单体应用可能习惯了session的存在,而到了Spring cloud的微服务化后,session虽然可以采取分布式会话来解决,但终究不是上上策。开始有人推行Spring Cloud Security结合很好的OAuth2,后面为了优化OAuth 2中Access Token的存储问题,提高后端服务的可用性和扩展性,有了更好Token验证方式JWT(JSON Web Token)。这里要强调一点的是,OAuth2和JWT这两个根本没有可比性,是两个完全不同的东西。 OAuth2是一种授权框架,而JWT是一种认证协议
有很多客户端,手机、网站、第三方,甚至网站还有各种二级网站需要支持sso,传统做法是登录后将session放到缓存比如redis,
基于token: 但是对于亿级用户级别,采用基于token的方式
2)请求路由
LVS负载均衡=>nginix=>网关系统gateway(spring.cloud.gateway)+请求路由
限流:
最原始redis计数器,更好的办法是使用sentinel
微服务的误读与误解 https://cloud.tencent.com/developer/article/1139783?areaSource=106002.19