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

skyWalking搭建(一)


title: “SkyWalking搭建(一)”
createTime: 2021-07-27T14:34:21+08:00
updateTime: 2021-07-27T14:34:21+08:00
draft: false
author: “name”
tags: [“skywalking”]
categories: [“java”]
description: “测试的”

基于 docker 部署 skywalking 并实现 SpringBoot 全链路监控

文章目录

    • title: "SkyWalking搭建(一)" createTime: 2021-07-27T14:34:21+08:00 updateTime: 2021-07-27T14:34:21+08:00 draft: false author: "name" tags: ["skywalking"] categories: ["java"] description: "测试的"
  • 基于 docker 部署 skywalking 并实现 SpringBoot 全链路监控
  • 一、安装环境部署
    • 1.1 Docker 中安装 Elasticsearch7.6.2(方式一)
    • 1.2 安装部署 elasticsearch:7.10.1(方式二)
      • 修改配置文件
      • 启动 elasticsearch
    • 1.3 安装 oap
    • 1.4 安装 ui
    • 1.5 下载源码包,会用到其中的 agent
  • 二、SpringBoot 集成 Skywalking
    • 2.1 配置
      • 文件准备
      • 使用方式
      • 详细配置
  • 三、使用systemctl
  • SkyWalking 文档中文版(社区提供)

一、安装环境部署

下载镜像:

$ docker pull docker pull elasticsearch:7.10.1
$ docker pull apache/skywalking-oap-server:8.3.0-es7
$ docker pull apache/skywalking-ui:8.3.0

1.1 Docker 中安装 Elasticsearch7.6.2(方式一)

安装 Elasticsearch

注意:使用版本为 7.6.2,你可以选择其他版本
拉取镜像

docker pull elasticsearch:7.6.2

启动容器

docker run --restart=always -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" \
-e ES_JAVA_OPTS="-Xms512m -Xmx512m" \
--name='elasticsearch' --cpuset-cpus="1" -m 2G -d elasticsearch:7.6.2xxxxxxxxxx docker run --restart=always -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" \-e ES_JAVA_OPTS="-Xms512m -Xmx512m" \--name='elasticsearch' --cpuset-cpus="1" -m 2G -d elasticsearch:7.6.2123

说明:

  • -v /opt/hanlp:/opt/hanlp 如果使用了 hanlp 的分词,所以需要挂载词库
  • ES_JAVA_OPTS 可以设置参数
  • 单节点启动

访问地址:http://172.18.63.211:9200

1.2 安装部署 elasticsearch:7.10.1(方式二)

修改配置文件

(可选)修改主机配置参数:

$ vi /etc/sysctl.conf
vm.max_map_count=262144
$ sysctl -p$ vi/etc/systemd/system.conf
DefaultLimitNOFILE=65536
DefaultLimitNPROC=32000
DefaultLimitMEMLOCK=infinity
$ systemctl daemon-reload$ vi /etc/security/limits.conf
* soft nofile 65536
* hard nofile 65536
* soft nproc 4096
* hard nproc 4096
* hard memlock unlimited
* soft memlock unlimited

启动 elasticsearch

创建持久化目录,并启动 elasticsearch

$ mkdir -p /data/elasticsearch/data
$ mkdir -p /data/elasticsearch/logs
$ chmod -R 777 /data/elasticsearch/data
$ chmod -R 777 /data/elasticsearch/logs
$ docker run -d --name=es7 \--restart=always \-p 9200:9200 -p 9300:9300 \-e "discovery.type=single-node" \-v /data/elasticsearch/data:/usr/share/elasticsearch/data \-v /data/elasticsearch/logs:/usr/share/elasticsearch/logs \
elasticsearch:7.10.1

1.3 安装 oap

注意:等待 elasticsearch 完全启动之后,再启动 oap

$ docker run --name oap --restart always -d \
--restart=always \
-e TZ=Asia/Shanghai \
-p 12800:12800 \
-p 11800:11800 \
--link es7:es7 \
-e SW_STORAGE=elasticsearch7 \
-e SW_STORAGE_ES_CLUSTER_NODES=es7:9200 \
apache/skywalking-oap-server:8.3.0-es7

