Docker 部署 SkyWalking 的指南

Docker 部署 SkyWalking 的指南

SkyWalking 是一款开源的应用性能监控工具,特别适用于分布式系统。通过 Docker 部署 SkyWalking,可以简化安装和配置过程。本文将详细介绍如何使用 Docker 部署 SkyWalking。

环境准备

在开始之前,请确保你的系统已经安装了 Docker。如果还没有安装,可以参考 Docker 官方文档 进行安装。为了保证部署的顺利进行,还需确认 Docker 和 Docker Compose 的版本符合要求。建议 Docker 版本在 19.03 及以上,Docker Compose 版本在 1.27 及以上。

1. 拉取 SkyWalking 镜像

首先,我们需要从 Docker Hub 拉取 SkyWalking 的镜像。SkyWalking 包含两个主要组件:OAP(后端分析处理)和 UI(前端展示)。

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

2. 运行 OAP 容器

接下来,运行 OAP 容器。OAP 负责接收和处理来自各个服务的监控数据。

bash 复制代码
docker run -d --name skywalking-oap \
  -e TZ=Asia/Shanghai \
  -p 12800:12800 \
  -p 11800:11800 \
  --restart always \
  apache/skywalking-oap-server:latest

在这一步,我们启动了 OAP 容器,并将它的 12800 和 11800 端口分别映射到宿主机的同名端口。这些端口分别用于接收监控数据和与 UI 组件通信。

3. 运行 UI 容器

然后,运行 UI 容器。UI 提供了一个可视化界面,方便我们查看和分析监控数据。

bash 复制代码
docker run -d --name skywalking-ui \
  -e TZ=Asia/Shanghai \
  -p 8080:8080 \
  --link skywalking-oap:oap \
  -e SW_OAP_ADDRESS=oap:12800 \
  --restart always \
  apache/skywalking-ui:latest

UI 容器通过 --link 参数连接到 OAP 容器,并通过环境变量 SW_OAP_ADDRESS 指定 OAP 服务的地址。

4. 配置 SkyWalking Agent

为了让你的应用程序能够将监控数据发送到 SkyWalking,需要配置 SkyWalking Agent。以下是一个 Java 应用程序的示例配置:

bash 复制代码
-javaagent:/path/to/skywalking-agent.jar \
-Dskywalking.agent.service_name=your-service-name \
-Dskywalking.collector.backend_service=oap:11800

将上述参数添加到你的应用程序启动命令中即可。-javaagent 参数指定了 SkyWalking Agent 的路径,-Dskywalking.agent.service_name 参数指定了服务名称,-Dskywalking.collector.backend_service 参数指定了 OAP 服务的地址。

5. 访问 SkyWalking UI

完成上述步骤后,你可以通过浏览器访问 SkyWalking UI,查看监控数据。默认情况下,UI 运行在 http://localhost:8080

进阶配置

如果你需要更高级的配置,例如持久化存储、集群部署等,可以参考 SkyWalking 的官方文档。以下是一些常见的进阶配置示例。

1. 配置持久化存储

SkyWalking 支持多种存储后端,如 ElasticSearch、MySQL 等。你可以通过修改 OAP 容器的环境变量来配置存储后端。例如,配置 ElasticSearch 作为存储后端:

bash 复制代码
docker run -d --name skywalking-oap \
  -e TZ=Asia/Shanghai \
  -e SW_STORAGE=elasticsearch \
  -e SW_STORAGE_ES_CLUSTER_NODES=es-host:9200 \
  -p 12800:12800 \
  -p 11800:11800 \
  --restart always \
  apache/skywalking-oap-server:latest

2. 集群部署

对于大规模分布式系统,可以部署多个 OAP 实例,并通过负载均衡器分发请求。使用 Docker Compose 可以简化集群部署的配置。

以下是一个简单的 Docker Compose 配置示例:

yaml 复制代码
version: '3.7'
services:
  oap:
    image: apache/skywalking-oap-server:latest
    ports:
      - "12800:12800"
      - "11800:11800"
    environment:
      TZ: Asia/Shanghai
    deploy:
      replicas: 2
      update_config:
        parallelism: 2
        delay: 10s

  ui:
    image: apache/skywalking-ui:latest
    ports:
      - "8080:8080"
    environment:
      TZ: Asia/Shanghai
      SW_OAP_ADDRESS: oap:12800
    depends_on:
      - oap

使用该配置文件,你可以通过以下命令启动 SkyWalking 集群:

bash 复制代码
docker-compose up -d

网络拉取问题排查,请看 Docker 网络代理配置及防火墙设置指南

总结

通过 Docker 部署 SkyWalking,可以大大简化安装和配置过程。只需几个简单的命令,就可以快速搭建一个强大的应用性能监控系统。对于更复杂的需求,可以根据官方文档进行相应的配置和调整。

进一步阅读:Apache SkyWalking 官方文档

相关推荐
Linux运维老纪4 小时前
DNS缓存详解(DNS Cache Detailed Explanation)
计算机网络·缓存·云原生·容器·kubernetes·云计算·运维开发
杨浦老苏6 小时前
开源音乐管理软件Melody
docker·群晖·多媒体
杨浦老苏8 小时前
面向npm的实时仪表板Dashly
网络·docker·群晖·导航
JunLan~9 小时前
Docker 部署 GLPI(IT 资产管理软件系统)
运维·docker·容器
青草地溪水旁10 小时前
c++ list的front和pop_front的概念和使用案例
c++·容器·list
特立独行的猫a11 小时前
使用 Docker(Podman) 部署 MongoDB 数据库及使用详解
数据库·docker·podman
LUCIAZZZ13 小时前
基于Docker以KRaft模式快速部署Kafka
java·运维·spring·docker·容器·kafka
特立独行的猫a16 小时前
Golang 应用的 Docker 部署方式介绍及使用详解
开发语言·docker·golang
IT艺术家-rookie17 小时前
k8s--部署k8s集群--控制平面节点
容器·kubernetes
康世行17 小时前
Windows环境下MaxKB大模型 Docker部署图文指南
windows·docker·容器