前言

新项目采用的abp vnext的微服务模块化架构,所以把应用的服务拆成了很多独立模块

在初期,我们通过日志还能跟踪到问题,

后期服务越来越多(大约扩充到了十几个),随着调用链路越来越深

,问题也越来越能排查了.

往往入口报错之后,要跟好几个服务的日志 才能找到最终节点.

所以考虑引入Skywalking链路跟踪服务,来监听整个应用

什么是Skywalking

以下内容为照葫芦画瓢,觉得写的不错,所以就CV了~

Skywalking是一款分布式链路追踪组件

那么什么是链路追踪?

随着微服务架构的流行,服务按照不同的维度进行拆分,一次请求往往需要涉及到多个服务。互联网应用构建在不同的软件模块集上,这些软件模块,有可能是由不同的团队开发、可能使用不同的编程语言来实现、有可能布在了几千台服务器,横跨多个不同的数据中心。

所以微服务面临了这些问题:

     某个核心服务挂了,导致大量报错,如何快速确定哪里出了问题?

     用户请求响应延迟高,怎么确定是哪些服务导致的?

     应用程序有性能瓶颈,怎样确定瓶颈在哪里?

     如何准实时的了解应用部署环境(CPU、内存、进程、线程、网络、带宽)情况,以便快速扩容/缩容、流量控制、业务迁移

     如何统计各个调用的性能指标,比如:吞吐量(TPS)、响应时间及错误记录等

分布式链路跟踪系统就是为了解决这些问题应运而生。

Skywalking有哪些功能?

  1. 多种监控手段。可以通过语言探针和 service mesh 获得监控数据。

  2.多个语言自动探针。包括 Java,.NET Core 和 Node.JS。

  3.轻量高效。无需大数据平台,和大量的服务器资源。

  4.模块化。UI、存储、集群管理都有多种机制可选。

  5.支持告警。

  6.优秀的可视化解决方案。

Skywalking的整体架构图

部署搭建Skywalking

Skywalking是支持容器化部署的,所以这里我们只讲如何通过Docker进行部署

1.部署ES数据库

这里说明一下.Skywalking容器里本身是自带H2数据库的并支持持久化的,如果想简化部署,可以直接使用

这里ES推荐使用7.10版本,因为7.11以上的版本 授权协议变更了 可能有法律风险

docker run -d -p 9200:9200 -p 9300:9300 --name es -e "discovery.type=single-node" -e ES_JAVA_OPTS="-Xms128m -Xmx256m" -v /home/elasticsearch/data:/usr/share/elasticsearch/data elasticsearch:7.10.1

上面的命令是运行一个基础的ES数据库,并将数据持久化到宿主机 /home/elasticsearch/data,各位可以根据自己情况 自行更改

3.部署skywalking-oap服务

docker run --name skywalking-oap
--restart always
-p 11800:11800
-p 12800:12800
-d -e TZ=Asia/Shanghai
-e SW_ES_USER=
-e SW_ES_PASSWORD=
-e SW_STORAGE=elasticsearch
-e SW_STORAGE_ES_CLUSTER_NODES=ES数据库地址:9200
-v /etc/localtime:/etc/localtime:ro
apache/skywalking-oap-server:9.6.0

3.部署skywalking-ui服务

docker run -d
--name skywalking-ui
--restart always
-p 8080:8080
-e TZ=Asia/Shanghai
-e SW_OAP_ADDRESS=http://这里填写skywalking-oap的地址:12800
-v /etc/localtime:/etc/localtime:ro
apache/skywalking-ui:9.6.0

这样,我们就完成了基本的skywalking服务的搭建

ASP.NET Core如何集成Skywalking

在.NET中接入Skywalking,主要使用  SkyAPM.Agent.AspNetCore  这个开源代理

SkyAPM.Agent.AspNetCore采用了IHostingStartup接口通过探针的形式进行接入

所以对应用的入侵性很小,几乎为0.所以接入数据很简单

我们只需要三步即可

1.给服务的宿主层添加引用:

