微服务架构设计模式-(16)重构

绞杀者应用程序

  • 由微服务组成的应用程序,将新功能作为服务,并逐步从单体应用中提取服务来实现。
  • 好处
    • 尽早并频繁的体现价值
      • 快速开发交付,使用
        • 与之相对的是“一步到位”重构,这时间长,且期间有新的功能加入,风险极高。
    • 尽可能减少对单体进行修改
      • 可用策略之一:将新服务的数据,同步到单体数据库。双写
  • 策略
    • 将新功能实现为服务
      • 元素
        • API Gateway
          • 新功能请求路由到新服务
        • 集成胶水代码
          • 使服务能够访问单体所拥有的数据,并能够使用单体的功能
    • 隔离表现层和后端
      • 单体的解耦策略
        • 表现逻辑层
          • 处理http请求,生成html页面
        • 业务逻辑层
          • 业务规则
        • 数据访问逻辑层
          • 访问基础服务,如数据库
      • 将应用程序分离
        • 表现层一个服务
        • 业务逻辑层和数据访问层一个服务
    • 通过将功能提取到服务来分解单体
      • 提取服务之前,问问自己这样做有什么好处
      • 服务边界问题
        • 新服务的逻辑需要使用到单体中的类
        • 解决方法
          • DDD聚合,使用主键来代替
            • 比如之间能在一个服务中,直接拿到对象来用,现在变成两个服务,把ID传过去,另一个服务用ID来引用对象(从数据库读取,或请求接口,获取完整对象)
      • 重构数据库
        • 为了避免单体更改,进行双写。客户端迁移完成之后,停止双写
      • 提取哪些服务,何时提取
        • 专注在能够带来最大收益的服务
          • 参考点
            • 加速开发
              • 比如说这块的功能后面几个月会有大量的需求迭代,可以提取出来成一个服务
            • 解决性能、可扩展性或可靠性问题
            • 允许提取其他一些服务
              • 有时候提取一个服务,会简化另一个服务的提取

为什么要重构单体

  • 交付缓慢
  • 充满故障的软件交付
  • 可扩展性差

服务与单体的协作方式

  • 重要问题
    • 维护服务与单体的数据一致性
      • 有时候需要saga来维护
  • 集成胶水
  • 反腐层
    • 两个不同领域模型之间进行转换,防止一个模型的概念污染另一个模型
  • 数据一致性
    • 视情况考虑saga
  • 身份验证和访问授权
    • api gateway
      • API gateway来验证用户身份,然后将用户身份信息放入header之中,请求服务的时候带上,那么服务就不需要验证用户是否登录了,直接从header中获取用户信息
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很抱歉,我无法提供PDF文件的下载。但是,对于微服务架构设计模式,你可以考虑参考以下两本书: 1. 喻勇翻译的《微服务架构设计模式》:这本书是近几年我所看到的众多论述微服务架构书籍中最好的一本。它深入浅出地介绍了微服务与SOA等其他架构的区别,讨论了微服务的架构设计、服务拆分策略、同步和异步通信模式、事务管理、业务逻辑设计等方面的内容。此外,它还详细描述微服务架构中的测试和生产部署策略。这本书所总结出的架构经验对设计微服务架构有很好的指导作用,建议软件研发人员认真研读。 2. Chris Richardson的《Java微服务架构设计模式》:这本书由微服务架构的先驱、Java开发者社区的意见领袖Chris Richardson亲自撰写。它旨在帮助架构师和程序员学会使用微服务架构成功开发应用程序。书中介绍了如何解决我们在微服务架构设计中面临的各种挑战,包括管理分布式数据、将单体应用程序重构微服务架构等。此外,书中还涵盖了44个架构设计模式,具体涉及服务拆分、事务管理、查询和跨服务通信等方面。这本书不仅介绍了微服务的原理和原则,还讲解了实际落地中的架构设计模式,使你能够全面理解微服务架构,并在实际应用中做出正确的架构选择和取舍。 这两本书都是专门讨论微服务架构设计模式的,并且提供了实际的代码例子,可以帮助你更好地理解和应用微服务架构设计模式。希望对你有帮助!<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [多位大厂专家鼎力推荐,44个微服务架构设计模式pdf,程序员福利](https://blog.csdn.net/shy111111111/article/details/128253809)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [微服务架构设计模式 PDF 电子书 百度云 网盘下载](https://blog.csdn.net/weixin_39713763/article/details/110624540)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值