advanced-java/docs/micro-services/micro-service-governance.md

126 lines
2.2 KiB
Markdown
Raw Normal View History

# 微服务治理策略
2020-04-19 17:54:04 +08:00
## 服务的注册和发现
2020-10-02 15:28:46 +08:00
解决问题:集中管理服务
2020-10-02 15:28:46 +08:00
解决方法:
- Eureka
- Zookeeper
## 负载均衡
2020-10-02 15:28:46 +08:00
解决问题:降低服务器硬件压力
解决方法:
2020-10-02 15:28:46 +08:00
- Nginx
- Ribbon
## 通讯
2020-10-02 15:28:46 +08:00
解决问题:各个服务之间的沟通桥梁
解决方法:
2020-10-02 15:28:46 +08:00
- REST同步
- RPC同步
- MQ异步
## 配置管理
2020-10-02 15:28:46 +08:00
解决问题:随着服务的增加配置也在增加,如何管理各个服务的配置。
2020-10-02 15:28:46 +08:00
解决方法:
- Nacos
- Spring Cloud Config
- Apollo
## 容错和服务降级
2020-10-02 15:28:46 +08:00
解决问题:在微服务当中,一个请求经常会涉及到调用几个服务,如果其中某个服务不可以,没有做服务容错的话,极有可能会造成一连串的服务不可用,这就是雪崩效应。
2020-10-02 15:28:46 +08:00
解决方法:
2020-10-02 15:28:46 +08:00
- Hystrix
2020-10-02 15:28:46 +08:00
## 服务依赖关系
2020-10-02 15:28:46 +08:00
解决问题:多个服务之间来回依赖,启动关系的不明确。
2020-10-02 15:28:46 +08:00
解决方法:应用分层。
## 服务文档
2020-10-02 15:28:46 +08:00
解决问题:降低沟通成本
2020-10-02 15:28:46 +08:00
解决方法:
- Swagger
- Java doc
## 服务安全问题
2020-10-02 15:28:46 +08:00
解决问题:敏感数据的安全性
解决方法:
2020-10-02 15:28:46 +08:00
- Oauth
- Shiro
- Spring Security
## 流量控制
2020-10-02 15:28:46 +08:00
解决问题:避免一个服务上的流量过大拖垮整个服务体系
解决方法:
2020-10-02 15:28:46 +08:00
- Hystrix
## 自动化测试
2020-10-02 15:28:46 +08:00
解决问题:提前预知异常,确定服务是否可用
2020-10-02 15:28:46 +08:00
解决方法:
2020-10-02 15:28:46 +08:00
- junit
2020-10-02 15:28:46 +08:00
## 服务上线,下线的流程
2020-10-02 15:28:46 +08:00
解决问题:避免服务随意的上线下线
解决方法:新服务上线需要经过管理人员审核,服务下线需要告知各个调用方进行修改,直到没有调用该服务才可以进行下线。
## 兼容性
2020-10-02 15:28:46 +08:00
解决问题:服务开发持续进行如何做到兼容。
2020-10-02 15:28:46 +08:00
解决方法:通过版本号的形式进行管理,修改完成进行回归测试。
## 服务编排
2020-10-02 15:28:46 +08:00
解决问题:解决服务依赖问题的一种方式
解决方法:
2020-10-02 15:28:46 +08:00
- Docker
- K8s
## 资源调度
2020-10-02 15:28:46 +08:00
解决问题:每个服务的资源占用量不同,如何分配
解决方法:
2020-10-02 15:28:46 +08:00
- JVM 隔离
- Classload 隔离
- 硬件隔离
## 容量规划
2020-10-02 15:28:46 +08:00
解决问题:随着时间增长,调用逐步增加,什么时候追加机器。
2020-10-02 15:28:46 +08:00
解决方法:统计每日调用量和响应时间,根据机器情况设置阈值,超过阈值就可以追加机器。