当前位置: 首页 > news >正文

模板手机网站建设公司排名北京黑马计算机培训机构

模板手机网站建设公司排名,北京黑马计算机培训机构,长沙企业网站建设报价,邢台信息港招聘一、问题拆解 1.1、客户端如何访问这些服务 原来的Monolithic方式开发#xff0c;所有的服务都是本地的#xff0c;UI可以直接调用#xff1b;现在按功能拆分成独立的服务#xff0c;跑在独立的虚拟机上的Java进程了。客户端UI如何访问他的#xff1f; 后台有N个服务所有的服务都是本地的UI可以直接调用现在按功能拆分成独立的服务跑在独立的虚拟机上的Java进程了。客户端UI如何访问他的 后台有N个服务前台就需要记住管理N个服务一个服务下线/更新/升级前台就要重新部署这明显不符合我们拆分的理念特别当前台是移动应用的时候通常业务变化的节奏更快。 另外N个小服务的调用也是一个不小的网络开销。还有一般微服务在系统内部通常是无状态的用户登录信息和权限管理最好有一个统一的地方维护管理OAuth。 所以一般在后台N个服务和UI之间一般会一个代理或者叫API Gateway他的作用包括 1、提供统一服务入口让微服务对前台透明 2、聚合后台的服务节省流量提升性能 3、提供安全过滤流控等API管理功能 其实这个API Gateway可以有很多广义的实现办法可以是一个软硬一体的盒子也可以是一个简单的MVC框架甚至是一个Node.js的服务端。他们最重要的作用是为前台通常是移动应用提供后台服务的聚合提供一个统一的服务出口解除他们之间的耦合不过API Gateway也有可能成为单点故障点或者性能的瓶颈。 用过Taobao Open Platform淘宝开放平台的就能很容易的体会TAO就是这个API Gateway 1.2、每个服务之间如何通信 所有的微服务都是独立的Java进程跑在独立的虚拟机上所以服务间的通信就是IPCinter process communication已经有很多成熟的方案。现在基本最通用的有两种方式 同步调用 1、RESTJAX-RSSpring Boot Spring Boot 最全基础教程https://github.com/javastacks/spring-boot-best-practice 2、RPCThrift, Dubbo 3、异步消息调用(Kafka, Notify, MetaQ) 1.2.1、REST 一般REST基于HTTP更容易实现更容易被接受服务端实现技术也更灵活些各个语言都能支持同时能跨客户端对客户端没有特殊的要求只要封装了HTTP的SDK就能调用所以相对使用的广一些。 1.2.2、RPC RPC也有自己的优点传输协议更高效安全更可控特别在一个公司内部如果有个统一的开发规范和统一的服务框架时他的开发效率优势更明显些。就看各自的技术积累实际条件自己的选择了。 1.2.3、异步消息 而异步消息的方式在分布式系统中有特别广泛的应用他既能减低调用服务之间的耦合又能成为调用之间的缓冲确保消息积压不会冲垮被调用方同时能保证调用方的服务体验继续干自己该干的活不至于被后台性能拖慢。 不过需要付出的代价是一致性的减弱需要接受数据最终一致性还有就是后台服务一般要实现幂等性因为消息发送出于性能的考虑一般会有重复保证消息的被收到且仅收到一次对性能是很大的考验最后就是必须引入一个独立的broker如果公司内部没有技术积累对broker分布式管理也是一个很大的挑战。 1.3、如此多的服务如何实现 1.3.1、负载均衡 在微服务架构中一般每一个服务都是有多个拷贝来做负载均衡。一个服务随时可能下线也可能应对临时访问压力增加新的服务节点。服务之间如何相互感知服务如何管理 1.3.2、如何发现服务 这就是服务发现的问题了。一般有两类做法也各有优缺点。基本都是通过zookeeper等类似技术做服务注册信息的分布式管理。 1、当服务上线时服务提供者将自己的服务信息注册到ZK或类似框架并通过心跳维持长链接实时更新链接信息。 2、服务调用者通过ZK寻址根据可定制算法找到一个服务还可以将服务信息缓存在本地以提高性能。 3、当服务下线时ZK会发通知给服务客户端。 客户端做优点是架构简单扩展灵活只对服务注册器依赖。缺点是客户端要维护所有调用服务的地址有技术难度一般大公司都有成熟的内部框架支持比如Dubbo。 服务端做优点是简单所有服务对于前台调用方透明一般在小公司在云服务上部署的应用采用的比较多。 1.4、服务挂了如何解决备份方案应急处理机制 前面提到Monolithic方式开发一个很大的风险是把所有鸡蛋放在一个篮子里一荣俱荣一损俱损。而分布式最大的特性就是网络是不可靠的。通过微服务拆分能降低这个风险不过如果没有特别的保障结局肯定是噩梦。所以当我们的系统是由一系列的服务调用链组成的时候我们必须确保任一环节出问题都不至于影响整体链路。 相应的手段有很多 1、重试机制 2、限流 3、熔断机制 4、负载均衡 4、降级本地缓存 这些方法基本都很明确通用比如Netflix的Hystrixhttps://github.com/Netflix/Hystrix 二、常见的设计模式和应用 有一个图非常好的总结微服务架构需要考虑的问题包括 1、API Gateway 2、服务间调用 3、服务发现 4、服务容错 5、服务部署 6、数据调用 六种常见的微服务架构设计模式 2.1、聚合器微服务设计模式 这是一种最常见也最简单的设计模式 聚合器调用多个服务实现应用程序所需的功能。它可以是一个简单的Web页面将检索到的数据进行处理展示。它也可以是一个更高层次的组合微服务对检索到的数据增加业务逻辑后进一步发布成一个新的微服务这符合DRY原则。另外每个服务都有自己的缓存和数据库。如果聚合器是一个组合服务那么它也有自己的缓存和数据库。聚合器可以沿X轴和Z轴独立扩展。 2.2、代理微服务设计模式 这是聚合模式的一个变种如下图所示 在这种情况下客户端并不聚合数据但会根据业务需求的差别调用不同的微服务。代理可以仅仅委派请求也可以进行数据转换工作。 2.3、链式微服务设计模式 这种模式在接收到请求后会产生一个经过合并的响应如下图所示 在这种情况下服务A接收到请求后会与服务B进行通信类似地服务B会同服务C进行通信。所有服务都使用同步消息传递。在整个链式调用完成之前客户端会一直阻塞。 因此服务调用链不宜过长以免客户端长时间等待。 2.4、分支微服务设计模式 这种模式是聚合器模式的扩展允许同时调用两个微服务链如下图所示 2.5、数据共享微服务设计模式 自治是微服务的设计原则之一就是说微服务是全栈式服务。但在重构现有的“单体应用monolithic application”时SQL数据库反规范化可能会导致数据重复和不一致。 因此在单体应用到微服务架构的过渡阶段可以使用这种设计模式如下图所示 在这种情况下部分微服务可能会共享缓存和数据库存储。不过这只有在两个服务之间存在强耦合关系时才可以。对于基于微服务的新建应用程序而言这是一种反模式。 2.6、异步消息传递微服务设计模式 虽然REST设计模式非常流行但它是同步的会造成阻塞。因此部分基于微服务的架构可能会选择使用消息队列代替REST请求/响应如下图所示 三、优点和缺点 3.1、微服务的优点 关键点复杂度可控独立按需扩展技术选型灵活容错可用性高 ①它解决了复杂性的问题。它会将一种怪异的整体应用程序分解成一组服务。虽然功能总量 不变但应用程序已分解为可管理的块或服务。每个服务都以RPC或消息驱动的API的形式定义了一个明确的边界Microservice架构模式实现了一个模块化水平。 ②这种架构使每个服务都能够由专注于该服务的团队独立开发。开发人员可以自由选择任何有用的技术只要该服务符合API合同。当然大多数组织都希望避免完全无政府状态并限制技术选择。然而这种自由意味着开发人员不再有义务使用在新项目开始时存在的可能过时的技术。在编写新服务时他们可以选择使用当前的技术。此外由于服务相对较小因此使用当前技术重写旧服务变得可行。 ③Microservice架构模式使每个微服务都能独立部署。开发人员不需要协调部署本地服务的变更。这些变化可以在测试后尽快部署。例如UI团队可以执行A | B测试并快速迭代UI更改。Microservice架构模式使连续部署成为可能。 ④Microservice架构模式使每个服务都可以独立调整。您可以仅部署满足其容量和可用性限制的每个服务的实例数。此外您可以使用最符合服务资源要求的硬件。 3.2、微服务的缺点 关键点挑战系统部署依赖服务间通信成本数据一致性系统集成测试重复工作性能监控等 ①一个缺点是名称本身。术语microservice过度强调服务规模。但重要的是要记住这是一种手段而不是主要目标。微服务的目标是充分分解应用程序以便于敏捷应用程序开发和部署。 ②微服务器的另一个主要缺点是分布式系统而产生的复杂性。开发人员需要选择和实现基于消息传递或RPC的进程间通信机制。此外他们还必须编写代码来处理部分故障因为请求的目的地可能很慢或不可用。 ③微服务器的另一个挑战是分区数据库架构。更新多个业务实体的业务交易是相当普遍的。但是在基于微服务器的应用程序中您需要更新不同服务所拥有的多个数据库。使用分布式事务通常不是一个选择而不仅仅是因为CAP定理。许多今天高度可扩展的NoSQL数据库都不支持它们。你最终不得不使用最终的一致性方法这对开发人员来说更具挑战性。 ④测试微服务应用程序也更复杂。服务类似的测试类将需要启动该服务及其所依赖的任何服务或至少为这些服务配置存根。再次重要的是不要低估这样做的复杂性。 ⑤Microservice架构模式的另一个主要挑战是实现跨越多个服务的更改。例如我们假设您正在实施一个需要更改服务AB和C的故事其中A取决于B和B取决于C.在单片应用程序中您可以简单地更改相应的模块整合更改并一次性部署。相比之下在Microservice架构模式中您需要仔细规划和协调对每个服务的更改。例如您需要更新服务C然后更新服务B然后再维修A.幸运的是大多数更改通常仅影响一个服务而需要协调的多服务变更相对较少。 ⑥部署基于微服务的应用程序也更复杂。单一应用程序简单地部署在传统负载平衡器后面的一组相同的服务器上。每个应用程序实例都配置有基础架构服务如数据库和消息代理的位置主机和端口。相比之下微服务应用通常由大量服务组成。例如每个服务将有多个运行时实例。更多的移动部件需要进行配置部署扩展和监控。此外您还需要实现服务发现机制使服务能够发现需要与之通信的任何其他服务的位置主机和端口。传统的基于故障单和手动操作的方法无法扩展到这种复杂程度。因此成功部署微服务应用程序需要开发人员更好地控制部署方法并实现高水平的自动化。 四、思考意识的转变 微服务对我们的思考更多的是思维上的转变。对于微服务架构 技术上不是问题意识比工具重要。 关于微服务的几点设计出发点 1、应用程序的核心是业务逻辑按照业务或客户需求组织资源这是最难的 2、做有生命的产品而不是项目 3、头狼战队全栈化 4、后台服务贯彻Single Responsibility Principle单一职责原则 5、VM-Docker to PE 6、DevOps (to PE) 同时对于开发同学有这么多的中间件和强大的PE支持固然是好事我们也需要深入去了解这些中间件背后的原理知其然知其所以然在有限的技术资源如何通过开源技术实施微服务 最后一般提到微服务都离不开DevOps和Docker理解 微服务架构是核心devops和docker是工具是手段。
http://www.dnsts.com.cn/news/153874.html

