当前位置: 首页>后端>正文

智慧医疗 - 微服务最佳实践

01 产品分析与定位

智慧医疗 - 微服务最佳实践,第1张
产品定位于分析

02 微服务架构设计

智慧医疗 - 微服务最佳实践,第2张
微服务架构设计
  • 以业务为中心
  • 高内聚低耦合
  • 高度自治
  • 弹性设计
  • 日志与监控
  • 自动化

03 实时消息推送技术演进

智慧医疗 - 微服务最佳实践,第3张
实时消息推送技术演进
  • 接入层负载均衡基于http七层负载均衡,从HA演进到Nginx
  • HA支持TCP与Http协议,支持8种负载均衡策略,支持通过URL健康检测,支持心跳检测,工作在网络4层和7层,但对ws协议支持不好,造成ws消息堆积
  • Nginx支持Http协议,工作在网络7层,支持WebSocket协议,支持通过端口健康检测,支持强大的正则匹配规则
  • Nginx分流:
server 172.16.125.76:8066 weight=10;  
 server 172.16.125.76:8077 down;  
 server 172.16.0.18:8066 max_fails=3 fail_timeout=30s;  
 server 172.16.0.18:8077 backup;  
  • HA分流:
server web01 192.168.137.203:80  check inter 2000 fall 3 weight 10

04 请求接口幂等性

智慧医疗 - 微服务最佳实践,第4张
请求接口幂等性
  • 验证颗粒度小、框架层、业务层零侵入:filter、拦截器不ok,业务层注解AOP
  • 过滤重复请求:AOP环绕通知,前置通知检查key存在性、后置通知释放key,key已存在过滤请求
  • 并发请求:多线程查询key、创建key不ok,利用redis单线程+保证key操作原子性,引入分布式锁
  • key释放的原子操作:释放只能释放自己线程的key,发生异常要在finaly中释放,引入redis事务,watch监听key
  • 极端情况:正常业务耗时,而key过期了;redis主从或者集群,master节点崩溃,slave节点未升级,数据同步未成功造成数据丢失。引入redisson分布式java解决方案,定时key续约,集群数据分布式内存网格存储

05 服务治理

智慧医疗 - 微服务最佳实践,第5张
服务治理
  • 服务化带来的挑战:
  • 服务越来越多,配置管理复杂
  • 服务间依赖关系复杂
  • 服务之间的负载均衡
  • 服务的拓展
  • 服务监控
  • 服务降级
  • 服务鉴权
  • 服务上线与下线
  • 服务文档
  • 服务治理是一项系统工程包括:服务注册与发现、分布式配置下发与动态热加载、服务调用与负载均衡、容错与降级限流、网关与鉴权、内外网隔离、服务调度、服务存活与检测、调用链路与跟踪、业务功能可用性检查、持续发布与自动自治

https://www.xamrdz.com/backend/33d1941508.html

相关文章: