zoukankan      html  css  js  c++  java
  • 微服务设计 读书笔记 一

    1.1 什么是微服务
    微服务就是一些协同工作的小而自治的服务。
    1.1.1 专注于做好一件事
    随着新功能的增加,代码库会越变越大。时间久了代码库会非常庞大,以至于想要知道该在什么地方做修改都很困难。在一个单块系统内,通常会创建一些抽象层或者模块来保证代码的内聚性,从而避免上述问题。内聚性是将相关代码放在一起,在考虑使用微服务的时候,内聚性这一概念很重要。
    微服务将这一理念应用在独立的服务上。根据业务的边界来确定服务的边界,这样久很容易确定某个功能代码应该放在哪里。而且由于该服务专注于某个边界之内,因此可以很好地避免由于代码库过大衍生出的很多相关问题。
    1.1.2 自治性
    一个微服务就是一个独立的实体。它可以独立地部署在服务器上。尽量避免把多个服务部署到同一台机器上,尽管这种隔离性会引发一些代价,但它能够大大简化分布式系统的构建。
    服务之间通过网络调用进行通信,从而加强了服务之间的隔离性,避免紧耦合。
    对于一个服务来说,我们需要考虑的是什么应该暴露,什么应该隐藏。如果暴露得过多,那么服务消费方会与该服务的内部实现产生耦合。服务会暴露出API,然后服务直接通过这些API进行通信。API的实现技术应该避免与消费方耦合。
    1.2 主要好处
    1.2.1 技术异构性
    1.2.2 弹性
    1.2.3 扩展
    1.2.4 简化部署
    1.2.5 与组织结构相匹配
    1.2.6 可组合性
    1.2.7 对可替代性的优化

    松耦合
    如果做到了服务之间的松耦合,那么修改一个服务久不需要修改另一个服务。使用微服务最重要的一点是,能够独立修改及部署单个服务而不需要修改系统其他部分。
    高内聚
    把相关行为聚集在一起,把不相关的行为放在别处。如果你需要改变某个行为的话,最好能够在一个地方进行修改,然后就可以尽快地发布。如果需要在很多不同的地方做这些修改,那么可能就需要同时发布多个微服务才能交付这个功能。在多个不同的地方进行修改会很慢,同时部署多个服务风险也很高。
    限界上下文
    一个由显示边界限定的特定职责。
    当你在思考组织内限界上下文时,不应该从共享数据角度来考虑,而应该从这些上下文能够提供的功能来考虑。

    监控
    将系统拆分成更小的、细粒度的微服务会带来很多好处。然而它也增加了生产系统的监控复杂性。
    监控小的服务,然后聚合起来看整体。
    多个服务,多个服务器
    你如何在多个主机上的、成千上万行的日志中定位错误的原因?如何确定一个服务器异常,还是一个系统性的问题?如何在多个主机间跟踪一个错误的调用链,找出引起这个错误的原因?
    答案是,从日志到应用指标,集中收集和聚合尽可能多的数据到我们的手上。

  • 相关阅读:
    kvm添加磁盘
    python学习1
    ubuntu使sudo不需要密码
    磁盘挂载
    github/gitlab添加多个ssh key
    生成SSH key
    git 删除追踪状态
    angular2+ 初理解
    本地项目上传到GitHub
    new Date()之参数传递
  • 原文地址:https://www.cnblogs.com/kxm87/p/9865890.html
Copyright © 2011-2022 走看看