当我们用很多服务时,各个服务间的调用关系是怎么样的?各个服务单调用的顺序\时间性能怎么样?服务出错了,到底是哪个服务引起的?这些问题我们用什么方案解决呢,以前的方式是各个系统自己单独做日志,出了问题从暴出问题的服务开始一个一个服务的排查,耗时耗力,有些日志不全的,还不一定查得出来。好在现在有Skywalking链路追踪系统,可以不用写任何代码,就追踪到各个服务间的调用关系和性能状态等。

本文将从0开始搭建两个webapi项目,使用Skywalking来追踪他们之间的调用关系及响应时间。开发环境为VisualStudio2019

1:安装Skywalking,可参考:https://www.cnblogs.com/sunyuliang/p/11422576.html,本列中搭建好后的Skywalking服务器地址为:192.168.150.134

2:打开VS创建一个demo1的webapi项目。

2.1:为项目添加NuGet程序包SkyAPM.Agent.AspNetCore的引用

  2.2,在项目根目录添加skyapm.json文件,并添加下以内容,其中的Servers结点的IP地址根据实际情况换成自己的服务器IP

{  "SkyWalking": {    "ServiceName": "Demo01",    "Namespace": "",    "HeaderVersions": [      "sw6"    ],    "Sampling": {      "SamplePer3Secs": -1,      "Percentage": -1.0    },    "Logging": {      "Level": "Debug",      "FilePath": "logs/skyapm-{Date}.log"    },    "Transport": {      "Interval": 3000,      "ProtocolVersion": "v6",      "QueueSize": 30000,      "BatchSize": 3000,      "gRPC": {        "Servers": "192.168.150.134:11800",        "Timeout": 10000,        "ConnectTimeout": 10000,        "ReportTimeout": 600000      }    }  }}

  2.3: 将skyapm.json文件的属性”复制到输出目录“ 修改为 ”如果较新则复制”

2.4:展开项目的Properties,打开launchSettings.json文件,在其中的环境变量中加入 "SKYWALKING__SERVICENAME": "asp-net-core-frontend"

  2.5:到目前skywalking就已经成功引入到系统中了。接下来我们来验证一下是否正常,直接Ctrl+F5启动项目,访问https://localhost:44313/api/values

         

  2.6:访问Skywalking管理后台(记得替换一下IP)http://192.168.150.134:8080/trace 。手动选一下时间范围,结束时间选明天(选当时时间会搜索不到数据,不知道是时区还是skywalking的bug),点击搜索。可以看到本次访问的追踪信息已经同步到了Skywalking中。

               

 以上单个系统的追踪就完成了,接下来我们再创建一个项目,步骤和第2步基本一样,看看多系统的追踪,这个才是Skywalking的价值所在。

3:另外再打开一个VS创建一个demo02的webapi项目。

3.1:为项目添加NuGet程序包SkyAPM.Agent.AspNetCore的引用

  3.2,在项目根目录添加skyapm.json文件,并添加下以内容,其中的Servers结点的IP地址根据实际情况换成自己的服务器IP。其中ServiceName结点设置为:Demo02

{  "SkyWalking": {    "ServiceName": "Demo02",    "Namespace": "",    "HeaderVersions": [      "sw6"    ],    "Sampling": {      "SamplePer3Secs": -1,      "Percentage": -1.0    },    "Logging": {      "Level": "Debug",      "FilePath": "logs/skyapm-{Date}.log"    },    "Transport": {      "Interval": 3000,      "ProtocolVersion": "v6",      "QueueSize": 30000,      "BatchSize": 3000,      "gRPC": {        "Servers": "192.168.150.134:11800",        "Timeout": 10000,        "ConnectTimeout": 10000,        "ReportTimeout": 600000      }    }  }}

  3.3: 将skyapm.json文件的属性”复制到输出目录“ 修改为 ”如果较新则复制”

3.4:展开项目的Properties,打开launchSettings.json文件,在其中的环境变量中加入 "ASPNETCORE_HOSTINGSTARTUPASSEMBLIES": "SkyAPM.Agent.AspNetCore"

  3.5:在ValuesController.cs中添加引用: System.Net.Http ,通过HttpClient依次调用Demo01的两个方法,里面的https://localhost:44313对应为我们的Demo01项目。具体Get方法代码如下:

        // GET api/values        [HttpGet]public async Task<string> Get()        {var client = new HttpClient();await client.GetStringAsync("https://localhost:44313/api/values/1");return  await client.GetStringAsync("https://localhost:44313/api/values");        }

3.6:Ctrl+F5启动项目,访问http://localhost:21143/api/values

  3.7:访问Skywalking管理后台(记得替换一下IP)http://192.168.150.134:8080/trace 。手动选一下时间范围,结束时间选明天(选当时时间会搜索不到数据,不知道是时区还是skywalking的bug),点击搜索。可以看到本次访问两系统单的调用关系图已经同步到了Skywalking中

 以上多个系统间的追踪也就都完成了,完全不用写代码,配置一下就好了。

