基于 Docker Compose 实践 .NET Core 的现代化架构 2:在容器中集成 Skywalking APM

本章节代码已经上传至 https://github.com/siegrainwong/.NET-Core-with-Docker/tree/master/Part2

系列大纲

还是先介绍一下目录,这次我们讲第二篇:

  1. 用 docker-compose 启动 WebApi 和 SQL Server

  2. 在容器中集成 Skywalking APM

  3. 通过 nginx-proxy 对 ES、Skywalking、WebApi 实现自动反向代理和 HTTPS

  4. 通过 Azure DevOps 进行 CI/CD 和蓝绿发布

按照惯例,故障排除在最后一个章节~

Skywalking 介绍

Skywalking是一个分布式链路追踪系统,在部署分布式系统时能以非常清晰和全面的方式为你展示各种各样的监控数据,且本身接入对代码毫无侵入性,加上docker的部署优势能让你分分钟将这个强大的 APM 集成并启动起来。

配置监控代理

监控代理负责运行在你WebApi容器中并向收集器(Skywalking-OAP)定时发送监控数据。

本节中的F:\path\to\your\project的路径字符串都用来指代你的项目根目录,注意替换

打开程序包管理控制台,安装SkyAPM

Install-Package SkyAPM.Agent.AspNetCore -Version 0.9.0

安装SkyAPM.DotNet.CLI

dotnet tool install -g SkyAPM.DotNet.CLI

添加配置文件

cd F:\path\to\your\project\Core.APIdotnet skyapm config coreapi sw-oap:11800

添加后是这样的,并且记得设置其为始终复制

640?wx_fmt=jpeg

配置docker-compose

修改你的docker-compose.yml文件成这样:

version: "3.3"services:  #coreapi:  #  container_name: coreapi  #  image: siegrainwong/coreapi:latest  #  ports:  #    - 5000:5000  #  depends_on:  #    - sqlserver  #  links:  #    - sqlserver  #  volumes:  #    - ./Core.API/appsettings.docker.json:/app/appsettings.json:ro  #  environment:  #    ASPNETCORE_HOSTINGSTARTUPASSEMBLIES: SkyAPM.Agent.AspNetCore  #    SKYWALKING__SERVICENAME: coreapi  #  restart: always  sqlserver:    image: mcr.microsoft.com/mssql/server:2017-latest    container_name: sqlserver    restart: always    environment:      ACCEPT_EULA: Y      MSSQL_PID: Developer      SA_PASSWORD: "NetCore123!@#"    volumes:      - coredata:/var/opt/mssql    ports:      - 1433  elasticsearch:    image: docker.elastic.co/elasticsearch/elasticsearch:6.4.3    container_name: elasticsearch    restart: always    ports:      - 9200:9200      - 9300:9300    environment:      discovery.type: single-node    ulimits:      memlock:        soft: -1        hard: -1  sw-oap:    image: apache/skywalking-oap-server:6.1.0    container_name: sw-oap    depends_on:      - elasticsearch    links:      - elasticsearch    restart: always    ports:      - 11800:11800      - 12800:12800    environment:      SW_STORAGE: elasticsearch      SW_STORAGE_ES_CLUSTER_NODES: elasticsearch:9200  sw-ui:    image: apache/skywalking-ui:6.1.0    container_name: sw-ui    depends_on:      - sw-oap    links:      - sw-oap    restart: always    ports:      - 8080:8080    environment:      SW_OAP_ADDRESS: sw-oap:12800volumes: coredata:

是的,我们先把这里的coreapi注释掉,方便本地调试

在根目录添加一个名为launch.ps1的脚本:

docker-compose up -ddocker run --rm -it `	-v F:\path\to\your\project:/app/ `	-v F:\path\to\your\project\Core.API\appsettings.docker.json:/app/Core.API/appsettings.Development.json:ro `	-p 5000:5000 `	--link sw-oap `	--link sqlserver `	--name coreapi_dev `	--network part2_default `	--env ASPNETCORE_HOSTINGSTARTUPASSEMBLIES=SkyAPM.Agent.AspNetCore `	--env SKYWALKING__SERVICENAME=coreapi ` 	-w /app/Core.API mcr.microsoft.com/dotnet/core/sdk:2.2-stretch dotnet watch run

