标签:交换机 and 解耦 返回 消息队列 形式 更新 大致 一个
(持续更新到找到工作...)
单点登录系统(SSO)(采用JWT + RSA)
阐述:用户只需要登录一次就可以访问所有相互信任的应用系统,实现无状态登录
流程:
我们首先利用RSA生成公钥和私钥,私钥保存在授权中心,公钥保存到 Zuul网关 和 各个服务
用户请求登录,服务端验证,将查询到的用户部分信息存入 JWT
使用私钥对 JWT进行签名加密 返回 JWT 给客户端
用户访问服务( 携带JWT ) 网关验证通过放行
到达微服务,微服务直接使用公钥解析 JWT 获取其中的用户信息
从 cookie 中获取对应的 token,取不到视为未登录,重定向到登录页面(网关的拦截器干的事情)
实现购物车商品数据同步(localStorage + redis)
阐述: 用户可以在登录和未登录下实现购物的添加
流程:
如果用户尚未登录,放入localStorage (HTML 5web本地储存,前端完成)
如果用户已经登录,让入redis ( 购物车读写频率高 )
查询购物车:
尚未登录: 查询 localStorage
已经登录:查询 localStorage是否有数据,有的话上传到 redis 合并,没有的话直接访问 redis
redis 中数据的储存形式: 购物车结构为一个双层Map :Map<String,Map<String,String>>
第一层Map: key为用户id
第二层Map key 为购物车中商品 id ,value为购物车数据(手动序列化存入)
什么是负载均衡
当服务器遇到高并发时,为了不让服务器崩溃,建立服务器集群来共同抵御高并发,实现服务的高可用
负载均衡的底层是反向代理实现的
RabbotMQ消息队列
作用: 通过异步的方式实现系统解耦完成系统间的通信(postman?)
原理: 有五种消息模型,但大致的原理为:消息生产者向 交换机/队列 推送信息,消息消费者从队列中拉取消息并完成相应逻辑
如何避免消息丢失:
1: 消费者的ACK消息确认机制;(如果忘记确认,会导致内存泄漏,最后宕机)
2: 消息的持久化 (需要将队列 ,交换机都持久化 )
标签:交换机 and 解耦 返回 消息队列 形式 更新 大致 一个
原文地址:https://www.cnblogs.com/msi-chen/p/10520081.html