从零开始使用Skywalking分布式链路追踪系统相关推荐

  1. NET Core微服务之路:SkyWalking+SkyApm-dotnet分布式链路追踪系统的分享

    对于普通系统或者服务来说,一般通过打日志来进行埋点,然后再通过elk或splunk进行定位及分析问题,更有甚者直接远程服务器,直接操作查看日志,那么,随着业务越来越复杂,企业应用也进入了分布式服务化的 ...

  2. 原来10张图就可以搞懂分布式链路追踪系统原理

    分布式系统为什么需要链路追踪? 随着互联网业务快速扩展,软件架构也日益变得复杂,为了适应海量用户高并发请求,系统中越来越多的组件开始走向分布式化,如单体架构拆分为微服务.服务内缓存变为分布式缓存.服务 ...

  3. 微服务链路追踪_.NET Core微服务:分布式链路追踪系统分享

    (给DotNet加星标,提升.Net技能) 转自:另一个老李 cnblogs.com/SteveLee/p/10463200.html 对于普通系统或者服务来说,一般通过打日志来进行埋点,然后再通过e ...

  4. 分布式链路追踪系统深入理解

    背景 对于普通系统或者服务来说,一般通过打日志来进行埋点,然后再通过elk进行定位及分析问题,更有甚者直接远程服务器,使用各种linux命令单手操作查看日志,说到这,我也没摆脱这种困境.那么随着业务越 ...

  5. 在spring boot中三分钟上手apache顶级分布式链路追踪系统skywalking

    skywalking在apache里全票通过成为了apache顶级链路追踪系统 项目地址:github.com/apache/skyw- 官方文档:github.com/apache/skyw- 虽然 ...

  6. skywalking分布式链路追踪

    下载地址​​​​​​​Downloads | Apache SkyWalking SkyWalking APM 9.2.0 Java Agent 8.12.0 linux搭建skywalking 0. ...

  7. [资源分享] 【Springboot】实例讲解Springboot整合OpenTracing分布式链路追踪系统(Jaeger和Zipkin)

    1 分布式追踪系统 随着大量公司把单体应用重构为微服务,对于运维人员的责任就更加重大了.架构更复杂.应用更多,要从中快速诊断出问题.找到性能瓶颈,并不是一件容易的事.因此,也随着诞生了一系列面向Dev ...

  8. 在微服务框架Demo.MicroServer中添加SkyWalking+SkyApm-dotnet分布式链路追踪系统

    1.APM工具的选取 Apm监测工具很多,这里选用网上比较火的一款Skywalking. Skywalking是一个应用性能监控(APM)系统,Skywalking分为服务端Oap.管理界面UI.以及 ...

  9. asp 采集系统_在微服务框架中添加SkyWalking+SkyApm-dotnet分布式链路追踪系统

    1.APM工具的选取 Apm监控工具很多,这里选用网上比较火的一款Skywalking. Skywalking是一个应用性能监控(APM)系统,Skywalking分为服务端Oap.管理界面UI.以及 ...

最新文章

  1. java 参数传递_java中方法的参数传递机制
  2. 不同映射方式下cache的失效率_详解发动机在不同工况下的喷油量控制方式
  3. Taro+react开发(12)--注意引入user
  4. CodeForces 771C Bear and Tree Jumps 树形DP
  5. 【MySQL】MySQL 8 IDEA连接本地MySQL报错 Host DESKTOP-MISSMJIJ is not allowed to connect to this serv
  6. DevOps 和敏捷开发的区别是什么?
  7. mysql-定时调用存储过程
  8. Stm32f10x 新建工程详解
  9. ConcurrentHashMap1.7到1.8变化
  10. iPhone6(IOS12.5.5)越狱记录
  11. 家中买的计算机配置,配置,教您买电脑主要看哪些配置
  12. [conda报错 已解决]An unexpected error has occurred. Conda has prepared the above report.
  13. 机器人 李永禄_第八届中国青少年机器人竞赛名单
  14. TCR历史论文多久能发表?
  15. Python分析《武林外传》
  16. Spring boot 更改启动LOGO,佛祖保佑,永无BUG或神兽保佑
  17. 创意小发明:使用51系列单片机的DIY点焊机控制项目(程序+原理图)
  18. nginx + ftp搭建文件服务器
  19. ab 发送post请求 测试API性能
  20. STL库:vector

热门文章

  1. html模板 循环里if,django模板里循环变量table里想要两个一行如何控制
  2. 延时消息_Handler的消息延时是怎么实现的
  3. 形容计算机老师风采的句子,关于老师的句子
  4. eclipse各种配置
  5. 全选按钮的使用。winfrom程序中,对全选按钮的理解,欢迎拍砖!
  6. 忽略NVRAM的config,修改cisco密码
  7. 基于ASP.NET Core SignalR的流式传输
  8. winform进度条实现
  9. 别等了,全面「远程办公」凉了
  10. 成长 | 《大厂晋升指南》学习总结(中)