2016.8.8, 深圳, Ken Fang
微服务设计是架构设计。
所以, 微服务设计不应是一个讲求标准答案, 简单粗暴的设计过程。而应该是一个考量各方因素下的一个决策的过程。
所以, 在探讨微服务架构前, 我们先来探讨下, 所谓的微服务具体应包含哪些核心的概念?
I. 分布式 (Distributed):
微服务与微服务间分布式调用最主要的概念便是: protocol-aware heterogeneous interoperability; 各微服务可各自拥有自身的 platform (Java,C#, Scala…等等), 但, 各微服务间却只能藉由单一共同的协议 (protocol); 如: REST; 进行分布式的调用。
II. 分别部署 (Separately Deploy):
微服务架构的产品或许会有数百甚至数千个微服务所构成。所以, 部署微服务时, 便很难经由手工来完成, 而必须相当程度的依赖自动化的 DevOps 工具。
Service Registry And Discovery |
Deployment |
Monitoring |
Zookeeper Doozer Etcd SmartStack Eureka |