k8s部署Skywalking及java接入agent

news2025/2/22 1:56:23

Skywalking由国内开源
大体架构是这样子

在这里插入图片描述
我用的是dockerhub的镜像

docker pull apache/skywalking-ui:8.5.0
docker pull apache/skywalking-oap-server:8.5.0-es7
docker pull elasticsearch:7.9.0

1.部署

搞了一个简单的es用

apiVersion: apps/v1
kind: Deployment
metadata:
  name: es
  namespace: default
spec:
  progressDeadlineSeconds: 600
  replicas: 1
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      workload.user.cattle.io/workloadselector: deployment-default-es
  strategy:
    rollingUpdate:
      maxSurge: 1
      maxUnavailable: 0
    type: RollingUpdate
  template:
    metadata:
      annotations:
        cattle.io/timestamp: "2022-11-10T03:19:31Z"
        field.cattle.io/ports: '[[{"containerPort":9200,"dnsName":"es","hostPort":0,"kind":"ClusterIP","name":"db","protocol":"TCP"},{"containerPort":9300,"dnsName":"es","hostPort":0,"kind":"ClusterIP","name":"transport","protocol":"TCP"}]]'
      creationTimestamp: null
      labels:
        workload.user.cattle.io/workloadselector: deployment-default-es
    spec:
      containers:
      - env:
        - name: discovery.type
          value: single-node
        image: elasticsearch:7.9.0
        imagePullPolicy: IfNotPresent
        name: es
        ports:
        - containerPort: 9200
          name: db
          protocol: TCP
        - containerPort: 9300
          name: transport
          protocol: TCP
        stdin: true
        terminationMessagePath: /dev/termination-log
        terminationMessagePolicy: File
        tty: true
      dnsPolicy: ClusterFirst
      restartPolicy: Always
      schedulerName: default-scheduler
      securityContext: {}
      terminationGracePeriodSeconds: 30

部署skywalking-oap

apiVersion: apps/v1
kind: Deployment
metadata:
  name: skywalking-oap
  namespace: default
spec:
  progressDeadlineSeconds: 600
  replicas: 1
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      workload.user.cattle.io/workloadselector: deployment-default-skywalking-oap
  strategy:
    rollingUpdate:
      maxSurge: 1
      maxUnavailable: 0
    type: RollingUpdate
  template:
    metadata:
      annotations:
        cattle.io/timestamp: "2022-11-10T03:22:45Z"
        field.cattle.io/ports: '[[{"containerPort":12800,"dnsName":"skywalking-oap","hostPort":0,"kind":"ClusterIP","name":"http","protocol":"TCP","sourcePort":0},{"containerPort":11800,"dnsName":"skywalking-oap","hostPort":0,"kind":"ClusterIP","name":"grpc","protocol":"TCP","sourcePort":0}]]'
      creationTimestamp: null
      labels:
        workload.user.cattle.io/workloadselector: deployment-default-skywalking-oap
    spec:
      containers:
      - env:
        - name: SW_AGENT_COLLECTOR_BACKEND_SERVICES
          value: skywalking-oap.skywalking:11800
        - name: SW_AGENT_NAME
          value: skywalking-oap
        - name: SW_ES_PASSWORD
        - name: SW_ES_USER
          value: '"elastic"'
        - name: SW_STORAGE
          value: elasticsearch7
        - name: SW_STORAGE_ES_CLUSTER_NODES
          value: es:9200
        image: apache/skywalking-oap-server:8.5.0-es7
        imagePullPolicy: IfNotPresent
        name: skywalking-oap
        ports:
        - containerPort: 12800
          name: http
          protocol: TCP
        - containerPort: 11800
          name: grpc
          protocol: TCP
        resources: {}
        securityContext:
          allowPrivilegeEscalation: false
          capabilities: {}
          privileged: false
          readOnlyRootFilesystem: false
          runAsNonRoot: false
        stdin: true
        terminationMessagePath: /dev/termination-log
        terminationMessagePolicy: File
        tty: true
      dnsPolicy: ClusterFirst
      restartPolicy: Always
      schedulerName: default-scheduler
      securityContext: {}
      terminationGracePeriodSeconds: 30

部署skywalking-ui

apiVersion: apps/v1
kind: Deployment
metadata:
  name: skywalking-ui
  namespace: default
