目录程序员
1、微服务编程
一、服务化拆分的两种姿式性能优化
二、服务化拆分的前置条件网络
2、微服务组件架构
一、服务描述并发
二、注册中心框架
三、服务框架异步
四、服务监控编程语言
五、服务追踪分布式
六、服务治理
微服务架构是一种将单应用程序做为一套微型服务开发的方法,每种应用程序都在其本身的进程中运行,并与轻量级机制(一般是HTTP资源的API)进行通讯。这些服务是围绕业务功能构建的,能够经过全自动部署机制进行独立部署。这些微服务的将集中化管理部分降到最少,同时,微服务还能够用不一样的编程语言编写,并使用不一样的数据存储技术。
服务化拆分的两种姿式
服务化拆分的前置条件
程序员进阶
服务描述
服务调用首先要解决的问题就是服务如何对外描述。好比,你对外提供了一个服务,那么这个服务的服务名叫什么?调用这个服务须要提供哪些信息?调用这个服务返回的结果是什么格式的?该如何解析?这些就是服务描述要解决的问题。简单来讲就是接口文档。
经常使用的服务描述方式包括RESTful API、XML配置以及IDL文件三种。
注册中心
你提供了一个服务,如何让外部想调用你的服务的人知道。这个时候就须要一个相似注册中心的角色,服务提供者将本身提供的服务以及地址登记到注册中心,服务消费者则从注册中心查询所须要调用的服务的地址,而后发起请求。
服务框架
服务通讯采用什么协议?就是说服务提供者和服务消费者之间以什么样的协议进行网络通讯,是采用四层TCP、UDP协议,仍是采用七层HTTP协议,仍是采用其余协议?
数据传输采用什么方式?就是说服务提供者和服务消费者之间的数据传输采用哪一种方式,是同步仍是异步,是在单链接上传输,仍是多路复用。
数据压缩采用什么格式?一般数据传输都会对数据进行压缩,来减小网络传输的数据量,从而减小带宽消耗和网络传输时间,好比常见的JSON序列化、Java对象序列化以及Protobuf序列化等。
服务监控
一旦服务消费者与服务提供者之间可以正常发起服务调用,你就须要对调用状况进行监控,以了解服务是否正常。
服务追踪
你还须要记录服务调用通过的每一层链路,以便进行问题追踪和故障定位。
服务治理
服务监控可以发现问题,服务追踪可以定位问题所在,而解决问题就得靠服务治理了。服务治理就是经过一系列的手段来保证在各类意外状况下,服务调用仍然可以正常进行。好比自动扩缩容,就能够用来解决服务的容量问题。
顺便给你们推荐一个Java技术交流群:710373545里面会分享一些资深架构师录制的视频资料:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化、分布式架构等这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多!
做者:摘星不想说话 连接:https://juejin.im/post/5ce25058e51d45105773e63f 来源:掘金 著做权归做者全部。商业转载请联系做者得到受权,非商业转载请注明出处。