docker 安装 skywalking

===================
docker下搭建SkyWalking
https://www.cnblogs.com/xiao987334176/p/13530575.html
下载image
docker pull elasticsearch:7.5.1
docker pull apache/skywalking-oap-server:6.6.0-es7
docker pull apache/skywalking-ui:6.6.0
===================
一些docker run命令的含义
--restart always: Docker重启时让容器能自动启动
--link:方便链接到其他容器, 设置别名; 
格式 --link <name or id>:<alias>
===================
安装+启动es:
docker run -d --name=es7 -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node"  -e “ES_JAVA_OPTS=-Xms512m -Xmx512m” elasticsearch:7.5.1

===================
安装+启动oap:
docker run -d --name oap --restart=always -e TZ=Asia/Shanghai -p 12800:12800 -p 11800:11800 --link es7:es7 -e SW_STORAGE=elasticsearch -e SW_STORAGE_ES_CLUSTER_NODES=es7:9200  -e “ES_JAVA_OPTS=-Xms512m -Xmx512m”  apache/skywalking-oap-server:6.6.0-es7

===================
安装+启动skywalking-ui:
docker run -d --name skywalking-ui --restart=always -e TZ=Asia/Shanghai -p 8088:8080 --link oap:oap -e SW_OAP_ADDRESS=oap:12800  -e “ES_JAVA_OPTS=-Xms512m -Xmx512m” apache/skywalking-ui:6.6.0

===================
启动参数格式
java -javaagent:<skywalking-agent.jar的本地路径> -Dskywalking.agent.service_name=<项目名称> -Dskywalking.collector.backend_service=<oap的ip和端口> -jar <项目jar包路径>

举例:
java -javaagent:d:/apache-skywalking-apm-bin/agent/skywalking-agent.jar -Dskywalking.agent.service_name=simple-test -Dskywalking.collector.backend_service=127.0.0.1:11800 -jar C:/git/simple-mybatis/simple-mybatis-service/target/simple-mybatis-service-1.0-SNAPSHOT.jar

====================
容器退出, 错误代码137 是内存不够, 检查.vslconfig文件; 或者使用 docker stats命令查看

====================
skywalking自定义traceid?  修改traceid?  怎么生成?
https://segmentfault.com/a/1190000022061988
由skywalking-agent.jar实现
org.apache.skywalking.apm.agent.core.context.ids.GlobalIdGenerator#generate方法生成Global(Distributed) Trace Id
traceId生成方式暂不支持自定义

芋道源码分析skywalking
https://www.iocoder.cn/categories/SkyWalking/
直接查看内容js:
javascript:$("#locker").remove();var total_height = 0;$(".article-content").children().each(function(){
total_height += $(this).outerHeight(true);});$(".article-content").css("height", total_height);

====================
日志中如何打印/获取trace id
https://www.cnblogs.com/hellxz/p/logback_skywalking_trace_id.html
方案一: 
<dependency>
    <groupId>org.apache.skywalking</groupId>
    <artifactId>apm-toolkit-trace</artifactId>
    <version>6.6.0</version>
</dependency>

使用代码 TraceContext.traceId();

方案二: 
使用skywalking的适配器, 设置日志格式
使用%tid 来占trace-id的位置,默认TID:N/A
<dependency>
    <groupId>org.apache.skywalking</groupId>
    <artifactId>apm-toolkit-logback-1.x</artifactId>
    <version>6.6.0</version>
</dependency>
==============
忽略某些url不被追踪
https://blog.csdn.net/fu_huo_1993/article/details/107188840
==============
https://www.cnblogs.com/caoweixiong/p/14486450.html
带ui使用图的教程
==============
如何打印url层面的入参和返回值
https://www.jianshu.com/p/1c843983d34c
基于拦截器+自定义跨度标记实现
ActiveSpan.tag("input", sb.toString());
==============
打印某一个方法的入参和返回值
https://segmentfault.com/a/1190000023121812
或者基于8.0的 @Tags注解实现某一层方法的单独调用
@Trace(operationName = "添加自定义的方法")
@Tags({
        @Tag(key = "从方法参数中获取值", value = "arg[0]"),
        @Tag(key = "从返回值中获取值", value = "returnedObj.name")
})
====================
@TraceCrossThread实现线程池的trace
lambda表达式的线程池场景, 自定义插件实现trace
https://www.freesion.com/article/3858712765/
====================
多个agent的场景
java -javaagent:agentA.jar -javaagent:agentB.jar 再跟项目jar
===============
APM(Application Performance Management )系统构建
https://skywalking-handbook.netlify.app/installation/container_way/
====================
官方文档
https://skyapm.github.io/document-cn-translation-of-skywalking/zh/8.0.0/


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值