相关文章:

  • 外贸公司网站怎么做网站到期续费通知
  • 做网站前景怎么样高端企业网站报价
  • 个人网站备案后可以做行业内容吗有哪些官网做的比较好的网站
  • 网站维护的具体方法北京网络营销招聘网
  • 网站建设费 开办费中国建筑信息平台
  • wordpress仿站教程网进出长春最新规定
  • 电影网站建设模板购物网站开发软件
  • 如何开一个自己的网站开发手机app价格
  • 基于html的个人网站的设计与实现论文百度识图软件
  • 网站dedecms数据库手机做网站的网站
  • 网上去哪里找做网站的wordpress基本功能
  • 广州网站优化快速获取排名上海千途建站
  • 婚庆网站设计专业做棋牌网站的
  • 做毕业设计一个网站的数据来源公司网站模板怎么写
  • 想自己做网站需要会什么科技网站欣赏
  • 电商网站设计的准则是什么商丘网络有限公司
  • 做外贸业务去哪些网站kali钓鱼网站制作
  • 免费的个人网站公司网上注册流程
  • 怎么做网站横幅网络科技公司简介模板
  • dede系统做的网站如何调用cu3er官网flash 3d焦点图怎么用dw建设自己的网站
  • 郑州企业网站快速优化多少钱嘉兴网站建设服务
  • Ie8网站后台编辑文章c2c网站的特点
  • 网站建立不安全怎么取消企业如何做好网站运营管理
  • 根据一个网站仿做新网站是什么网站做网站编辑累不累
  • 葫芦岛做网站的公司北京宣传片制作公司
  • 广州网站建设 易企建站公司视频 主题 wordpress
  • 关于外贸的网站酒店房产网站建设
  • wordpress代码缩进灯塔seo
  • 建设个人网站ip做海报有什么参考的网站
  • 网站备案接入商变更赌粉在哪个平台引流