docker run这条命令的意思是以交互模式将当前目录挂载到docker中执行dotnet watch run,并在执行完成后(或按 Ctrl+C 退出时)移除该容器,一般我们开发中就都是通过这种命令将应用程序快速运行在容器中。

还需要注意的是,这里手动指定了容器的网络(--network),只有运行在同一网络内的容器才能利用容器名在容器内网互相通信,你可以用docker network ls看看有哪些容器网络,之前我们用docker-compose创建起来的所有容器都在一个网络中,这个网络的名称一般是当前你的项目根目录名_default,所以我的就叫part2_default,你需要将其改为你的网络名称。

想验证容器之间的网络是否通畅,比如想测试从 coreapi 到 sqlserver 的连接,只需要docker exec coreapi_dev curl sqlserver:1433即可。

其他命令的意思你应该很轻松就能猜到的,如果不明白可以对照一下上一章中文注释过的docker-compose.yml文件,就不多解释了。

我们执行这个脚本后,访问localhost:8080,不出意外将出现Skywalking的登录界面: 640?wx_fmt=jpeg

输入 admin/admin 登录: 640?wx_fmt=jpeg

然后就能看到这个酷炫的页面了,不过此时你很有可能看不见数据,别急,我们先去http://localhost:5000/api/values页面刷两下,回来再将右下角的 UTC+8 改为 UTC+0,因为 ES 跟 OAP 的默认时区都是 UTC+0,这个我们后面再解决,现在刷新看是不是有数据了。

里面具体有什么就自己探索吧,这里主要讲部署方法,具体使用方法也有很多其他博主写过了,就不多讲了。

纠正时区为 UTC+8

纠正时区的原理非常简单,就是靠命令修改容器虚拟机的时区。这需要我们在 oap 跟 es 的 Dockerfile 中执行这两条命令:

ln -sf /usr/share/zoneinfo/Asia/Shanghai  /etc/localtimeecho Asia/Shanghai > /etc/timezone

好消息是其实这些活儿也是有人做好了的,直接拿来用就是了。

修改 ES 的容器镜像为:

elasticsearch:  image: wutang/elasticsearch-shanghai-zone:6.3.2

修改 OAP 的容器镜像为:

sw-oap:  image: siegrainwong/skywalking-oap:6.1.0

再去划拉两下,是不是时间就正确了? 640?wx_fmt=jpeg

具体的修改方式可以参考这个commit以及这个repo,其实在有官方的容器化之前一直是这位大佬在维护的,大家要感谢他,本来当时我也是跟着这个 Repo 学习的,文章也写到一半了,结果发现官方容器化后又重新走了一遍 23333。

故障排除

  1. 通过查看Core.API\logs\skyapm-xxx.log排错,一般都是代理连不上 oap 等类似错误,重新修改下你的gRPC/Servers直到连通为止(不过这里好像有点 bug,有时候莫名其妙日志就不生成了~),如果有这样的日志,就说明代理连上 oap 了

org.apache.skywalking.oap.server.receiver.register.provider.handler.v5.grpc.InstanceDiscoveryServiceHandler -13182375 [grpc-default-executor-43] INFO [] - register service instance id=16 [UUID:23e8d5461f0049cfa708d5ec782a6a8b]
  1. 通过docker logs命令查看sw-oap或者sw-ui的日志,看看是不是有什么错误,一般也还是连不通的错误,oap 连不上 es 呀,ui 连不上 oap 啊,等等

  2. 参考 skywalking-docker 官方repo

  3. 参考 SkyAPM 官方repo

  4. 如果你的 skywalking 没有 CLR 信息,可能是你混用的 5.x 版本的监控代理,那个程序集叫 Skywalking.xxxxx,接入时还需要修改 Startup.cs 文件,发生这种情况用最新的 Agent 即可 

