微服务: 强调的是服务的大小,他关注的是某一个点,是具体解决某一问题/提供落地对应服务的一个服务应用,狭义的看可以看作为eclipse里面的一个微服务工程/或者module ,每一个微服务都可以直接运行。
微服务架构:微服务架构是一种架构模式,它提倡将单一应用程序划分成一组小的服务,服务之间互相协调,互相配合,为用户提供最终价值,每一个服务运行都在其独立的进程中,服务与服务之间采用轻量级的通信机制互相协作(通常是基于HTTP协议的restful api)。每个服务都围绕着具体的业务进行构建,并且能够独立的部署到生产环境、类生产环境等。另外,应当尽量避免统一的、集中式的服务管理机制,对具体的一个服务而言,应根据业务上下文,选择合适的语言、工具对其进行构建。
微服务的优点:
1、每个服务足够内聚,足够小,代码容易理解,这样能聚焦一个指定的业务功能或业务需求
2、开发简单、开发效率提高,每一个服务可能就是专一的只干一件事
3、微服务是松耦合的,是有功能意义的服务,无论是在开发阶段或者部署阶段都是独立的。
4、微服务能使用不用的语言开发,和webservice类似
5、易于和第三方集成,微服务允许容易且灵活的方式集成自动部署,通过持续集成工具,如:Jenkins、Hudson、bamboo
6、微服务易于被一个开发人员理解,修改和维护,这样小团队能够关注自己的工作成果。无需通过合作才能体现价值
7、微服务允许你利用融合最新技术
8、微服务只是业务逻辑的代码,不会和html,css或者其他界面组件混合。
9、每个微服务都有自己的存储能力,可以有自己的数据库,也可以有统一数据库。
缺点:
1、开发人员需要处理分布式系统的复杂性
2、多服务运维难度,随着服务的增加,运维的压力也在增大
3、系统部署依赖
4、服务之间的通讯成本
5、数据、软件、系统集成测试、性能监控