java微服务和分布式的区别有哪些?
发布网友
发布时间:2022-04-23 17:28
我来回答
共2个回答
热心网友
时间:2022-04-04 05:29
这个问题已经收藏了一个多月了,一直在考虑如何回答这个问题,总结了很长时间终于有了一些感悟(之前一直都是只可意会不可言传的感觉),和大家分享一下,如果有不同的建议,欢迎大家留言指正。
分布式和微服务
首先 ,我认为微服务就是分布式框架的一种。
分布式的思想就是把一个系统的不同模块,部署在不同的服务器上,以应对高并发的问题。
SOA是一种分布式架构,把业务系统分成多个子系统,提供不同的服务,再通过服务组合、编排实现业务流程;通常在SOA架构中,ESB企业服务总线扮演了重要的角色。
微服务是SOA的升华,如果非要说点儿不同的,那么微服务更加强调服务的细分和专业,去ESB总线、去中心化,部署粒度更细,服务扩展更灵活。
微服务不只是技术架构
很多同学一说微服务,就说这是一种技术架构,有的推荐使用Dubbo,有的推荐使用Spring Cloud。
我认为,微服务不单单是一种技术架构,也涉及到了管理、组织架构。
大多数的公司,需求、开发、测试、运维都是独立的团队,这实际上是有悖于微服务快速迭代的思想;在微服务的架构下,一个服务应该是由一个团队全权负责的。
不过组织架构方面的事情,真的不是我们能说了算的。
必须要用微服务?
我觉得没有必要为了微服务,而微服务;有的公司把服务拆分,但是数据库依然是同一个库,依然是一个项目直接掉另外一个项目的接口,然后对外就宣称完成了微服务的改造...
架构设计还是要根据需求背景、团队开发能力、软硬件实力综合来考虑。
好的架构是可以进化的,而不是一步到位建成的。
我将持续分享Java开发、架构设计、程序员职业发展等方面的见解,希望能得到你的关注。
热心网友
时间:2022-04-04 06:47
Java是变成语言;
微服务是系统架构方式;
分布式是系统部署方式;