在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的代理调用链监控了。

参考:

相关推荐
武昌库里写JAVA1 分钟前
MacOS Python3安装
java·开发语言·spring boot·学习·课程设计
eternal__day8 分钟前
Spring Cloud:构建云原生微服务架构的最佳工具和实践
java·spring cloud·微服务·云原生·架构
cdut_suye8 分钟前
【Linux系统】从 C 语言文件操作到系统调用的核心原理
java·linux·数据结构·c++·人工智能·机器学习·云计算
forestsea15 分钟前
Maven 插件参数注入与Mojo开发详解
java·maven·mojo
且听风吟022032 分钟前
Springboot之类路径扫描
spring boot
荔枝吻40 分钟前
【抽丝剥茧知识讲解】引入mybtis-plus后,mapper实现方式
java·sql·mybatis
在未来等你1 小时前
互联网大厂Java求职面试:构建高并发直播平台的架构设计与优化
java·spring boot·微服务·kubernetes·高并发·分布式系统·直播平台
轮到我狗叫了1 小时前
力扣.1471数组的k个最强值,力扣.1471数组的k个最强值力扣1576.替换所有的问号力扣1419.数青蛙编辑力扣300.最长递增子序列
java·数据结构·算法
秋野酱1 小时前
基于SpringBoot的家政服务系统设计与实现(源码+文档+部署讲解)
java·spring boot·后端
趁你还年轻_1 小时前
常用的Java工具库
java