说明:这里指定 elasticsearch 来存储数据

  • –link: es7 和你启动的 es 容器的 name 保持一致
  • -e SW_STORAGE_ES_CLUSTER_NODES:es7 也可改为你 es 服务器部署的 Ip 地址,即 ip:9200

如果有如下报错:

[Entrypoint] Apache SkyWalking Docker Image
Current image doesn't Elasticsearch 6

把 SW_STORAGE 改成 elasticsearch7 即可

1.4 安装 ui

$ docker run -d --name skywalking-ui \
--restart=always \
-e TZ=Asia/Shanghai \
-p 8080:8080 \
--link oap:oap \
-e SW_OAP_ADDRESS=oap:12800 \
apache/skywalking-ui:8.3.0

说明:

  • – link:注意容器的名称
  • -e SW_OAP_ADDRESS:oap 容器名称,也可改为 ip:12800,即其他服务的 IP 和端口

1.5 下载源码包,会用到其中的 agent

http://skywalking.apache.org/downloads/

[外链图片转存失败, 源站可能有防盗链机制, 建议将图片保存下来直接上传 (img-K4yXkgBY-1615948939842)(https://lovebetterworld.com/skywalking.png)]

二、SpringBoot 集成 Skywalking

2.1 配置

文件准备

将 apache-skywalking-apm-bin-es7/agent 文件夹拷贝到发布容器中,位置可以根据情况调整。

cp -r ./agent/*  /opt/skywalkingAgent

文件说明

  • config/agent.config:为客户端代理配置文件,可以根据系统情况进行响应调整,这里就不详细说明。
  • logs:SW agent 相关运行情况日志。
  • skywalking-agent.jar:agent 代理 jar 包。

使用方式

优先级:探针 > JVM 配置 > 系统环境变量 > agent.config

一般都使用探针方式,其他方式就不介绍了,配置方式如下:s

  • 格式 1(推荐):-javaagent:/path/to/skywalking-agent.jar={config1}={value1},{config2}={value2}
-javaagent:../skywalking-agent.jar=agent.service_name=fw-gateway,collector.backend_service=127.0.0.1:11800
  • 格式 2:-Dskywalking.[option1]=[value2]
-javaagent:../skywalking-agent.jar -Dskywalking.agent.service_name=fw-gateway -Dskywalking.collector.backend_service=127.0.0.1:11800

一般配置下面两项即可:

agent.service_name:客户端服务名,在apm系统中显示的服务名称。
collector.backend_service:SW上传的服务地址。

访问相关服务地址后可以在 SW 控制台中查看相关信息

详细配置

# 探针代理命名空间,跨进场传输时的header标记
# agent.namespace=${SW_AGENT_NAMESPACE:default-namespace}# 代理服务名称,在ui显示的的服务名称
agent.service_name=${SW_AGENT_NAME:Your_ApplicationName}# 采样率,每3秒trace几条
# 小于等于0使用默认值,每条都采样
# agent.sample_n_per_3_secs=${SW_AGENT_SAMPLE:-1}# server端的认证配置
# agent.authentication = ${SW_AGENT_AUTHENTICATION:xxxx}# 单个trace的span跨度,会有内存开销
# agent.span_limit_per_segment=${SW_AGENT_SPAN_LIMIT:150}# 忽略span,多个逗号分隔
# agent.ignore_suffix=${SW_AGENT_IGNORE_SUFFIX:.jpg,.jpeg,.js,.css,.png,.bmp,.gif,.ico,.mp3,.mp4,.html,.svg}# 开启debug模式,用于发现sw的bug
# agent.is_open_debugging_class = ${SW_AGENT_OPEN_DEBUG:true}# 是否缓存sw的增强包
# agent.is_cache_enhanced_class = ${SW_AGENT_CACHE_CLASS:false}# sw指令类的缓存模式: MEMORY or FILE
# MEMORY: 缓存在内存中,占用内容
# FILE: 缓存到/class-cache目录下, 退出自动删除
# agent.class_cache_mode = ${SW_AGENT_CLASS_CACHE_MODE:MEMORY}# 操作名称的最大长度,最大不要超过190
# agent.operation_name_threshold=${SW_AGENT_OPERATION_NAME_THRESHOLD:150}# 代理默认使用gRPC纯文本。
# 如果为true,则即使未检测到CA文件,SkyWalking代理也会使用TLS。
# agent.force_tls=${SW_AGENT_FORCE_TLS:false}# 是否使用新的配置文件
# profile.active=${SW_AGENT_PROFILE_ACTIVE:true}# 并行监听的分段数量
# profile.max_parallel=${SW_AGENT_PROFILE_MAX_PARALLEL:5}# 监听分段的最大时间,超出则停止
# profile.duration=${SW_AGENT_PROFILE_DURATION:10}# 线程最大跨线程数
# profile.dump_max_stack_depth=${SW_AGENT_PROFILE_DUMP_MAX_STACK_DEPTH:500}# 数据快照缓冲区大小
# profile.snapshot_transport_buffer_size=${SW_AGENT_PROFILE_SNAPSHOT_TRANSPORT_BUFFER_SIZE:50}# server服务地址
collector.backend_service=${SW_AGENT_COLLECTOR_BACKEND_SERVICES:127.0.0.1:11800}# sw日志文件
logging.file_name=${SW_LOGGING_FILE_NAME:skywalking-api.log}# sw日志级别
logging.level=${SW_LOGGING_LEVEL:INFO}# 日志文件地址
# logging.dir=${SW_LOGGING_DIR:""}# 单个日志文件大小, default: 300 * 1024 * 1024 = 314572800
# logging.max_file_size=${SW_LOGGING_MAX_FILE_SIZE:314572800}# 最大日志文件数量,滚动删除,小于等于0时不删除
# logging.max_history_files=${SW_LOGGING_MAX_HISTORY_FILES:-1}# 忽略异常
# statuscheck.ignored_exceptions=${SW_STATUSCHECK_IGNORED_EXCEPTIONS:}# 异常trace的跟踪深度,建议小于10,对性能有影响
# statuscheck.max_recursive_depth=${SW_STATUSCHECK_MAX_RECURSIVE_DEPTH:1}# 扩展插件
plugin.mount=${SW_MOUNT_FOLDERS:plugins,activations}# 不加载插件
# plugin.exclude_plugins=${SW_EXCLUDE_PLUGINS:}# mysql插件
# plugin.mysql.trace_sql_parameters=${SW_MYSQL_TRACE_SQL_PARAMETERS:false}# Kafka地址
# plugin.kafka.bootstrap_servers=${SW_KAFKA_BOOTSTRAP_SERVERS:localhost:9092}# Match spring bean with regex expression for classname
# plugin.springannotation.classname_match_regex=${SW_SPRINGANNOTATION_CLASSNAME_MATCH_REGEX:}

三、使用systemctl

# 创建后台启动模版
vim /etc/systemd/system/skywaking.service
# 内容如下:
[Unit]
Description=skywaking
After=network.target[Service]
# /usr/local/src/frp_0.34.2_linux_amd64 frp所在位置
ExecStart=/opt/software/skywalking/apache-skywalking-apm-bin/bin/startup.sh[Install]
WantedBy=multi-user.target# 启动测试
systemctl start skywaking.service
# 查看启动状态
systemctl status skywaking.service
# 开机自启
systemctl enable skywaking.service
# 重新启动
systemctl restart skywaking.service

SkyWalking 文档中文版(社区提供)

https://github.com/SkyAPM/document-cn-translation-of-skywalking

相关文章:

skyWalking搭建(一)

title: “SkyWalking搭建(一)” createTime: 2021-07-27T14:34:2108:00 updateTime: 2021-07-27T14:34:2108:00 draft: false author: “name” tags: [“skywalking”] categories: [“java”] description: “测试的” 基于 docker 部署 skywalking 并实现 SpringBoot 全链路…...

Golang开发--sync.WaitGroup

sync.WaitGroup 是 Go 语言标准库中的一个并发原语,用于等待一组并发操作的完成。它提供了一种简单的方式来跟踪一组 goroutine 的执行状态,并在所有 goroutine 完成后恢复执行。 下面是关于 sync.WaitGroup 的实现细节的详细解释: 创建 Wa…...

Linux命令教程:使用cat命令查看和处理文件

文章目录 教程:使用cat命令在Linux中查看和处理文件1. 引言2. cat命令的基本概述3. 查看文件内容4. 创建文件5. 文件重定向和管道6. 格式化和编辑文件7. 实际应用示例7.1 使用cat命令浏览日志文件7.2 利用cat命令合并多个配置文件7.3 使用cat命令将文件内容发送到其…...

Websocket集群解决方案以及实战(附图文源码)

最近在项目中在做一个消息推送的功能,比如客户下单之后通知给给对应的客户发送系统通知,这种消息推送需要使用到全双工的websocket推送消息。 所谓的全双工表示客户端和服务端都能向对方发送消息。不使用同样是全双工的http是因为http只能由客户端主动发…...

科技的成就(五十一)

397、初等数论的不可解问题 1936 年 4 月,邱奇证明判定性问题不可解。33 岁的邱奇发表论文《初等数论的不可解问题》,运用λ演算给出了判定性问题一个否定的答案。λ演算是一套从数学逻辑中发展起来的形式系统,采用变量绑定和替换&#xff0c…...

Tomcat8 任意写文件PUT方法 (CVE-2017-12615)

Tomcat 任意写文件PUT方法 (CVE-2017-12615) 文章目录 Tomcat 任意写文件PUT方法 (CVE-2017-12615)1 在线漏洞解读:2 版本影响3 环境搭建4 漏洞复现4.1 访问4.2 POC攻击点4.2.1 直接发送以下数据包,然后shell将被写入Web根目录。4.2.2 访问是否通,可以访…...

SAP服务器修改主机名操作手册

1、业务背景 SAP服务器P2V:虚拟化后的服务器主机名(或叫计算机名、设备名,hostname,下文同)会和原参照克隆的服务器主机名一样,若两台服务器处于同一网域,会出现域冲突,导致以下事故发生 (1)、使得原服务器出现掉域情况(DEV->CLN->PRD后台服务器访问失效) …...

【大数据】Doris 构建实时数仓落地方案详解(一):实时数据仓库概述

本系列包含: Doris 构建实时数仓落地方案详解(一):实时数据仓库概述Doris 构建实时数仓落地方案详解(二):Doris 核心功能解读Doris 构建实时数仓落地方案详解(三)&#…...

C++ list容器的实现及讲解

所需要的基础知识 对C类的基本了解 默认构造函数 操作符重载 this指针 引用 模板等知识具有一定的了解&#xff0c;阅读该文章会很轻松。 链表节点 template<class T>struct list_node{T _data;list_node<T>* _next;list_node<T>* _prev;list_node(const T&…...

前端项目练习(练习-002-NodeJS项目初始化)

首先&#xff0c;创建一个web-002项目&#xff0c;内容和web-001一样。 下一步&#xff0c;规范一下项目结构&#xff0c;将html&#xff0c;js&#xff0c;css三个文件放到 src/view目录下面&#xff1a; 由于html引入css和js时&#xff0c;使用的是相对路径&#xff0c;所以…...

C++QT day11

绘制时钟 widget.h #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QPaintEvent>//绘制事件类 #include <QDebug>//信息调试类 #include <QPainter>//画家类 #include <QTimer>//定时器类 #include <QTime> #include &…...

Stable DIffusion 炫酷应用 | AI嵌入艺术字+光影光效

目录 1 生成AI艺术字基本流程 1.1 生成黑白图 1.2 启用ControlNet 参数设置 1.3 选择大模型 写提示词 2 不同效果组合 2.1 更改提示词 2.2 更改ControlNet 2.2.1 更改模型或者预处理器 2.2.2 更改参数 3. 其他应用 3.1 AI光影字 本节需要用到ControlNet&#xff0c;可…...

C#通过重写Panel改变边框颜色与宽度的方法

在C#中,Panel控件是一个容器控件,用于在窗体或用户控件中创建一个可用于容纳其他控件的面板。Panel提供了一种将相关控件组合在一起并进行布局的方式。以下是Panel控件的详细使用方法: 在窗体上放置 Panel 控件: 在 Visual Studio 的窗体设计器中,从工具箱中拖动并放置一…...

Vue2+ElementUI 静态首页案例

源码 <template><div class"app-container home"><el-row type"flex" justify"space-around" class"row-bg"><el-card class"box-card cardDiv1"><el-col :span"5"><div clas…...

Linux的socket通信

关于套接字通信定义如下&#xff1a; 套接字对应程序猿来说就是一套网络通信的接口&#xff0c;使用这套接口就可以完成网络通信。网络通信的主体主要分为两部分&#xff1a;客户端和服务器端。在客户端和服务器通信的时候需要频繁提到三个概念&#xff1a;IP、端口、通信数据&…...

MySQL学习大纲

了解 MySQL 的基础知识和命令是使用此数据库的前提。以下是一些必须了解的 MySQL 概念和命令&#xff0c;包括基础的 CRUD&#xff08;创建&#xff0c;读取&#xff0c;更新&#xff0c;删除&#xff09;操作&#xff0c;以及一些高级功能&#xff1a; 1. 安装和启动 命令su…...

【Ambari】银河麒麟V10 ARM64架构_安装Ambari2.7.6HDP3.3.1(HiDataPlus)

&#x1f341; 博主 "开着拖拉机回家"带您 Go to New World.✨&#x1f341; &#x1f984; 个人主页——&#x1f390;开着拖拉机回家_大数据运维-CSDN博客 &#x1f390;✨&#x1f341; &#x1fa81;&#x1f341; 希望本文能够给您带来一定的帮助&#x1f338;文…...

驱动开发练习,platform实现如下功能

实验要求 驱动代码 #include <linux/init.h> #include <linux/module.h> #include <linux/platform_device.h> #include <linux/mod_devicetable.h> #include <linux/of_gpio.h> #include <linux/unistd.h> #include <linux/interrupt…...

QT之QString的用法介绍

QT之QString的用法介绍 成员函数常见用法 成员函数 1&#xff09;QString &append(const QString &str) 将 str 字符串追加到当前字符串末尾&#xff0c;并返回修改后的 QString 对象的引用。 2&#xff09;QString &prepend(const QString &str) 将 str 字符…...

基于Java+SpringBoot+Vue3+Uniapp前后端分离考试学习一体机设计与实现2.0版本(视频讲解,已发布上线)

博主介绍&#xff1a;✌全网粉丝4W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面有丰富的经验…...

springboot 获取参数

1.获取简单参数 2.实体对象参数...

【笔记】离线Ubuntu20.04+mysql 5.7.36 + xtrabackup定时增量备份脚本

一、环境 ● Ubuntu版本查看 lsb_release -a● mysql 版本查看 mysql --version我的是ubuntu 20.04&#xff0c;mysql是5.7.36&#xff0c;所以要用 install_percona-xtrabackup-24 二、原理 备份 通过ubuntu自带的定时器运行增量备份脚本备份文件可以存储在映射后的其他…...

树哈希与换根dp:CF763D

采用的树哈希函数是&#xff1a; d p x w x ∑ y ∈ x d p y 2 w x 2 \Large dp_xw_x\times \sum_{y\in x}dp_y^2w_x^2 dpx​wx​y∈x∑​dpy2​wx2​ 发现从 x x x 到 y y y 时只有 x x x 与 y y y 的哈希值会变化&#xff0c;分别维护即可 #include<bits/stdc.h&…...

npm、yarn、pnpm如何清除缓存?

前端工程化创建项目会经常使用各种安装包管理工具&#xff0c;安装各种前端依赖包。例如&#xff0c;npm、yarn、pnpm等。时间一长&#xff0c;各种安装包管理工具的在安装依赖时&#xff0c;留下的缓存文件就会变得很大&#xff0c;以至于影响系统的运行&#xff0c;因此必要时…...

12款最火的AI画图软件,助你探索创新设计

ChatGPT火爆出圈&#xff0c;AI画图软件也如雨后春笋般流行起来。各类AI画图的软件工具横空出世&#xff0c;设计师与其焦虑工作会不会被人工智能取代&#xff0c;不如践行“工欲善其事必先利其器”&#xff0c;开拓思路&#xff0c;打开格局&#xff0c;好好地探索下如何利用好…...

cookie信息无法获取问题研究

背景 在oneapi这个前后端都有的开源项目中&#xff0c;我想接入chatnextweb到oneapi的后端。 由于需要二开chatnextweb&#xff0c;添加登录注册功能&#xff0c;考虑到java后端的性能问题和内存占用&#xff0c;决定不重启写个服务&#xff0c;而是将登录注册接入到oneapi的…...

Linux:冯诺依曼系统和操作系统的概念

文章目录 冯诺依曼体系结构冯诺依曼体系的理解 操作系统操作系统的基本定位操作系统的理解1 操作系统的理解2总结 本篇主要总结的是操作系统的基本认知和一些概念 冯诺依曼体系结构 那么上图表示的就是冯诺依曼体系结构&#xff0c;那这个体系结构是什么&#xff1f;为什么要先…...

【操作系统笔记十一】进程间通信

Linux文件系统 inode 节点 &#xff08;index node&#xff09;&#xff1a;给每个文件赋予一个称为 i 节点的数据结构。 inode 一开始是存储在硬盘中的&#xff0c;只有当文件被打开的时候&#xff0c;其对应的 i 节点才加载到内存中。 总结&#xff1a; Linux 中&#xff0c…...

【操作系统】聊聊Linux软中断

什么是中断 中断是系统用来响应硬件设备请求的一种机制&#xff0c;会打断进程的正常调度和执行&#xff0c;转而去执行内核中的中断处理程序。 比如你正在看书&#xff0c;你女朋友叫你出去逛街。你就需要先放下手里的事情&#xff0c;然后逛街。回来之后&#xff0c;在接着看…...

公众号迁移个人可以迁移吗?

公众号账号迁移的作用是什么&#xff1f;只能变更主体吗&#xff1f;很多小伙伴想做公众号迁移&#xff0c;但是不知道公众号迁移有什么作用&#xff0c;今天跟大家具体讲解一下。首先公众号迁移最主要的就是修改公众号的主体了&#xff0c;比如我们公众号原来是A公司的&#x…...

苏州园区网站建设/最新军事动态

SQL Server 日期的加减函数: DATEDIFF DATEADD 原文:SQL Server 日期的加减函数: DATEDIFF DATEADD原文地址&#xff1a;http://blog.csdn.net/xyzqiang/article/details/6577831 SQL Server 日期的加减函数: DATEDIFF DATEADDDATEDIFF: 返回跨两个指定日期的日期边界数和时…...

哪些域名适合营销型网站/苏州seo建站

centos 7 中没有iptables 和service iptables save 指令使用失败问题解决方案参考文章&#xff1a; &#xff08;1&#xff09;centos 7 中没有iptables 和service iptables save 指令使用失败问题解决方案 &#xff08;2&#xff09;https://www.cnblogs.com/AmbitiousMice/…...

浏览国外网站dns/广州网站排名优化报价

摘要&#xff1a; 前面分享了一些less的是用方法&#xff0c;包括在grunt中&#xff0c;今天在分享下使用gulp来编译less文件。首先需要安装gulp&#xff0c;如何安装请看文章。 安装插件&#xff1a; gulp编译less使用了gulp-less模块&#xff0c;所以package.json如下&#x…...

网站和网页的区别/网络软文投放

传送门 题意 一棵树&#xff0c;有些是红点。如果点u满足&#xff1a;每个红点到u的距离都<D&#xff0c;则u符合题意。求合题意的点有多少个。 注&#xff1a;题干用的是”小姐姐“&#xff0c;本文都用”红点“来指代。 思路 我们不妨求出离当前点最远的红点的距离值…...

2017网站备案抽查/搜索引擎排名优化公司

当你在seachBar中输入字母之前的时候&#xff0c;只是用鼠标选中searchBar的时候&#xff0c;如图 终端输出截图如下&#xff1a;&#xff08;这个时候调用先shouldBeginEditing&#xff0c;之后调用didBeginEditing&#xff0c;&#xff09; 当你希望选中UISearchBar的时候…...

杭州杭州网站建设公司/营销推广策划及渠道

序列号内容链接1前端知识面试题 - http&https&#xff08;2022版&#xff09;https://blog.csdn.net/qq_43061290/article/details/1266517832前端知识面试题 - 浏览器&#xff08;2022版&#xff09;https://blog.csdn.net/qq_43061290/article/details/1267765383前端知识…...