原文地址:https://siegrain.wang/article/2019/07/08/deploy-skywalking-in-docker-with-netcore


.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com 

640?wx_fmt=jpeg

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315015.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用Minikube部署本地Kubernetes集群(二十九)

前言 使用Minikube部署本地k8s集群相对比较简单,非常推荐将其用于本地k8s开发环境,唯一麻烦点的仅仅是网络问题。在本篇教程中,我们使用了国内的镜像来完成本地k8s集群的搭建。如果搭建过程中出现错误,建议使用mini…

Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2) F. Bits And Pieces sosdp预处理超集

传送门 文章目录题意:思路:题意: n≤1e6,ai≤2e6n\le1e6,a_i\le2e6n≤1e6,ai​≤2e6 思路: 由于(aj&ak)(a_j \And a_k)(aj​&ak​)打的括号,所以应该放在一起考虑,现在我们可以枚举aia_iai​&…

架构杂谈《一》

架构杂谈《一》从传统单体架构到服务化架构的发展历程典型的单体架构分为三个层级,Web层、业务逻辑层和数据存储层,每个层的指责分别如下:Web 层:负责与用户交互或者对外提供接口业务逻辑层:为了实现业务逻辑而设计的流…

hdu 3308 LCIS 线段树 + 区间合并

传送门 文章目录题意:思路:题意: 思路: 日常水一篇题解。 带修改的求区间连续的递增序列,我们考虑用线段树维护。 直接维护mlenmlenmlen是区间最长的递增序列,lslsls是从左端点开始的最长递增序列&#xf…

从零开始实现ASP.NET Core MVC的插件式开发(二) - 如何创建项目模板

标题:从零开始实现ASP.NET Core MVC的插件式开发(二) - 如何创建项目模板作者:Lamond Lu地址:https://www.cnblogs.com/lwqlun/p/11155666.html源代码:https://github.com/lamondlu/DynamicPlugins在上一篇中,我们介绍…

Codeforces Round #112 (Div. 2) E. Compatible Numbers sosdp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 以下假设all1<<22all1<<22all1<<22。 转化问题&#xff0c;对于每个aia_iai​我们都计算xaixorallxa_i\ \ xor \ \ allxai​ xor all&#xff0c;对于所有xxx的子集都…

多租户通用权限设计(基于 casbin)

所谓权限控制, 概念并不复杂, 就是确认某个操作是否能做, 本质上仅仅就是个bool判断.权限几乎是每个系统必不可少的功能, 和具体业务结合之后, 在系统中往往表现的非常复杂和难于控制, 很大部分原因是把权限和具体业务结合的太过紧密, 把业务的复杂度也加入到权限控制中来了.一…

容器化单页面应用中RESTful API的访问

最近在工作中&#xff0c;需要让运行在容器中的单页面应用程序能够访问外部的RESTful API。这个需求看起来并不困难&#xff0c;不过实现起来还是有些曲折的。在此&#xff0c;我就将这部分内容总结一下。在入正题之前&#xff0c;有个一问题&#xff0c;就是为什么要将单页面应…

LogoSharp:Logo语言的C#实现

上周在朋友中问了一圈&#xff0c;发现没有几个人知道Logo语言的&#xff0c;或许&#xff0c;这门古老的语言现在用的人已经非常少了&#xff0c;除了国外有少量的用户将Logo语言用于教育外&#xff0c;估计国内不会有人使用这门语言。其实&#xff0c;Logo语言本来也就是以编…

Hello Kubernetes快速交互实验手册

“ K8S在线实验室提供了一个交互实验环境&#xff0c;现将这部分文章精简并翻译为中文&#xff0c;希望对那些不了解K8S的童鞋有帮助&#xff0c;能够快速玩起来有个感性认识...”原文&#xff1a;https://kubernetes.io/docs/tutorials翻译&#xff1a;Edison ZhouHello Kuber…