spec:
  progressDeadlineSeconds: 600
  replicas: 1
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      workload.user.cattle.io/workloadselector: deployment-default-skywalking-ui
  strategy:
    rollingUpdate:
      maxSurge: 1
      maxUnavailable: 0
    type: RollingUpdate
  template:
    metadata:
      annotations:
        cattle.io/timestamp: "2022-11-10T03:27:36Z"
        field.cattle.io/ports: '[[{"containerPort":8080,"dnsName":"skywalking-ui","hostPort":0,"kind":"ClusterIP","name":"http","protocol":"TCP","sourcePort":0}]]'
      creationTimestamp: null
      labels:
        workload.user.cattle.io/workloadselector: deployment-default-skywalking-ui
    spec:
      containers:
      - env:
        - name: SW_OAP_ADDRESS
          value: skywalking-oap:12800
        image: apache/skywalking-ui:8.5.0
        imagePullPolicy: IfNotPresent
        name: skywalking-ui
        ports:
        - containerPort: 8080
          name: http
          protocol: TCP
        resources: {}
        securityContext:
          allowPrivilegeEscalation: false
          capabilities: {}
          privileged: false
          readOnlyRootFilesystem: false
          runAsNonRoot: false
        stdin: true
        terminationMessagePath: /dev/termination-log
        terminationMessagePolicy: File
        tty: true
      dnsPolicy: ClusterFirst
      restartPolicy: Always
      schedulerName: default-scheduler
      securityContext: {}
      terminationGracePeriodSeconds: 30

2.java接入agent(用的Sidecar模式注入)

使用 sidecar 将 pod 接入链路追踪
下面介绍如何使用 sidecar 将 pod 接入链路追踪。Java微服务接入skywalking 可以使用 SkyWalking Java Agent 来上报监控数据,这就需要 java 微服务在启动参数中通过 -javaagent: 指定 skywalking agent 探针包,通常有以下三种方式集成:

1.使用官方提供的基础镜像 skywalking-base;
2.将 agent 包构建到已存在的镜像中;
3.通过 sidecar 模式挂载 agent;

前面两种方式在前面的文章中有简单介绍,这里主要介绍如何使用 sidecar 将 pod 接入链路追踪,这种方式不需要修改原来的基础镜像,也不需要重新构建新的服务镜像,而是会以sidecar模式,通过共享的 volume 将 agent 所需的相关文件直接挂载到已经存在的服务镜像中。sidecar模式原理很简单,就是在 pod 中再部署一个初始容器,这个初始容器的作用就是将 skywalking agent 和 pod 中的应用容器共享。

#这里通过JAVA_TOOL_OPTIONS,而不是JAVA_OPTS,JAVA_TOOL_OPTIONS可以实现不通过将agent命令加入到java应用jvm参数而实现agent的集成(具体的请自行查找)

什么是初始化容器 init container
Init Container 就是用来做初始化工作的容器,可以是一个或者多个,如果有多个的话,这些容器会按定义的顺序依次执行,只有所有的 Init Container 执行完后,主容器才会被启动。我们知道一个Pod里面的所有容器是共享数据卷和网络命名空间的,所以 Init Container 里面产生的数据可以被主容器使用到的。

官方下载地址:https://archive.apache.org/dist/skywalking/

首先做这个agent镜像
下载这个包 apache-skywalking-apm-es7-8.7.0.tar
解压这个包,里面有agent

# Dockerfile
FROM busybox:latest  
ENV LANG=C.UTF-8
RUN set -eux && mkdir -p /usr/skywalking/
ADD agent/ /usr/skywalking/
WORKDIR /
docker build -t skywalking-agent:8.5.0 .

我用的应用是自己打成的spring

下面是yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  name: spring
  namespace: default
