在SpringBoot中验证Skywalking(AWS EKS版)

问题

之前在AWS EKS上面部署成功了Skywalking,现在在这个基础上面需要使用Springboot验证Skywalking是否生效。

思路

这里主要是自己手动构建skywalking 代理边车镜像,然后,把这个docker镜像推送到自己的AWS ECR私有库(Docker私库)上面,然后,在Spring中使用这个代理边车镜像。最后,在Skywalking UI中检查检查。

步骤

从官网上面下载skywalking的java 代理包。具体如下:

选择可选插件

解压这个包,从可选插件里面,根据你自己的java项目的实际情况,选择可选包,复制到正式插件包里面。具体如下:

将这些可选包从optional-plugins复制到plugins文件夹。

Dockerfile

bash 复制代码
FROM busybox:latest

ENV LANG=C.UTF-8

RUN set -eux && mkdir -p /usr/skywalking/agent/

ADD skywalking-agent/ /usr/skywalking/agent/

WORKDIR /

开始构建自己的skwalking agent镜像文件。

bash 复制代码
docker build -t sw-agent-sidecar .

推送到私有ECR库中

bash 复制代码
# 登录到ECR私有库
aws ecr get-login-password --region us-east-1 | docker login --username AWS --password-stdin xxxxx.dkr.ecr.us-east-1.amazonaws.com
# 构建
docker build -t sw-agent-sidecar .
# 标记
docker tag sw-agent-sidecar:latest xxx.dkr.ecr.us-east-1.amazonaws.com/sw-agent-sidecar:latest
# 推送
docker push xxxx.dkr.ecr.us-east-1.amazonaws.com/sw-agent-sidecar:latest

Spring中k8s配置

yaml 复制代码
apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    name: demo-sw
  name: demo-sw
spec:
  replicas: 1
  selector:
    matchLabels:
      name: demo-sw
  template:
    metadata:
      labels:
        name: demo-sw
    spec:
      initContainers:
      - image: xxxx.dkr.ecr.us-east-1.amazonaws.com/sw-agent-sidecar:latest
        name: sw-agent-sidecar
        imagePullPolicy: IfNotPresent
        command: ['sh']
        args: ['-c','mkdir -p /skywalking/agent && cp -r /usr/skywalking/agent/* /skywalking/agent']
        volumeMounts:
        - mountPath: /skywalking/agent
          name: sw-agent
      containers:
      - image: nginx:1.7.9
        name: nginx
        volumeMounts:
        - mountPath: /usr/skywalking/agent
          name: sw-agent
        ports:
        - containerPort: 80
      volumes:
      - name: sw-agent
        emptyDir: {}

除了在Deployment设置sidecar之外,还需要在configmap里面给Spring设置3个环境变量:

yaml 复制代码
apiVersion: v1
kind: ConfigMap
metadata:
  name: {{ .Values.services.demo2.name }}-configmap
  namespace: {{ .Release.Namespace }}
data:
  SPRING_PROFILES_ACTIVE: {{ .Values.spring.profiles.active }}
  MYSQL_HOST: {{ .Values.mysql.HOST }}
  JAVA_OPTS: -javaagent:/usr/skywalking/agent/skywalking-agent.jar
  SW_AGENT_NAME: demo2
  SW_AGENT_COLLECTOR_BACKEND_SERVICES: skywalking-skywalking-helm-oap.skywalking:11800

主要是下面3个变量:

yaml 复制代码
  JAVA_OPTS: -javaagent:/usr/skywalking/agent/skywalking-agent.jar
  SW_AGENT_NAME: demo2
  SW_AGENT_COLLECTOR_BACKEND_SERVICES: skywalking-skywalking-helm-oap.skywalking:11800

这里涉及到k8s跨名字空间的服务调用------FQDN。

效果

启动转发命令:

bash 复制代码
kubectl port-forward svc/skywalking-skywalking-helm-ui 8080:80 --namespace skywalking

具体效果:

总结

利用k8s边车模式,就解决了skywalking的代理文件共享问题。最后,利用环境变量JAVA_OPTS正常启动spring就可以开启skywalking的代理调用链监控了。

参考:

相关推荐
rannn_11113 分钟前
【苍穹外卖|Day4】套餐页面开发(新增套餐、分页查询、删除套餐、修改套餐、起售停售)
java·spring boot·后端·学习
qq_124987075317 分钟前
基于JavaWeb的大学生房屋租赁系统(源码+论文+部署+安装)
java·数据库·人工智能·spring boot·计算机视觉·毕业设计·计算机毕业设计
短剑重铸之日23 分钟前
《设计模式》第十一篇:总结
java·后端·设计模式·总结
若鱼19191 小时前
SpringBoot4.0新特性-Observability让生产环境更易于观测
java·spring
倒流时光三十年1 小时前
SpringBoot 数据库同步 Elasticsearch 性能优化
数据库·spring boot·elasticsearch
觉醒大王1 小时前
强女思维:着急,是贪欲外显的相。
java·论文阅读·笔记·深度学习·学习·自然语言处理·学习方法
努力学编程呀(๑•ี_เ•ี๑)1 小时前
【在 IntelliJ IDEA 中切换项目 JDK 版本】
java·开发语言·intellij-idea
码农小卡拉1 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
向上的车轮1 小时前
为什么.NET(C#)转 Java 开发时常常在“吐槽”Java:checked exception
java·c#·.net
Dragon Wu1 小时前
Spring Security Oauth2.1 授权码模式实现前后端分离的方案
java·spring boot·后端·spring cloud·springboot·springcloud