2020 ICPC 上海 Sum of Log 数位dp + 状态剪枝

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 观察可以发现&#xff0c;由于i&j0i \And j0i&j0&#xff0c;所以log2(ij)log_2(ij)log2​(ij)表示的应该是ijijij的111的最高位。 一个显然的dpdpdp状态就出来了f[pos][flag1][fl…

从MVP到微软产品经理的几点心得

昨天&#xff0c;我应邀在微软2019年暑期实习生的入职培训活动上做了一个简短的分享 —— 以我自身的职业发展过程为例&#xff0c;给大家讲了一讲我是怎样从一个技术爱好者&#xff0c;到获得第一个MVP&#xff08;微软最有价值专家&#xff09;的荣誉奖项&#xff0c;以及后来…

小白开学Asp.Net Core 《六》 —— 探究.Net Core 跨平台的奥秘

1、写这篇文章的初衷有好多朋友反馈看不懂我写的开源的一个练手项目&#xff08;GitHub&#xff1a;https://github.com/AjuPrince/Aju.Carefree&#xff09;也有好多人都希望我能写一些简单的入门的文章&#xff0c;记得前几天在群里有人问为什么 .Net Core 能跨平台&#xff…

Codeforces Round #636 (Div. 3) D. Constant Palindrome Sum 思维 + 差分

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 首先有一个显然的性质就是每组操作最多不会超过两次。 很容易想到一个很暴力的思路&#xff0c;就是枚举x∈[1,2∗k]x \in [1,2*k]x∈[1,2∗k]&#xff0c;让后判断一下每组需要操作几次取…

C#8.0: 在 LINQ 中支持异步的 IAsyncEnumerableT接口

C# 8.0中&#xff0c;提供了一种新的IAsyncEnumerable<T>接口&#xff0c;在对集合进行迭代时&#xff0c;支持异步操作。比如在读取文本中的多行字符串时&#xff0c;如果读取每行字符串的时候使用同步方法&#xff0c;那么会导致线程堵塞。IAsyncEnumerable<T>可…

Codeforces Round #636 (Div. 3) E. Weights Distributing 思维 + bfs

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; n≤2e5,m≤2e5n\le2e5,m\le2e5n≤2e5,m≤2e5 思路&#xff1a; 怎么感觉每场div3div3div3都有一个巧妙的图论题。 首先如果只有两个点的话&#xff0c;肯定是一次bfsbfsbfs之后取前disdisdis小的www作为边权…

解读 Microsoft.NET.Sdk 的源码,你能定制各种奇怪而富有创意的编译过程

在 csproj 中&#xff0c;Project 中的 Sdk 属性是 MSBuild 15.0 开始支持的&#xff0c;也就是 Visual Studio 2017 开始支持。有了 Sdk 属性的存在&#xff0c;MSBuild 编译过程能够扩展得非常强大&#xff0c;而不止是过去 Import 的一个 props 和 targets 文件。本文将介绍…

《ASP.NET Core 微服务实战》译者序

最近&#xff0c;我将《ASP.NET Core 微服务实战》一书由英文翻译为中文。这本书是由清华大学出版社引进的&#xff0c;目前还处于最后的排版校对过程中&#xff0c;现将该书的译者序发表于此。以下为译者译全文&#xff1a;“微服务”的概念在 2014 年正式提出之后&#xff0c…

.NET 云原生技术使用调查

.NET Core 3.0 即将发布RC&#xff0c;.NET Core 3.0默认更好的支持Docker资源限制&#xff0c;官方团队也在努力让.NET Core成为真正的容器运行时&#xff0c;使其在低内存环境中具有容器感知功能并高效运行。GC堆限制.NET Core减少了CoreCLR默认使用的内存&#xff0c;如G0代…

FZU - 2042 The Mad Mathematician 数位dp + 算贡献

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 求sumsumsum。 a,b,c,d,e≤1e18a,b,c,d,e\le1e18a,b,c,d,e≤1e18 思路&#xff1a; 这是一篇无从考究的题解&#xff0c;因为fzu现在进不去。 看到这种题直接考虑数位dpdpdp&#xff0c;对于[A,B],[C,D][…