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

内部网站制作优化手机网站

内部网站制作,优化手机网站,公司logo设计费用,SEO做得最好的网站1.雪崩问题 级联失败或雪崩问题指的是在微服务架构中#xff0c;由于服务间的相互依赖和调用#xff0c;当一个服务出现故障时#xff0c;会引起调用它的服务也出现故障#xff0c;进而引发整个调用链路的多个服务都出现故障#xff0c;最终导致整个系统崩溃的现象。 产生…1.雪崩问题 级联失败或雪崩问题指的是在微服务架构中由于服务间的相互依赖和调用当一个服务出现故障时会引起调用它的服务也出现故障进而引发整个调用链路的多个服务都出现故障最终导致整个系统崩溃的现象。 产生雪崩原因 服务依赖微服务架构中服务之间通过远程调用相互依赖一旦某个服务出现问题就会影响到依赖它的其他服务。故障传播当一个服务出现故障时如果没有有效的隔离和恢复机制故障会沿着调用链传播导致更多的服务受到影响。资源耗尽如果某个服务占用了过多的系统资源如CPU、内存、网络带宽等会导致其他服务无法获取足够的资源而出现故障。 2.微服务保护 2.1微服务保护方案 微服务保护的方案有很多比如 请求限流 线程隔离 服务熔断 这些方案或多或少都会导致服务的体验上略有下降比如请求限流降低了并发上限线程隔离降低了可用资源数量服务熔断降低了服务的完整度部分服务变的不可用或弱可用。因此这些方案都属于服务降级的方案。但通过这些方案服务的健壮性得到了提升。 2.1.1请求限流 服务故障最重要原因就是并发太高。解决了这个问题就能避免大部分故障。当然接口的并发不是一直很高而是突发的。因此请求限流就是限制或控制接口访问的并发流量避免服务因流量激增而出现故障。 请求限流往往会有一个限流器数量高低起伏的并发请求曲线经过限流器就变的非常平稳。这就像是水电站的大坝起到蓄水的作用可以通过开关控制水流出的大小让下游水流始终维持在一个平稳的量。 2.1.2线程隔离 线程隔离也叫做舱壁模式模拟船舱隔板的防水原理。通过限定每个业务能使用的线程数量而将故障业务隔离避免故障扩散。 当一个业务接口响应时间长而且并发高时就可能耗尽服务器的线程资源导致服务内的其它接口受到影响。所以我们必须把这种影响降低或者缩减影响的范围。 为了避免某个接口故障或压力过大导致整个服务不可用我们可以限定每个接口可以使用的资源范围也就是将其“隔离”起来。 如图所示我们给业务2限定可用线程数量上限为4这样即便服务C而出现故障也不会导致服务器的线程资源被耗尽不会影响到其它接口。 2.1.3服务熔断 线程隔离虽然避免了雪崩问题但故障服务商品服务依然会拖慢购物车服务服务调用方的接口响应速度。而且商品查询的故障依然会导致查询购物车功能出现故障购物车业务也变的不可用了。 所以我们要做两件事情 编写服务降级逻辑就是服务调用失败后的处理逻辑根据业务场景可以抛出异常也可以返回友好提示或默认数据。 异常统计和熔断统计服务提供方的异常比例当比例过高表明该接口会影响到其它服务应该拒绝调用该接口而是直接走降级逻辑。 2.2.Sentinel 2.2.1.介绍和安装 Sentinel是阿里巴巴开源的一款服务保护框架目前已经加入SpringCloudAlibaba中。官方网站 quick-start | Sentinel (sentinelguard.io)https://sentinelguard.io/zh-cn/docs/quick-start.html Sentinel 的使用可以分为两个部分: 核心库Jar包不依赖任何框架/库能够运行于 Java 8 及以上的版本的运行时环境同时对 Dubbo / Spring Cloud 等框架也有较好的支持。在项目中引入依赖即可实现服务限流、隔离、熔断等功能。 控制台DashboardDashboard 主要负责管理推送规则、监控、管理机器信息等。 为了方便监控微服务我们先把Sentinel的控制台搭建出来。 1下载jar包 下载地址Releases · alibaba/Sentinel (github.com) 2运行 将jar包放在任意非中文、不包含特殊字符的目录下重命名为sentinel-dashboard.jar 然后运行如下命令启动控制台 java -Dserver.port8090 -Dcsp.sentinel.dashboard.serverlocalhost:8090 -Dproject.namesentinel-dashboard -jar sentinel-dashboard.jar 3访问 访问http://localhost:8090页面就可以看到sentinel的控制台了 需要输入账号和密码默认都是sentinel 登录后即可看到控制台默认会监控sentinel-dashboard服务本身 2.2.2.微服务整合 在微服务模块中整合sentinel连接sentinel-dashboard控制台步骤如下 1引入sentinel依赖 !--sentinel-- dependencygroupIdcom.alibaba.cloud/groupId artifactIdspring-cloud-starter-alibaba-sentinel/artifactId /dependency 2配置控制台 修改application.yaml文件添加下面内容 spring:cloud: sentinel:transport:dashboard: localhost:8090 3访问cart-service的任意端点 重启cart-service然后访问查询购物车接口sentinel的客户端就会将服务访问的信息提交到sentinel-dashboard控制台。并展示出统计信息 点击簇点链路菜单会看到下面的页面 所谓簇点链路就是单机调用链路是一次请求进入服务后经过的每一个被Sentinel监控的资源。默认情况下Sentinel会监控SpringMVC的每一个Endpoint接口。 因此我们看到/carts这个接口路径就是其中一个簇点我们可以对其进行限流、熔断、隔离等保护措施。 默认情况下Sentinel会把路径作为簇点资源的名称无法区分路径相同但请求方式不同的接口查询、删除、修改等都被识别为一个簇点资源这显然是不合适的。 所以我们可以选择打开Sentinel的请求方式前缀把请求方式 请求路径作为簇点资源名 首先在cart-service的application.yml中添加下面的配置 spring:cloud:sentinel:transport:dashboard: localhost:8090http-method-specify: true # 开启请求方式前缀 然后重启服务通过页面访问购物车的相关接口可以看到sentinel控制台的簇点链路发生了变化
http://www.dnsts.com.cn/news/144054.html