spec:
  progressDeadlineSeconds: 600
  replicas: 1
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      workload.user.cattle.io/workloadselector: deployment-default-spring
  strategy:
    rollingUpdate:
      maxSurge: 1
      maxUnavailable: 0
    type: RollingUpdate
  template:
    metadata:
      annotations:
        cattle.io/timestamp: "2022-11-10T03:24:50Z"
        field.cattle.io/ports: '[[{"containerPort":5000,"dnsName":"spring-nodeport","hostPort":0,"kind":"NodePort","name":"spring","protocol":"TCP","sourcePort":0}],[]]'
      creationTimestamp: null
      labels:
        workload.user.cattle.io/workloadselector: deployment-default-spring
    spec:
      containers:
      - env:
        - name: JAVA_TOOL_OPTIONS
          value: -javaagent:/usr/skywalking/agent/skywalking-agent.jar -XX:MaxRAMPercentage=75.0
        - name: SW_AGENT_COLLECTOR_BACKEND_SERVICES
          value: skywalking-oap:11800
        - name: TZ
          value: Asia/Shanghai
        image: root/hello-spring:v0.1
        imagePullPolicy: IfNotPresent
        name: spring
        ports:
        - containerPort: 5000
          name: spring
          protocol: TCP
        resources: {}
        securityContext:
          allowPrivilegeEscalation: false
          capabilities: {}
          privileged: false
          readOnlyRootFilesystem: false
          runAsNonRoot: false
        stdin: true
        terminationMessagePath: /dev/termination-log
        terminationMessagePolicy: File
        tty: true
        volumeMounts:
        - mountPath: /usr/skywalking/agent
          name: sw-agent
      dnsConfig: {}
      dnsPolicy: ClusterFirst
      initContainers:
      - command:
        - /bin/sh
        - -c
        - mkdir -p /skywalking/agent && cp -r /usr/skywalking/agent/* /skywalking/agent
        image: skywalking-agent:8.5.0
        imagePullPolicy: IfNotPresent
        name: agent
        resources: {}
        securityContext:
          allowPrivilegeEscalation: false
          privileged: false
          readOnlyRootFilesystem: false
          runAsNonRoot: false
        stdin: true
        terminationMessagePath: /dev/termination-log
        terminationMessagePolicy: File
        tty: true
        volumeMounts:
        - mountPath: /skywalking/agent
          name: sw-agent
      restartPolicy: Always
      schedulerName: default-scheduler
      securityContext: {}
      terminationGracePeriodSeconds: 30
      volumes:
      - hostPath:
          path: /opt/test
          type: ""
        name: sw-agent


最后的结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/4507.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL数据库基础:数据类型详解-文本字符串类型

前言 正好趁着这次一起学习复习一下MySQL数据库的基本知识。也是一直在用这个数据库,有些基础的知识点长久不用就会遗忘,就比如数据类型溢出的问题,很多时候建表的时候随便给定个类似,结果导入数据的时候报错又得删表就很麻烦&am…

第六章 Docker 应用部署

6-1 部署一个 SpringBoot 项目 1、将开发的 springboot 程序打成 jar 包或者 war 包; 2、将打好的 jar 包或 war 包上传到 Linux 某个目录下,比如:/root/docker 3、定义 Dockerfile 文件,用于创建项目镜像; 6-2 Docker 部署 Jar …

零基础如何学好Photoshop

1、首先第一点很重要,你要对PS感兴趣! 学习好PS并不是一朝一夕就可以学好的,兴趣——是迈向PS大神之路的一个好的开头,如果你只是因为工作需要,被迫去学习PS,那么你无论请教哪位大师、报读任何培训班&…

linux篇【9】:进程间通信(共享内存)——<后序>

目录 一.system V共享内存——先让不同的进程看到同一份资源 1.共享内存原理 监控共享内存脚本 2.创建/获取 共享内存接口—shmget函数(shared memory get) 3.参数key解释 (1)共享内存存在哪里? (2&a…

Spring Boot DTO 验证示例

在本教程中,我们将学习如何使用 Hibernate 验证器验证 Spring 启动 REST API DTO 请求。 在Java中,Java Bean Validation框架已经成为处理Java项目中验证的事实标准。 JSR 380 是用于 Bean 验证的 Java API 规范,它使用 NotNull、Min 和 Ma…

深入理解Java虚拟机

Java Virtual MachineJVM内存模型类加载器沙箱安全机制Native 和 方法区栈、队列、堆三种JVM垃圾回收一次完整的GCJVM内存模型 .class文件在进入类加载器后,进行加载-连接-初始化 类加载器 public class User {private String name;private Integer age;public st…

什么是浏览器的缓存机制

先来粗略的概念: 什么是浏览器的缓存机制 浏览器的缓存机制就是把一个请求过的web资源(例如:html页面、图片、js、数据等)拷贝一份副本储存在浏览器中;缓存会根据进来的请求保存输出内容的副本,当下一个请求…

frp内网穿透并实现开机自启动

frp配置内网穿透、ssh远程连接、systemctl自启动 1.服务器端 VPS 配置内网穿透 修改frps.ini文件: # frps.ini[common]bind_port 7000 启动frps: ./frps -c ./frps.ini 2.客户端配置 修改 frpc.ini 文件,假设 frps 所在服务器的公网 IP 为…

【C++笔试强训】第二十天

🎇C笔试强训 博客主页:一起去看日落吗分享博主的C刷题日常,大家一起学习博主的能力有限,出现错误希望大家不吝赐教分享给大家一句我很喜欢的话:夜色难免微凉,前方必有曙光 🌞。 💦&a…

初识C++(五)

简述:初识C章节最后一节啦 整体感觉就是C像是C的补充和升级 以一种更简单的方式奔向普罗大众 从而也能使更多人接受编程 当然不是讲C简单 就是C像是从机器时代进入了电气时代 以更简单的操作实现更高的效率,这是我在接触C一周时的整体印象。 目录 auto关…

学习python第6天

函数 函数的作用: 函数是组织好的,可以重复使用的、用来实现单一功能的代码 函数的组成   数学函数 y 6 * x 9,x 是自变量,6 * x 9 是执行过程,y 是因变量,自变量 x 决定了因变量 y 的值。 那么,你…

Python美化桌面—自制桌面宠物

前言 嗨嗨,最近就喜欢搞一些花里胡哨的东西 这不就开始折腾我的电脑了吗 浅浅搞个桌面小挂件(桌面宠物) 前期准备 开发工具 Python版本:3.6.4 相关模块: PyQt5模块; 以及一些Python自带的模块。 …

花了一天的时间,地板式扫盲了vue3中所有API盲点

📍前言 最近在一次理解vue项目的代码时,发现周一对好多API都不太熟悉。这间接导致的问题是,代码理解速度要比平常要慢很多。于是乎,赶忙把vue API的学习提上了日程。 在下面的文章中,将地板式地扫盲vue3文档中API模块…

MALUNet:一种多关注,轻量级的皮肤病变分割UNet

Tittle:MALUNet: A Multi-Attention and Light-weight UNet for Skin Lesion Segmentation 摘要 本篇文章提出的目的是为了缓解计算资源的不足,轻量化模型提出的。简单来说本文提出了4个模块。 1)DGA:由扩展卷积和门控注意机制…

【数据结构初阶】复杂链表复制+带头双向循环链表+缓存级知识

我父亲曾将我高举过头顶,所以到哪我都不会觉得自己低人一等。 加油!少年! 文章目录一、复杂链表复制二、带头双向循环链表的实现2.1 简单介绍一哈2.2 结构的定义链表初始化2.3 开辟结点空间头插尾插头删尾删链表打印2.4 结点查找pos之前插入…

【读论文】DDcGAN

DDcGAN: A Dual-Discriminator ConditionalGenerative Adversarial Network for Multi-Resolution Image Fusion简介贡献提出的方法损失函数网络结构生成器结构辨别器结构MRI和PET图像融合处理思路公式损失函数处理过程训练总结参考论文: https://ieeexplore.ieee.o…

双11,用Python爬取4000多条笔记本电脑的销售数据并分析

双11,用Python爬取4000多条笔记本电脑的销售数据并分析 2022年,大部分电子产品的销量都在下滑,比如手机,一方面,产品的创新和提升不足,另一方面,大部分人更愿意把钱存起来,降低生活…

PolarDB for PostgreSQL透明加密

PolarDB for PostgreSQL透明加密简介透明加密TDE(Transparent Data Encryption)通过在数据库层执行静止数据加密,阻止可能的攻击者绕过数据库直接从存储读取敏感信息。经过数据库身份认证的应用和用户可以继续透明地访问数据,而尝试读取数据库文件中敏感…

基于BP神经网络的非线性函数拟合(一维高斯函数)研究-含Matlab代码

目录一、引言二、BP神经网络的结构与原理2.1 信息前向传播2.2 误差的反向传播过程三、基于BP神经网络的非线性函数拟合3.1 数据生成3.2 神经网络拟合结果四、参考文献五、Matlab代码获取一、引言 以生物学基础的BP网络为全局网络,于多变量函数逼近理论不同&#xf…

C语言之文件的使用(上)

目录 目录 前言 预备知识 一、为什么要使用文件? 二、什么是文件?文件有哪些分类? 1.程序文件 2.数据文件 三、文件名 四、对文件的操作 1.基础知识(含文件指针的介绍) 2.文件打开与关闭的相关函数 1.fope…