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= 30 s;
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 服务治理
服务化带来的挑战: 服务越来越多,配置管理复杂 服务间依赖关系复杂 服务之间的负载均衡 服务的拓展 服务监控 服务降级 服务鉴权 服务上线与下线 服务文档 服务治理是一项系统工程包括:服务注册与发现、分布式配置下发与动态热加载、服务调用与负载均衡、容错与降级限流、网关与鉴权、内外网隔离、服务调度、服务存活与检测、调用链路与跟踪、业务功能可用性检查、持续发布与自动自治