认识微服务
单体架构:
简单方便,高度耦合,扩展性差,适合小型项目,例如,学生管理系统。
分布式架构
松耦合,扩展性好,但架构复杂,难度大。适合大型互联网项目。如,京东、淘宝。
微服务是一种经过良好架构设计的分布式架构方案,
特征:
- 单一职责:微服务拆分力度更小,每一个服务都对应唯一的业务能力,做到单一职责,避免重复业务开发。
- 面向服务:微服务对外暴露接口。
- 自治:团队独立、技术独立、数据独立、部署独立。
- 隔离性强:服务调用做好隔离、容错、降级、避免出现连级问题。
优点:拆分力度更小,服务更独立,耦合度低。
缺点:架构非常复杂,运维、监控、部署难度更高。
目前国内最知名的微服务框架就是springcloud和阿里巴巴的dubbo。
微服务技术对比
SpringCloud
目前国内使用最广泛的微服务架构,集成了各种微服务功能的组件,基于springboot实现了这些组件的自动装配。
springCloud与springboot版本对应
官网
服务的拆分和远程调用
服务拆分的注意事项
1.不同微服务,不重复开发相同的业务
2.微服务数据独立,不要访问其他微服务的数据库
3.微服务可以将自己的业务暴露为接口,供其他微服务调用