码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 微服务拆分


    熟悉黑马商城

    服务拆分原则

    什么时候拆分?

    • 创业型项目:先采用单体架构,快速开发,快速试错。随着规模扩大,逐渐拆分。
    • 确定的大型项目:资金充足,目标明确,可以直接选择微服务架构,避免后续拆分的麻烦。

    怎么拆分?

    从拆分目标来说,要做到:

    • 高内聚:每个微服务的职责要尽量单一,包含的业务相互关联度高、完整度高。
    • 低耦合:每个微服务的功能要相对独立,尽量减少对其它微服务的依赖。

    从拆分方式来说,一般包含两种方式:

    • 纵向拆分:按照业务模块来拆分
    • 横向拆分:抽取公共服务,提高复用性

    拆分服务

    将hm-service中与商品管理相关功能拆分到一个微服务module中,命名为item-service

    将hm-service中与购物车有关的功能拆分到一个微服务module中,命名为cart-service

    服务调用

    Spring给我们提供了一个RestTemplate工具,可以方便的实现Http请求的发送。使用步骤如下:

    1. 注入RestTemplate到Spring容器

    1. 发起远程调用

    总结

    什么时候拆分微服务?

    • 初创型公司或项目尽量采用单体项目,快速试错。随着项目发展到达一定规模再做拆分

    如何拆分微服务?

    • 目标:高内聚、低耦合。
    • 方式:纵向拆分、横向拆分

    拆分后碰到的第一个问题是什么,如何解决?

    • 拆分后,某些数据在不同服务,无法直接调用本地方法查询数据
    • 利用RestTemplate发送Http请求,实现远程调用

  • 相关阅读:
    设置HTTP代理隧道
    CLIP(Contrastive Language-Image Pretraining)
    如何安装 ONLYOFFICE Workspace丨安装教程丨使用教程
    MySQL---聚合函数
    RTSP 服务器实例 live555 源代码分析
    Qt 序列化函数和反序列化函数
    Anaconda和Python的区别
    关于视频流读取失败的时间问题解决 & 利用修饰符进行限时操作
    指数族分布(2):矩母函数、累积量生成函数
    writev()与readv()
  • 原文地址:https://blog.csdn.net/m0_60301012/article/details/139897963
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号