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

参考:

相关推荐
LB211217 分钟前
Redis 黑马skyout
java·数据库·redis
洛小豆21 分钟前
Swagger3学习与实践指南
spring boot·后端·spring cloud
豐儀麟阁贵23 分钟前
Java知识点储备
java·开发语言
hrrrrb29 分钟前
【Spring Security】Spring Security 密码编辑器
java·hive·spring
豐儀麟阁贵32 分钟前
2.3变量与常量
java·开发语言
摇滚侠2 小时前
Spring Boot 3零基础教程,自动配置机制,笔记07
spring boot·笔记·后端
兮动人2 小时前
Eureka注册中心通用写法和配置
java·云原生·eureka
爱编程的小白L4 小时前
基于springboot志愿服务管理系统设计与实现(附源码)
java·spring boot·后端
聪明的笨猪猪6 小时前
Java Redis “持久化”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
聪明的笨猪猪6 小时前
Java Redis “核心基础”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试