01 产品分析与定位
02 微服务架构设计
- 以业务为中心
- 高内聚低耦合
- 高度自治
- 弹性设计
- 日志与监控
- 自动化
03 实时消息推送技术演进
- 接入层负载均衡基于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;
server web01 192.168.137.203:80 check inter 2000 fall 3 weight 10
04 请求接口幂等性
- 验证颗粒度小、框架层、业务层零侵入: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 服务治理
- 服务化带来的挑战:
- 服务越来越多,配置管理复杂
- 服务间依赖关系复杂
- 服务之间的负载均衡
- 服务的拓展
- 服务监控
- 服务降级
- 服务鉴权
- 服务上线与下线
- 服务文档
- 服务治理是一项系统工程包括:服务注册与发现、分布式配置下发与动态热加载、服务调用与负载均衡、容错与降级限流、网关与鉴权、内外网隔离、服务调度、服务存活与检测、调用链路与跟踪、业务功能可用性检查、持续发布与自动自治