基于 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,一经查实,立即删除!

相关文章

【雅礼集训2017】字符串【后缀自动机】【数据分治】

题意:给定一个字符串SSS和mmm个区间[li,ri][l_i,r_i][li​,ri​],qqq次询问,每次给定长度为kkk的字符串www和区间[a,b][a,b][a,b],求对于所有i∈[a,b]i\in[a,b]i∈[a,b],www在[li,ri][l_i,r_i][li​,ri​]内的子串在SSS中出现次数…

AtCoder Regular Contest 100 E - Or Plus Max Sos dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个长度为2n2^n2n的数组&#xff0c;让你对于所有的1≤k≤2n−11\le k\le 2^n-11≤k≤2n−1求最大的aiaj,0≤i<j≤2n−1,iorj≤ka_ia_j,0\le i<j\le2^n-1,i\ \ or \ \ j\le kai​aj​,0≤i<j≤…

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

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

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

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

【PKUWC2018】随机算法【状压dp】【组合计数】

题意&#xff1a;一张nnn个点mmm条边的无向无权图&#xff0c;求以下算法计算最大独立集的正确率&#xff1a;随机一个排列&#xff0c;依次考虑排列中每一个点&#xff0c;如果不与任何一个独立集中的点相邻则将其加入独立集。模998244353998244353998244353。 n≤20n\leq20n≤…

架构杂谈《一》

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

hdu 3308 LCIS 线段树 + 区间合并

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

【ARC103D】Distance Sums【树论】【构造】

题意&#xff1a;一棵nnn个点的无权树&#xff0c;给定每个点iii到其他所有点的距离之和did_idi​&#xff0c;保证did_idi​两两不同。构造或判断无法构造一棵满足条件的树。 n≤105n\leq 10^5n≤105 首先对于非根结点uuu&#xff0c;有 dudfau−sizu(n−sizu)d_ud_{fa_u}-si…

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

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

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的子集都…

【CF1349D】Slime and Biscuits【概率期望】【解方程】

题意&#xff1a;nnn个人共有mmm个饼干&#xff0c;每轮随机选一个饼干随机给一个另外的人&#xff0c;所有饼干都在一个人手里时游戏结束&#xff0c;求期望进行次数。模998244353998244353998244353。 n≤105,m≤3105n\leq10^5,m\leq3\times10^5n≤105,m≤3105 首先肯定是每…

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

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

Codeforces Round #225 (Div. 1) E. Vowels 容斥 + sosdp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你nnn个长度为333的串&#xff0c;串的每个字母都在a−za-za−z范围内&#xff0c;定义一个串合法当且仅当这个串中含有至少一个元音字母。现在他忘记了元音字母都有那几个&#xff0c;显然有2242^{24}224…

【CF1344D】Résumé Review【数学】【二分】

题意&#xff1a;给定长度为nnn的自然数序列aaa和整数kkk&#xff0c;要求构造长度为nnn的自然数序列bbb&#xff0c;使得0≤bi≤ai,∑bik0\leq b_i\leq a_i,\sum b_ik0≤bi​≤ai​,∑bi​k&#xff0c;且∑bi(ai−bi2)\sum b_i(a_i-b_i^2)∑bi​(ai​−bi2​)最大化。 n≤105…

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

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

2020牛客暑期多校训练营(第六场)H.Harmony Pairs 数位dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个nnn&#xff0c;问你有多少对0≤a≤b≤n0\le a\le b\le n0≤a≤b≤n满足S(a)>S(b)S(a)>S(b)S(a)>S(b)。其中S(a)S(a)S(a)表示aaa的十进制各位数之和。 思路&#xff1a; 显然的数位dpdpd…

【PKUWC2018】随机游走【Min-Max容斥】【树形dp】【FWT】

题意&#xff1a;给一棵nnn个点的无权树和xxx&#xff0c;qqq次询问&#xff0c;每次给定一个点集SSS,询问从xxx开始每次随机走一步&#xff0c;SSS中的每个点至少被经过一次的期望步数。 n≤18,q≤5000n\leq 18,q\leq 5000n≤18,q≤5000 题目求的相当于是SSS中的所有点 第一次…

LogoSharp:Logo语言的C#实现

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

hdu 6899 Xor 数位dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 问你有多少对x,yx,yx,y满足以下条件&#xff1a; (1)x∈[0,A],y∈[0,B](1)x \in [0,A],y\in [0,B](1)x∈[0,A],y∈[0,B] (2)∣x−y∣≤K(2)|x-y|\le K(2)∣x−y∣≤K (3)xxory≤W(3)x \ \ xor \ \ y\le W(3)…

【PKUWC2018】Minimax【线段树合并】

题意&#xff1a;给定一棵nnn个点的二叉树&#xff0c;叶子的权值输入给定且互不相同&#xff0c;非叶子结点iii的权值有pip_ipi​的概率为儿子结点权值最大值&#xff0c;1−pi1-p_i1−pi​的概率为最小值。求根结点取每种值的概率。模998244353998244353998244353。 n≤3105n…