SkyAPM.Agent.AspNetCore

2.然后添加环境变量:

ASPNETCORE_HOSTINGSTARTUPASSEMBLIES=SkyAPM.Agent.AspNetCore (PS:如果有其他的拦截,这里的环境变量可以配置多个,通过逗号分隔)

3.添加Skywalking配置项,创建skyapm.json文件:

(PS:这里不一定要创建skyapm.json文件,也可以把配置写在appsettings.json里,研究过代理工具的源码,他也读取了appsettings的配置)

类似如下:

{
"SkyWalking": {
"ServiceName": "asp-net-core-backend", //服务名
"Namespace": "",
"HeaderVersions": [
"sw8"
],
"Sampling": {
"SamplePer3Secs": -1,
"Percentage": -1.0,
"LogSqlParameterValue": false
},
"Logging": {
"Level": "Information",
"FilePath": "logs/skyapm-{Date}.log"
},
"Transport": {
"Interval": 3000,
"ProtocolVersion": "v8",
"QueueSize": 30000,
"BatchSize": 3000,
"gRPC": {
"Servers": "localhost:11800", //指向SkywalkingOAP的地址
"Timeout": 100000,
"ConnectTimeout": 100000,
"ReportTimeout": 600000
}
}
}
}

由于可能线上的数据量很大,所以除了代理类自行监听的日志以外

我们还可以通过代码自行添加Tag和Log,方便跟踪查询

可以通过依赖注入的形式,拿到IEntrySegmentContextAccessor对象,进行标记和日志记录

代码如下:

private readonly IEntrySegmentContextAccessor _segContext;
public Test(IEntrySegmentContextAccessor segContext = null)
{
_segContext = segContext;
} public void Doing()
{
_segContext.Context.Span.AddLog(LogEvent.Message(""));//记录日志
_segContext.Context.Span.AddTag("lowsql", "lowsql");//记录标签
}

可以在此基础上自行扩展,比如加到ActionFilterAttribute拦截里面进行跟踪拦截

最后

最后,我们来看看效果:

链路情况:

这样,我们就能很方便的知道哪个服务调用了哪些服务,执行了哪些SQL操作了..