相关文章:

  • 郑州专业做网站wordpress过滤用户输入数据
  • 织梦网如何把做网站的删掉网页版微信二维码几分钟失效
  • 自己的网站怎么编辑广州网站建设信息科技有限公司
  • 外贸网站faq南京移动网站建设报价
  • 营销型网站建设报价灌南县规划局网站理想家园规划建设
  • 购物网站开发设计思路什么是网站版面布局
  • 网站快捷导航ie怎么做自己做企业网站详细流程免费
  • 做网站用小公司还是大公司好怎么创建网页的快捷方式到桌面
  • 网帆-网站建设官方店适合个人开网店的平台
  • 国内做的比较好的旅游网站手机wap网站免费建站
  • seo网站排名厂商定制专业建设思路
  • 为什么网站突然打不开行业网站建设教程
  • 给朋友网站做宣传怎么写wordpress图片站优化
  • 信息手机网站模板做网站推广哪些
  • 网站开发背景知识微网站设计与开发是什么
  • 网站的功能规范厦门外贸网站建设
  • 检测网站是否被墙wordpress自定义页
  • 做响应网站的素材网站南昌百度推广公司
  • 国外有哪些做建筑材料的网站亚马逊外贸网站如何做
  • 文具网站建设策划书做财经类新闻的网站
  • 建基建设集团网站做门户网站难吗
  • 个人网站建设方案模板网络营销的策划方案
  • 网站建设公司优惠中男女做暧视频网站免费
  • 荷城网站制作公司最新黑帽seo培训
  • 免费php网站模板下载啥是网络推广
  • 微网站方案萧涵 wordpress
  • 东莞企业网站推广网站开发企业标准
  • 网站开发的职位要求新手学做网站 pdf 下载
  • 双语网站建设定制开发学历提升文案
  • 网站备案关闭嘉兴网站建设制作