一、在学习软件构造、设计相关知识时,你们应该有学习到内聚性的概念:即把因相同缘由而变化的东西聚合到一块儿,而把因不一样缘由而变化的东西分离开来。而数据库
微服务将这个理念应用在独立的服务上。根据业务的边界来肯定服务的边界,这样就很容 易肯定某个功能代码应该放在哪里。
我我的以为,微服务就是将原来的单体应用安装功能进行切分,而后各个服务之间经过通讯(跨进程、跨机器)来共同完成原来的单体应用所提供的功能。
微服务对比与原来的单体应用,有它的优点,如服务的自治性加强、但同时也会带来一些其余问题,如性能、复杂度等问题。架构
二、想要使用微服务,首先是要清楚哪些业务或者功能应该成为单独的服务。《微服务设计》一书中给了一些建议:分布式
当你在思考组织内的限界上下文时,不该该从共享数据的角度来考虑,而应该从这些上下 文可以提供的功能来考虑。
这个上下文是作什么用的。
组织结构和软件架构会互相影响。
固然,书中列出的建议不止这些,我也想谈一谈我本身的一些想法。微服务
若有不正确的地方,欢迎指正交流。性能