SkyWalking 10.2.0 & SWCK 配置过程

SkyWalking 10.2.0 & SWCK 配置过程

skywalking oap-server & ui 使用Docker安装在K8S集群以外,K8S集群中的微服务使用initContainer按命名空间将skywalking-java-agent注入到业务容器中。

SWCK有整套的解决方案,全安装在K8S群集中。
具体可参考:
https://skywalking.apache.org/zh/2022-04-19-how-to-use-the-java-agent-injector/
https://blog.youkuaiyun.com/alksjdfp32r/article/details/139339328

依赖ES用于存储数据,需提前安装

安装skywalking-oap


使用SW_ES_USER、SW_ES_PASSWORD变量配置ES的账户及密码,具体各变量可参考SKYWALKING的配置文件,里面全是变量。
注意 SW_STORAGE=elasticsearch 不要配置成elasticsearch7,会出异常 no provider found for module storage

启动skywalking-oap容器

docker run \
--name skywalking-oap \
--restart always \
-p 11800:11800 \
-p 12800:12800 -d \
--privileged=true \
-e SW_STORAGE=elasticsearch \
-e SW_STORAGE_ES_CLUSTER_NODES=your_es_ip:9200 \
-e SW_ES_USER=elastic \
-e SW_ES_PASSWORD=your_es_passwd \
-v /etc/localtime:/etc/localtime:ro \
your_harbor_addr/apache/skywalking-oap-server:10.2.0
docker exec -it skywalking-oap /bin/bash
docker stop  skywalking-oap
docker rm  skywalking-oap
docker logs -f skywalking-oap

如有兴趣可查看配置文件

docker cp  skywalking-oap:/skywalking/ /yourDir/skywalking/


安装skywalking-ui 

注意SW_OAP_ADDRESS配置,需要添加 "http://" 否则空指针异常:NullPointerException: authority

2025-05-21 07:43:29,114 com.linecorp.armeria.common.util.SystemInfo 525 [main] INFO  [] - IPv6: disabled (no IPv6 network interface)
Exception in thread "main" java.lang.NullPointerException: authority
        at java.base/java.util.Objects.requireNonNull(Unknown Source)
        at com.linecorp.armeria.client.Endpoint.parse(Endpoint.java:100)

检查数据是否进入ES,SW开头的索引

启动skywalking-ui容器

docker run \
--name skywalking-ui \
--restart always \
-p 8091:8080 -d \
--privileged=true \
--link skywalking-oap:skywalking-oap \
-e SW_OAP_ADDRESS=http://your_oap_addr:12800 \
-v /etc/localtime:/etc/localtime:ro \
your_harbor_addr/apache/skywalking-ui:10.2.0
docker logs -f skywalking-ui
docker stop  skywalking-ui
docker rm  skywalking-ui


安装SWCK


具体可参考:https://skywalking.apache.org/zh/2022-04-19-how-to-use-the-java-agent-injector/

安装证书管理器(cert-manger)

wget https://github.com/jetstack/cert-manager/releases/download/v1.13.3/cert-manager.yaml
kubectl apply -f cert-manager.yaml


检查安装是否成功

kubectl get pod -n cert-manager

相关镜像        

        docker push your_harbor_addr/jetstack/cert-manager-cainjector:v1.3.1
        docker push your_harbor_addr/jetstack/cert-manager-controller:v1.3.1
        docker push your_harbor_addr/jetstack/cert-manager-webhook:v1.3.1


安装SWCK operator

mkdir swck & cd swck
wget https://archive.apache.org/dist/skywalking/swck/0.6.1/skywalking-swck-0.6.1-bin.tgz
tar -xvf skywalking-swck-0.6.1-bin.tgz


operator有个镜像需要修改

      gcr.io/kubebuilder/kube-rbac-proxy:v0.8.0镜像缺失问题。由于国内无法下载,建议使用kubesphere/kube-rbac-proxy:v0.8.0替代

参考:
https://blog.youkuaiyun.com/shenghuiping2001/article/details/125354590

kubectl apply -f config/operator-bundle.yaml


检查安装是否成功

kubectl get pod -n skywalking-swck-system

部署oap和ui
这一步就省了,前面已使用Docker安装过了

修改configMap中的oap地址

kubectl edit configmap skywalking-swck-java-agent-configmap -n yourMicroServiceNamespace

yourOAPServerAddr:11800

apiVersion: v1
data:
  agent.config: |-
    # The service name in UI
    agent.service_name=${SW_AGENT_NAME:Your_ApplicationName}

    # Backend service addresses.
    collector.backend_service=${SW_AGENT_COLLECTOR_BACKEND_SERVICES:yourOAPServerAddr:11800}

    plugin.mount=${SW_MOUNT_FOLDERS:plugins,activations,optional-plugins}
  apm-trace-ignore-plugin.config: |-
    trace.ignore_path=${SW_AGENT_TRACE_IGNORE_PATH:/yourMicroService/actuator/**,/actuator/**,/eureka/**,Lettuce/**,Gson/**,Mysql/**}


相关配置可参考:https://skywalking.apache.org/docs/skywalking-java/latest/en/setup/service-agent/java-agent/configurations/#table-of-agent-configuration-properties


部署业务微服务应用


创建 yourMicroServiceNamespace 命名空间。

kubectl create namespace springboot-system


给 yourMicroServiceNamespace 命名空间打上标签使能 java 探针注入器

kubectl label namespace production swck-injection=enabled


配置微服务部署的yml文件

template:
    metadata:
      labels:
        swck-java-agent-injected: "true"  # enable the java agent injector
        app: demo-springboot
      annotations:
        strategy.skywalking.apache.org/agent.Overlay: "true"  # enable the agent overlay
        agent.skywalking.apache.org/collector.backend_service: "yourOAPServerAddr:11800"
        sidecar.skywalking.apache.org/initcontainer.Image: "your_harbor_addr/apache/skywalking-java-agent:8.8.0-java8"

  initcontainer.Image 在内网环境中无法下载apache/skywalking-java-agent,如果有HARBOR,修改一下配置即可。
  initcontainer相关配置可参考:https://skywalking.apache.org/docs/skywalking-swck/next/java-agent-injector/#configure-sidecar

kubectl apply -f springboot.yaml


查看部署情况

kubectl get pod -n yourMicroServiceNamespace


通过 JavaAgent 查看最终注入的 java 探针配置

kubectl get javaagent -n yourMicroServiceNamespace

相关configmap,你的APP所在的命名空间中也会出现一个

kubectl edit configmap skywalking-swck-java-agent-configmap -n skywalking-swck-system
kubectl edit configmap skywalking-swck-manager-config -n skywalking-swck-system

kubectl edit configmap operator-skywalking-helm-swck-operator-java-agent-configmap -n skywalking-swck-system


在 springboot-system 命名空间中部署 spring boot 应用。

 kubectl apply -f springboot.yaml


跑几百个请求试试

for i in {1..100}; do curl http://your_demo_addr/gateway/hello && echo ""; done


打开ui查看 yourUIAddr:8091
 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值