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

建网站要钱吗 优帮云程序员最低学历要求

建网站要钱吗 优帮云,程序员最低学历要求,青海网站制作多少钱,做公司网站哪家好目录 前言 一、问题的出现#xff1f; 二、一体化架构中的慢请求排查如何做 三、分布式 Trace原理 四、如何来做分布式 Trace 前言 在分布式服务架构下#xff0c;一个 Web 请求从网关流入#xff0c;有可能会调用多个服务对请求进行处理#xff0c;拿到最终结果。这个…目录 前言 一、问题的出现 二、一体化架构中的慢请求排查如何做 三、分布式 Trace原理 四、如何来做分布式 Trace 前言 在分布式服务架构下一个 Web 请求从网关流入有可能会调用多个服务对请求进行处理拿到最终结果。这个过程中每个服务之间的通信又是单独的网络请求无论请求经过的哪个服务出了故障或者处理过慢都会对前端造成影响。 处理一个Web请求要调用的多个服务为了能更方便的查询哪个环节的服务出现了问题现在常用的解决方案是为整个系统引入分布式链路跟踪。 一、问题的出现 通过监控发现系统的核心下单接口在晚高峰的时候会有少量的慢请求用户也投诉在 APP 上下单时等待的时间比较长。而下单的过程可能会调用多个RPC 服务或者使用多个资源一时之间你很难快速判断究竟是哪个服务或者资源出了问题从而导致整体流程变慢于是你和你的团队开始想办法如何排查这个问题。 二、一体化架构中的慢请求排查如何做 因为在分布式环境下请求要在多个服务之间调用所以对于慢请求问题的排查会更困难我们不妨从简单的入手先看看在一体化架构中是如何排查这个慢请求的问题的。 最简单的思路是打印下单操作的每一个步骤的耗时情况然后通过比较这些耗时的数据找到延迟最高的一步然后再来看看这个步骤要如何的优化。如果有必要的话你还需要针对步骤中的子步骤再增加日志来继续排查简单的代码就像下面这样 long start System.currentTimeMillis(); processA(); Logs.info(process A cost (System.currentTimeMillis() - start));// 打印 A 步 start System.currentTimeMillis(); processB(); Logs.info(process B cost (System.currentTimeMillis() - start));// 打印 B 步 start System.currentTimeMillis(); processC(); Logs.info(process C cost (System.currentTimeMillis() - start));// 打印 C 步 这是最简单的实现方式打印出日志后我们可以登录到机器上搜索关键词来查看每个步骤的耗时情况。 虽然这个方式比较简单但你可能很快就会遇到问题由于同时会有多个下单请求并行处理所以这些下单请求的每个步骤的耗时日志是相互穿插打印的。你无法知道这些日志哪些是来自于同一个请求也就不能很直观地看到某一次请求耗时最多的步骤是哪一步了。那么你要如何把单次请求每个步骤的耗时情况串起来呢 一个简单的思路是给同一个请求的每一行日志增加一个相同的标记。这样只要拿到这个标记就可以查询到这个请求链路上所有步骤的耗时了我们把这个标记叫做requestId我们可以在程序的入口处生成一个 requestId然后把它放在线程的上下文中这样就可以在需要时随时从线程上下文中获取到 requestId 了。简单的代码实现就像下面这样 String requestId UUID.randomUUID().toString(); //requestId 存储在线程上下文中 ThreadLocalString tl new ThreadLocalString() { Override protected String initialValue() { return requestId; } }; long start System.currentTimeMillis(); processA(); Logs.info(rid : tl.get() , process A cost (System.currentTimeMillis() - start));start System.currentTimeMillis(); processB(); Logs.info(rid : tl.get() , process B cost (System.currentTimeMillis() - start));start System.currentTimeMillis(); processC(); Logs.info(rid : tl.get() , process C cost (System.currentTimeMillis() - start)); 有了 requestId你就可以清晰地了解一个调用链路上的耗时分布情况了。于是你给你的代码增加了大量的日志来排查下单操作缓慢的问题。很快 你发现是某一个数据库查询慢了才导致了下单缓慢然后你优化了数据库索引问题最终得到了解决。 正当你要松一口气的时候问题接踵而至又有用户反馈某些商品业务打开缓慢商城首页打开缓慢。你开始焦头烂额地给代码中增加耗时日志而这时你意识到每次排查一个接口就需要增加日志、重启服务这并不是一个好的办法于是你开始思考解决的方案。 其实从我的经验出发来说一个接口响应时间慢一般是出在跨网络的调用上比如说请求数据库、缓存或者依赖的第三方服务。所以我们只需要针对这些调用的客户端类做切面编程通过插入一些代码打印它们的耗时就好了。 一次请求可能要打印十几条日志如果你的电商系统的 QPS 是 10000 的话就是每秒钟会产生十几万条日志对于磁盘 I/O 的负载是巨大的那么这时你就要考虑如何减少日志的数量。 你可以考虑对请求做采样采样的方式也简单比如你想采样 10% 的日志那么你可以只打印“requestId%100”的请求。 有了这些日志之后当给你一个 requestId 的时候你发现自己并不能确定这个请求到了哪一台服务器上所以你不得不登陆所有的服务器去搜索这个 requestId 才能定位请求。这样无疑会增加问题排查的时间。 你可以考虑的解决思路是把日志不打印到本地文件中而是发送到消息队列里再由消息处理程序写入到集中存储中比如 Elasticsearch。这样你在排查问题的时候只需要拿着 requestId 到 Elasticsearch 中查找相关的记录就好了。在加入消息队列和Elasticsearch 之后我们这个排查程序的架构图也会有所改变 三、分布式 Trace原理 在分布式链路跟踪中有两个重要的概念跟踪trace和 跨度 span。trace 是请求在分布式系统中的整个链路视图span 则代表整个链路中不同服务内部的视图span 组合在一起就是整个 trace 的视图。 在整个请求的调用链中请求会一直携带 traceid 往下游服务传递每个服务内部也会生成自己的 spanid 用于生成自己的内部调用视图并和traceid一起传递给下游服务。 traceid 在请求的整个调用链中始终保持不变所以在日志中可以通过 traceid 查询到整个请求期间系统记录下来的所有日志。请求到达每个服务后服务都会为请求生成spanid而随请求一起从上游传过来的上游服务的 spanid 会被记录成parent-spanid或者叫 pspanid。当前服务生成的 spanid 随着请求一起再传到下游服务时这个spanid 又会被下游服务当做 pspanid 记录。 通过在访问日志和业务日志里记录的traceid、spanid 和 pspanid 能完整的还原出整个请求的调用链路视图对错误排查能起到很大的帮助。 上面就是分布式链路跟踪的原理我们可以自己实现也可以依赖 opentracing 这种开源的解决方案。一般是在请求到达网关的开始生成本次请求的traceid 和 在网关服务内的spanid 将他们放在HTTP 请求头或者RPC调用的元数据里在调用下游服务时继续向下传递。下游的RESTful API服务的全局路由中间件和RPC服务的拦截器里会接收请求携带的traceid 和生成当次请求在服务内部的spanid从上游接收到的 spanid 在这里会被转换成 pspanid。除此之外我们甚至可以把 traceid 和 spanid 注入到一些数据库连接池应用里让记录的慢SQL日志里同样能打上 traceid 和 spanid 信息为请求的响应过慢提供有效的分析数据。 四、如何来做分布式 Trace 你可能会问题目既然是“分布式 Trace横跨几十个分布式组件的慢请求要如何排查”那么我为什么要花费大量的篇幅来说明在一体化架构中如何排查问题呢这是因为在分布式环境下你基本上也是依据上面我提到的这几点来构建分布式追踪的中间件的。 在一体化架构中单次请求的所有的耗时日志都被记录在一台服务器上而在微服务的场景下单次请求可能跨越多个 RPC 服务这就造成了单次的请求的日志会分布在多个服务器上。 当然你也可以通过 requestId 将多个服务器上的日志串起来但是仅仅依靠 requestId很难表达清楚服务之间的调用关系所以从日志中就无法了解服务之间是谁在调用谁。因此我们采用 traceId spanId 这两个数据维度来记录服务之间的调用关系这里traceId 就是 requestId也就是使用 traceId 串起单次请求用 spanId 记录每一次RPC 调用。说起来可能比较抽象我给你举一个具体的例子。 比如你的请求从用户端过来先到达 A 服务A 服务会分别调用 B 和 C 服务B 服务又会调用 D 和 E 服务。 我来给你讲讲图中的内容 用户到 A 服务之后会初始化一个 traceId 为 100spanId 为 1A 服务调用 B 服务时traceId 不变而 spanId 用 1.1 标识代表上一级的 spanId 是1这一级的调用次序是 1A 调用 C 服务时traceId 依然不变spanId 则变为了 1.2代表上一级的 spanId 还是 1而调用次序则变成了 2以此类推。 通过这种方式我们可以在日志中清晰地看出服务的调用关系是如何的方便在后续计算中调整日志顺序打印出完整的调用链路。那么 spanId 是何时生成的又是如何传递的呢 首先A 服务在发起 RPC 请求服务 B 前先从线程上下文中获取当前的 traceId 和spanId然后依据上面的逻辑生成本次 RPC 调用的 spanId再将 spanId 和 traceId 序列化后装配到请求体中发送给服务方 B。 服务方 B 获取请求后从请求体中反序列化出 spanId 和 traceId同时设置到线程上下文中以便给下次 RPC 调用使用。在服务 B 调用完成返回响应前计算出服务 B 的执行时间发送给消息队列。 当然在服务 B 中你依然可以使用切面编程的方式得到所有调用的数据库、缓存、HTTP 服务的响应时间只是在发送给消息队列的时候要加上当前线程上下文中的spanId 和 traceId。 这样无论是数据库等资源的响应时间还是 RPC 服务的响应时间就都汇总到了消息队列中在经过一些处理之后最终被写入到 Elasticsearch 中以便给开发和运维同学查询使用。 而在这里你大概率会遇到的问题还是性能的问题也就是因为引入了分布式追踪中间件导致对于磁盘 I/O 和网络 I/O 的影响而我给你的“避坑”指南就是如果你是自研的分布式 trace 中间件那么一定要提供一个开关方便在线上随时将日志打印关闭如果使用开源的组件可以开始设置一个较低的日志采样率观察系统性能情况再调整到一个合适的数值。
http://www.zqtcl.cn/news/440496/