Skywalking APM监控系列(一丶.NET5.0+接入Skywalking监听)的更多相关文章

  1. OSGi 系列(七)之服务的监听、跟踪、声明等

    OSGi 系列(七)之服务的监听.跟踪.声明等 1. OSGi 服务的事件监听 和 bundle 的事件监听类似,服务的事件监听是在服务注册.注销,属性被修改的时候,OSGi 框架会发出各种不同的事件 ...

  2. OSGi 系列(三)之 bundle 事件监听

    OSGi 系列(三)之 bundle 事件监听 bundle 的事件监听是在 bundle 生命周期的不同状态相互转换时,OSGi 框架会发出各种不同的事件供事先注册好的事件监听器处理. 1. 事件监 ...

  3. C# Socket系列一 简单的创建socket的监听

    socket的应用场景,在快速,稳定,保持长连接的数据传输代码.Http也是socket封装出来的,基于一次请求一次回复,然后断开的socket连接封装. 比如我们常见的游戏服务器,目前的很火的物联网 ...

  4. 另辟思路解决 Android 4.0.4 不能监听Home键的问题

    问题描述: 自从Android 4.0以后,开发人员是不能监听和屏蔽Home键的,对于KEYCODE_HOME,官方给出的描述如下: Home key. This key is handled by ...

  5. Web重温系列(三):OracleDependency实现监听数据库变化

    有个小项目(后来由另一个小组以Java开发了),内容是监控一个Oracle数据库.如果其中一个表A有数据变动,则需要将相关内容重组后通过接口发送给B. 通常的解决办法是定时查询,时间间隔可以小一点,还 ...

  6. Swift3.0 键盘高度监听获取

    方法:通过通知监听键盘的动态 1.键盘的动态有四种: public static let UIKeyboardWillShow: NSNotification.Name public static l ...

  7. vue2.0使用watch监听对象属性

    二话不说直接代码,找了一个百度都没找到.... var head=new Vue({ data:{ checkBoxState:{//监听设置开关勾选状态 notice:true, sound:tru ...

  8. 前端监控系列1| 字节的前端监控SDK是怎样设计的

    作者:彭莉,火山引擎 APM 研发工程师,2020年加入字节,负责前端监控 SDK 的开发维护.平台数据消费的探索和落地. 摘要 字节内部应用环境多样( Web 应用.小程序.Electron 应用. ...

  9. .NetCore SkyWalking APM实现服务器监控环境安装及基础使用

    下载Java 8 SDK wget  --no-cookies --no-check-certificate --header "Cookie: gpw_e24=http%3A%2F%2Fw ...

  10. SkyWalking —— 分布式应用监控与链路追踪

    SkyWalking 是一个应用性能监控系统,特别为微服务.云原生和基于容器(Docker, Kubernetes, Mesos)体系结构而设计.除了应用指标监控以外,它还能对分布式调用链路进行追踪. ...

随机推荐

  1. Nmap使用教程(初级篇)

    基本扫描技术 扫描单个网络 nmap 192.168.1.1/www.baidu.com 扫描多个网络/目标 nmap 192.168.1.1 192.168.1.2 #将扫描同个网段内不同的ip地址 ...

  2. synchronized中wait、notify的原理与源码

    synchronized中wait.notify的原理与源码 1.wait和notify的流程图 2.JVM源码 java层面wait的方法 public final native void wait ...

  3. PostgreSQL 12 文档: 部分 I. 教程

    部分 I. 教程 欢迎来到PostgreSQL教程.下面的几章将为那些新接触PostgreSQL.关系数据库概念和 SQL 语言的读者给出一个简单介绍.我们只假定读者拥有关于如何使用计算机的一般知识. ...

  4. 怎样优雅地增删查改(一):从0开始搭建Volo.Abp项目

    @ 目录 项目介绍 模块化 由框架实现的 需要实现的 创建项目 创建业务模块 配置引用和依赖 配置DbContext 创建实体和Dto 配置AutoMapper 软件系统中数据库或者持久层的基本操作功 ...

  5. VSCode隐藏一些非必要的文件

    VSCode自动编译生成 .exe文件 很烦 所以要隐藏掉 文件,首选项,搜索 files.exclude 在后面添加 **/*.exe 即可

  6. 记一次 .NET 某游戏服务后端 内存暴涨分析

    一:背景 1. 讲故事 前几天有位朋友找到我,说他们公司的后端服务内存暴涨,而且CPU的一个核也被打满,让我帮忙看下怎么回事,一般来说内存暴涨的问题都比较好解决,就让朋友抓一个 dump 丢过来,接下 ...

  7. 进程相关API

    ID与句柄 如果我们成功创建一个进程,CreateProcess函数会给我们返回一个结构体,包括四个数 据:进程编号(ID).进程句柄.线程编号(ID).线程句柄. 进程ID其实我们早见过了,通常我们 ...

  8. DevOps实战:使用GitLab+Jenkins+Kubernetes(k8s)建立CI/CD解决方案

    目录 一.系统环境 二.前言 三.DevOps简介 四.CI/CD简介 五.安装并配置docker参数 六.使用registry搭建镜像仓库 七.安装部署gitlab代码仓库 7.1 创建gitlab ...

  9. KVM (Centos7)使用macvtap网卡的后续 -- 宿主机创建macvtap网卡,并配置ip

    因为使用虚拟机上的 macvtap 网卡与宿主机器上的网卡无法直接通信,所以需要在宿主机上也创建 macvtap 网卡,将 ip 迁移过去. 因为未能找到配置文件的设置方法,所以使用脚本来配置,并将脚 ...

  10. DDD项目落地之充血模型实践

    背景: 充血模型是DDD分层架构中实体设计的一种方案,可以使关注点聚焦于业务实现,可有效提升开发效率.提升可维护性: 1.DDD项目落地整体调用关系 调用关系图中的Entity为实体,从进入领域服务( ...