docker部署skywalking

skywalking版本下载

1:拉取skywalking的oap镜像(可以选择自己的版本,最好与ui,agent版本一致)

bash 复制代码
docker pull apache/skywalking-oap-server:9.5.0

2:启动oap

bash 复制代码
docker run -d -p 11800:11800 -p 12800:12800 --name sw_oap apache/skywalking-oap-server:9.5.0

11800 :SkyWalking OAP 服务器默认使用这个端口来接收来自 Agent 的数据上报
12800:SkyWalking OAP 服务器的 web 管理界面默认运行在这个端口上,通过这个端口可以访问到 SkyWalking 的 UI 界面

3:拉取skywalking的ui镜像

bash 复制代码
docker pull apache/skywalking-ui:9.5.0

4:启动ui

bash 复制代码
docker run -d -p 8080:8080 -e SW_OAP_ADDRESS=http://192.168.16.35:12800 apache/skywalking-ui:9.5.0

5:在浏览器输入127.0.0.1:8080可登入ui界面

6:下载Agent,官网下载

7-1:idea配置某个项目,添加探针参数

7-2:应用demo.jar包直接启动的方式,添加探针参数

bash 复制代码
java -jar -javaagent:/home/app/skywalking/skywalking-agent/agent/skywalking-agent.jar -Dskywalking.agent.service_name=demo-server -Dskywalking.collector.backend_service=127.0.0.1:11800 demo.jar

-javaagent: 项目中 skywalking-agent.jar 的绝对路径,修改为自己的地址
-Dskywalking.agent.service_name:服务名称
-Dskywalking.collector.backend_service:Skywalking 服务地址

配置完成后,重启你的微服务,在日志的一开始会打印如下内容,意思是加载了Skywalking的Agent

8:使用Skywalking的日志采集

xml 复制代码
<!-- Sky walking 日志收集, 版本号要和当前使用的Skywalking保持一直 -->
<dependency>
  <groupId>org.apache.skywalking</groupId>
  <artifactId>apm-toolkit-logback-1.x</artifactId>
  <version>8.7.0</version>
</dependency>

9:在logback-spring.xml中增加配置

xml 复制代码
   <appender name="SKY_WALKING_LOG" class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.log.GRPCLogClientAppender">
        <!-- 日志输出编码,own-pattern 为自己定义的日志打印格式  -->
        <encoder>
            <pattern>%p%d%msg%M%F{32}%L</pattern>
        </encoder>
    </appender>

	<!-- 日志输出级别 -->
	<root level="INFO">
		<appender-ref ref="STDOUT" />
		<appender-ref ref="FILE" />
		<appender-ref ref="HTML" />
		<appender-ref ref="FILE_HTML" />
		<appender-ref ref="SKY_WALKING_LOG" />
	</root>

10:再进行重启项目后,访问接口,即可在Skywalking的日志中看到访问的日志了(重启服务,日志就会刷新,之前的日志就会不存在了)

11:docker-compose.yml配置

yml 复制代码
version: '3'

services:
  skywalking-server-service:
    image: apache/skywalking-oap-server:9.5.0
    container_name: skywalking-server
    restart: always
    ports:
      - 11800:11800
      - 12800:12800
    env_file:
      - /opt/skywalking/skywalking.env


  skywalking-ui-service:
    image: apache/skywalking-ui:9.5.0
    container_name: skywalking-ui
    restart: always
    ports:
      - 8080:8080
    depends_on:
      - skywalking-server-service
    environment:
      SW_OAP_ADDRESS: http://skywalking-server-service:12800   #这里必须添加 http://

注意如果报:Exception in thread "main" java.lang.NullPointerException: authority:因为 SW_OAP_ADDRESS 配置需要添加 http://

12:微服务Gateway集成Skywalking链路追踪

其他服务已经完成链路追踪功能,只有gateway服务需要特殊配置一下,问题:Spring Cloud Gateway是基于WebFlux实现的,Skywalking默认不支持,在链路上是不展示gateway组件的

解决方案如下,查看项目gateway版本

复制agent/optional-plugins下面的与gateway对应的两个插件


两个插件,复制到plugins中

然后重启gateway服务


相关推荐
容器魔方21 小时前
Bloomberg 正式加入 Karmada 用户组!
云原生·容器·云计算
muyun28001 天前
Docker 下部署 Elasticsearch 8 并集成 Kibana 和 IK 分词器
elasticsearch·docker·容器
Nazi61 天前
k8s的dashboard
云原生·容器·kubernetes
傻傻虎虎1 天前
【Docker】常用帮忙、镜像、容器、其他命令合集(2)
运维·docker·容器
是小崔啊1 天前
叩丁狼K8s - 概念篇
云原生·容器·kubernetes
2401_897930062 天前
使用Docker轻松部署Neo4j图数据库
数据库·docker·neo4j
LeeZhao@2 天前
【AI推理部署】Docker篇04—Docker自动构建镜像
人工智能·docker·容器
程思扬2 天前
利用JSONCrack与cpolar提升数据可视化及跨团队协作效率
网络·人工智能·经验分享·docker·信息可视化·容器·架构
落日漫游2 天前
dockercompose和k8s区别
docker·kubernetes
lllsure2 天前
【Docker】存储卷
运维·docker·容器