相关文章:

  • 1688网站怎么做分销高质量的网站内容建设
  • 网站建设公司济宁网站转跳怎么做
  • 镇江网站设计多少钱企业网络部署方案
  • 建网站的公司浩森宇特wordpress登录缓存
  • 便宜建站空间战队头像在线制作免费
  • 做招聘网站赚钱吗厦门网站建设哪里好
  • 新乡网站建设哪家公司好阿里巴巴做国际网站多少钱
  • 怎么在悉尼做网站dede做手机网站
  • 企业网站模板免费下载品牌建设专家库推荐表
  • 辽宁智能网站建设推荐网络营销推广方案创意
  • 安阳做一个网站多少钱东营做网站公司
  • 深圳市罗湖网站建设百度自助建站官网
  • 网站开发安装环境网站建设销售话术
  • 网站权重网站栏目划分的原则
  • 国际网站建设的目的我的百度账号登录
  • 温州网站设计定制博客和网站的区别
  • 益阳建设网站wordpress加载图片慢
  • 网站官网阜新网站开发公司
  • 适合做网站的图片印刷公司网站模板
  • 南昌哪家网站建设最好网站建设的方法有
  • 东莞做网站 动点官网百度开户流程
  • 中力建设网站怎么做自己的门户网站
  • 做的网站必须放做音乐网站的目地
  • 网站备案下来以后怎么做网页万网创始人张向东
  • 怎么做网站官方电话品牌营销策划十大要点
  • 上海自适应网站深圳网络推广外包
  • 网站的建设模式是指什么时候开始外网视频网站做泥声控
  • 免费在线观看电影电视剧网站网站建设公司哪家好 在线磐石网络
  • 域名是建网站之前申请吗怎么查看网站开发语言
  • 网站建设业务的延伸性查企业信息查询平台官网免费