当前位置: 首页 > news >正文

docker配置skywalking 监控springcloud应用

在使用 Docker 配置 SkyWalking 监控 Spring Cloud 应用时,主要分为以下几个步骤:


1. 准备工作

  • 确保你的开发环境已经安装了 Docker 和 Docker Compose。
  • 准备好 Spring Cloud 应用代码,并确保它支持 SkyWalking 的探针(Agent)。

2. 拉取 SkyWalking OAP Server 和 UI 镜像

SkyWalking 提供了官方的 Docker 镜像,可以通过以下命令拉取:

docker pull apache/skywalking-oap-server
docker pull apache/skywalking-ui
docker pull docker.elastic.co/elasticsearch/elasticsearch:7.17.0

3. 创建 docker-compose.yml 文件

为了简化部署,可以使用 Docker Compose 来启动 SkyWalking 的 OAP Server 和 UI。

创建一个 docker-compose.yml 文件,内容如下:

version: '3.7'services:oap:image: apache/skywalking-oap-servercontainer_name: skywalking-oapports:- "11800:11800" # gRPC port- "12800:12800" # REST portenvironment:SW_STORAGE: elasticsearchSW_STORAGE_ES_CLUSTER_NODES: elasticsearch:9200networks:- skywalking-netui:image: apache/skywalking-uicontainer_name: skywalking-uiports:- "8080:8080"environment:SW_OAP_ADDRESS: http://oap:12800depends_on:- oapnetworks:- skywalking-netelasticsearch:image: docker.elastic.co/elasticsearch/elasticsearch:7.17.0container_name: elasticsearchenvironment:discovery.type: single-nodeports:- "9200:9200"networks:- skywalking-netnetworks:skywalking-net:driver: bridge

4. 启动 SkyWalking 服务

运行以下命令启动 SkyWalking 的 OAP Server、UI 和 Elasticsearch:

docker compose up -d

这将启动以下服务:

  • OAP Server:负责收集和处理监控数据。
  • UI:提供可视化界面,默认访问地址为 http://localhost:8080
  • Elasticsearch:存储监控数据。

5. 配置 Spring Cloud 应用

为了让 Spring Cloud 应用与 SkyWalking 集成,需要在应用中引入 SkyWalking 的 Java Agent。

5.1 下载 SkyWalking Agent

从 Apache SkyWalking 官方网站 下载对应版本的 SkyWalking Agent。

解压后,你会得到一个文件夹,例如 apache-skywalking-java-agent-8.9.0

5.2 修改 Spring Cloud 应用的启动命令

在 Spring Cloud 应用的启动命令中添加 -javaagent 参数。例如:

java -javaagent:/path/to/apache-skywalking-java-agent-8.9.0/skywalking-agent.jar \-Dskywalking.agent.service_name=your-service-name \-Dskywalking.collector.backend_service=oap:11800 \-jar your-spring-cloud-app.jar
5.3 关键参数说明
  • -javaagent:指定 SkyWalking Agent 的路径。
  • skywalking.agent.service_name:设置你的服务名称,用于区分不同的服务。
  • skywalking.collector.backend_service:指定 SkyWalking OAP Server 的地址(默认为 oap:11800)。

6. 使用 Docker 启动 Spring Cloud 应用

如果你使用 Docker 来运行 Spring Cloud 应用,可以在 Dockerfile 或 docker-compose.yml 中添加 -javaagent 参数。

例如,在 docker-compose.yml 中添加:

app:image: your-spring-cloud-imagecontainer_name: spring-cloud-appenvironment:- JAVA_OPTS=-javaagent:/skywalking-agent/skywalking-agent.jar -Dskywalking.agent.service_name=your-service-name -Dskywalking.collector.backend_service=oap:11800volumes:- ./apache-skywalking-java-agent-8.9.0:/skywalking-agentdepends_on:- oapnetworks:- skywalking-net

7. 验证监控

  1. 访问 SkyWalking UI:http://localhost:8080
  2. 在页面上查看服务拓扑图、性能指标等信息。
  3. 如果一切正常,你应该能看到你的 Spring Cloud 应用的监控数据。

8. 注意事项

  • 确保 Spring Cloud 应用和 SkyWalking OAP Server 在同一个网络中(例如通过 Docker Compose 创建的 skywalking-net 网络)。
  • 如果使用的是自定义的 Elasticsearch 地址或端口,请修改 SW_STORAGE_ES_CLUSTER_NODES 环境变量。
  • 根据实际需求调整 SkyWalking Agent 的配置文件(agent/config/agent.config)。

通过以上步骤,你可以成功使用 Docker 配置 SkyWalking 来监控 Spring Cloud 应用!

http://www.xdnf.cn/news/44695.html

相关文章:

  • 缓存 --- Redis性能瓶颈和大Key问题
  • 数据通信学习笔记之OSPF其他内容3
  • 学习设计模式《四》——单例模式
  • sizeof和strlen区分,(好多例子)
  • gbase8s之线程状态详解(超值)
  • deep-share开源浏览器扩展,用于分享 DeepSeek 对话,使用户能够将对话内容保存为图片或文本以便轻松分享
  • Linux 进程间通信之消息队列:原理 + API 与实战 (System-V IPC)
  • 人工智能-机器学习其他技术(决策树,异常检测,主成分分析)
  • 论文笔记(七十八)Do generative video models understand physical principles?
  • vscode使用技巧
  • SpringBoot 3 与 SpringDoc 打造完美接口文档
  • 面试常用基础算法
  • JSON-RPC远程控制
  • Linux中的信号量
  • 健身房管理系统设计与实现(springboot+ssm+vue+mysql)含万字详细文档
  • 01.04、回文排序
  • AI日报 - 2025年04月21日
  • 高效获取淘宝实时商品数据:API 接口开发与数据采集实战指南
  • Vue3核心源码解析
  • nvm管理node版本 与 nvm常用指令的使用
  • SpringBoot3集成ES8.15实现余额监控
  • Docker镜像仓库
  • 深拷贝和浅拷贝的区别
  • React Router V7使用详解
  • LeetCode[232]用栈实现队列
  • PySide6 GUI 学习笔记——常用类及控件使用方法(常用类矩阵QRect)
  • Hello, Dirty page
  • 【Flutter】使用LiveKit和Flutter构建实时视频聊天应用
  • Linux操作系统--进程的创建和终止
  • java面试篇(常见的集合底层原理)