feat: agent - eBPF Optimize data push logic (#8653) #21316
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: auto test | |
on: | |
pull_request: | |
branches: | |
- main | |
- v6.[1-9] | |
- v7.[1-9] | |
paths: | |
- 'server/**' | |
- 'message/**' | |
- 'agent/**' | |
# schedule: | |
# - cron: '0 10,12,2,4,6,8 * * *' | |
env: | |
IMAGE: "deepflow-server" | |
AGENT_IMAGE: "deepflow-agent" | |
jobs: | |
ignore: | |
name: ignore | |
runs-on: ubuntu-latest | |
steps: | |
- run: 'echo "No build required" ' | |
# build_server: | |
# name: build server | |
# runs-on: [self-hosted, 16c16g] | |
# steps: | |
# - name: Checkout | |
# uses: actions/checkout@v3 | |
# with: | |
# submodules: recursive | |
# fetch-depth: 0 | |
# - name: get changes | |
# run: | | |
# set +e | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^server/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "SERVER_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^agent/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "AGENT_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^message/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "SERVER_CHANGE=true" >> $GITHUB_ENV | |
# echo "AGENT_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# set -e | |
# - name: Set up Go | |
# if: ${{ env.SERVER_CHANGE == 'true' }} | |
# uses: actions/setup-go@master | |
# with: | |
# go-version: 1.18.x | |
# - name: Install Protoc | |
# if: ${{ env.SERVER_CHANGE == 'true' }} | |
# uses: arduino/setup-protoc@v1 | |
# with: | |
# version: '3.6.1' | |
# repo-token: ${{ secrets.GITHUB_TOKEN }} | |
# - name: build server | |
# if: ${{ env.SERVER_CHANGE == 'true' }} | |
# run: | | |
# # sudo apt-get update | |
# # sudo apt-get install tmpl | |
# # pip install ujson | |
# GO111MODULE="off" go get github.com/gogo/protobuf/protoc-gen-gofast | |
# GO111MODULE="off" go get github.com/gogo/protobuf/proto | |
# GO111MODULE="off" go get github.com/gogo/protobuf/jsonpb | |
# GO111MODULE="off" go get github.com/gogo/protobuf/protoc-gen-gogo | |
# GO111MODULE="off" go get github.com/gogo/protobuf/gogoproto | |
# GO111MODULE="off" go get github.com/golang/protobuf/protoc-gen-go | |
# cd server | |
# CGO_ENABLED=0 GOOS=linux GOARCH=amd64 make -e BINARY_SUFFIX=.amd64 | |
# - name: Package code build results | |
# if: ${{ env.SERVER_CHANGE == 'true' }} | |
# run: | | |
# tar cvf server-artifact.tar server/bin/ | |
# - name: Archive code build results packager | |
# if: ${{ env.SERVER_CHANGE == 'true' }} | |
# uses: actions/upload-artifact@v3 | |
# with: | |
# name: build results | |
# path: | | |
# server-artifact.tar | |
# build_server_image: | |
# name: build server image | |
# needs: [build_server] | |
# runs-on: ubuntu-latest | |
# steps: | |
# - name: Checkout | |
# uses: actions/checkout@v3 | |
# with: | |
# submodules: recursive | |
# fetch-depth: 0 | |
# - name: get changes | |
# run: | | |
# set +e | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^server/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "SERVER_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^agent/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "AGENT_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^message/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "SERVER_CHANGE=true" >> $GITHUB_ENV | |
# echo "AGENT_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# set -e | |
# - name: Set up Docker Buildx | |
# uses: docker/setup-buildx-action@v2 | |
# if: ${{ env.SERVER_CHANGE == 'true' }} | |
# with: | |
# install: true | |
# - name: Download code build results | |
# uses: actions/download-artifact@v3 | |
# if: ${{ env.SERVER_CHANGE == 'true' }} | |
# with: | |
# name: build results | |
# path: . | |
# - name: Unpack code build results | |
# if: ${{ env.SERVER_CHANGE == 'true' }} | |
# run: | | |
# tar xvf server-artifact.tar | |
# - name: Log in to GitHub Docker Registry | |
# uses: docker/login-action@v2 | |
# if: ${{ env.SERVER_CHANGE == 'true' }} | |
# with: | |
# registry: "ghcr.io" | |
# username: "${{ github.repository_owner }}" | |
# password: "${{ secrets.GHCR_PUSH_TOKEN }}" | |
# - name: Build and push deepflow images | |
# if: ${{ env.SERVER_CHANGE == 'true' }} | |
# uses: docker/build-push-action@v2 | |
# with: | |
# context: server | |
# push: true | |
# file: server/Dockerfile | |
# platforms: linux/amd64 | |
# tags: | | |
# "ghcr.io/${{ github.repository_owner }}/deepflow-ce/${{ env.IMAGE }}:${{ github.run_id }}" | |
# build_agent: | |
# name: build agent | |
# runs-on: [self-hosted, 16c16g] | |
# steps: | |
# - name: Checkout | |
# uses: actions/checkout@v3 | |
# with: | |
# submodules: recursive | |
# fetch-depth: 0 | |
# - name: get changes | |
# run: | | |
# set +e | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^server/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "SERVER_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^agent/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "AGENT_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^message/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "SERVER_CHANGE=true" >> $GITHUB_ENV | |
# echo "AGENT_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# set -e | |
# - name: Log in to GitHub Docker Registry | |
# uses: docker/login-action@v2 | |
# if: ${{ env.AGENT_CHANGE == 'true' }} | |
# with: | |
# registry: "ghcr.io" | |
# username: "${{ github.repository_owner }}" | |
# password: "${{ secrets.GHCR_PUSH_TOKEN }}" | |
# - name: Build deepflow agent | |
# if: ${{ env.AGENT_CHANGE == 'true' }} | |
# uses: docker/build-push-action@v2 | |
# with: | |
# builder: default | |
# context: . | |
# push: false | |
# file: agent/docker/dockerfile-build | |
# platforms: linux/amd64 | |
# outputs: type=local,dest=./agent/output/ | |
# - name: Package code build results | |
# if: ${{ env.AGENT_CHANGE == 'true' }} | |
# run: | | |
# tar cvf agent-artifact.tar agent/output/target/x86_64-unknown-linux-musl/release/deepflow-agent agent/output/target/x86_64-unknown-linux-musl/release/deepflow-agent-ctl agent/output/src/ebpf/deepflow-ebpfctl | |
# - name: Archive code build results | |
# if: ${{ env.AGENT_CHANGE == 'true' }} | |
# uses: actions/upload-artifact@v3 | |
# with: | |
# name: agent build results | |
# path: | | |
# agent-artifact.tar | |
# build_agent_image: | |
# name: build agent image | |
# needs: [build_agent] | |
# runs-on: ubuntu-latest | |
# steps: | |
# - name: Checkout | |
# uses: actions/checkout@v3 | |
# with: | |
# submodules: recursive | |
# fetch-depth: 0 | |
# - name: get changes | |
# run: | | |
# set +e | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^server/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "SERVER_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^agent/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "AGENT_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^message/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "SERVER_CHANGE=true" >> $GITHUB_ENV | |
# echo "AGENT_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# set -e | |
# - name: Download code build results | |
# if: ${{ env.AGENT_CHANGE == 'true' }} | |
# uses: actions/download-artifact@v3 | |
# with: | |
# name: agent build results | |
# path: . | |
# - name: Unpack code build results | |
# if: ${{ env.AGENT_CHANGE == 'true' }} | |
# run: | | |
# tar xvf agent-artifact.tar | |
# - name: Set up Docker Buildx | |
# uses: docker/setup-buildx-action@v2 | |
# if: ${{ env.AGENT_CHANGE == 'true' }} | |
# with: | |
# install: true | |
# - name: Log in to GitHub Docker Registry | |
# if: ${{ env.AGENT_CHANGE == 'true' }} | |
# uses: docker/login-action@v2 | |
# with: | |
# registry: "ghcr.io" | |
# username: "${{ github.repository_owner }}" | |
# password: "${{ secrets.GHCR_PUSH_TOKEN }}" | |
# - name: Build and push deepflow agent images | |
# if: ${{ env.AGENT_CHANGE == 'true' }} | |
# uses: docker/build-push-action@v2 | |
# with: | |
# context: agent | |
# push: true | |
# file: agent/docker/dockerfile | |
# platforms: linux/amd64 | |
# tags: | | |
# "ghcr.io/${{ github.repository_owner }}/deepflow-ce/${{ env.AGENT_IMAGE }}:${{ github.run_id }}" | |
# auto_test_install: | |
# name: auto test install | |
# needs: | |
# - build_server | |
# - build_agent | |
# runs-on: ubuntu-latest | |
# steps: | |
# - name: Checkout | |
# uses: actions/checkout@v3 | |
# with: | |
# submodules: recursive | |
# fetch-depth: 0 | |
# - name: get changes | |
# run: | | |
# set +e | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^server/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "SERVER_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^agent/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "AGENT_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^message/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "SERVER_CHANGE=true" >> $GITHUB_ENV | |
# echo "AGENT_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# set -e | |
# # - name: start minikube | |
# # uses: medyagh/setup-minikube@master | |
# # with: | |
# # minikube-version: 1.24.0 | |
# # driver: docker | |
# # container-runtime: containerd | |
# # kubernetes-version: v1.22.3 | |
# # memory: 4000m | |
# # cni: bridge | |
# - name: Setup Minikube | |
# uses: manusa/[email protected] | |
# with: | |
# minikube version: 'v1.26.0' | |
# kubernetes version: 'v1.24.1' | |
# github token: ${{ secrets.GITHUB_TOKEN }} | |
# - name: Interact with the cluster | |
# run: | | |
# kubectl get nodes | |
# kubectl get sc | |
# # - name: Create k8s Kind Cluster | |
# # uses: helm/[email protected] | |
# # - name: Testing | |
# # run: | | |
# # kubectl cluster-info | |
# # kubectl get pods -n kube-system | |
# # kubectl get sc | |
# # echo "current-context:" $(kubectl config current-context) | |
# # echo "environment-kubeconfig:" ${KUBECONFIG} | |
# - name: Install Helm | |
# uses: azure/setup-helm@v1 | |
# with: | |
# version: v3.8.1 | |
# - name: add deepflow helm repo | |
# run: | | |
# helm repo add deepflow https://deepflowio.github.io/deepflow-charts | |
# helm repo update deepflow | |
# - name: install and upgrade deepflow server | |
# if: ${{ env.SERVER_CHANGE == 'true' }} | |
# run: | | |
# helm upgrade --install deepflow -n deepflow deepflow/deepflow --create-namespace \ | |
# --set global.allInOneLocalStorage=true \ | |
# --set global.hostNetwork=true \ | |
# --set global.dnsPolicy=ClusterFirstWithHostNet \ | |
# --set global.nodePort.clickhouse="" \ | |
# --set global.nodePort.deepflowServerIngester="" \ | |
# --set global.nodePort.deepflowServerhealthCheck="" \ | |
# --set global.image.repository="ghcr.io/deepflowio/deepflow-ce" \ | |
# --set-string image.server.tag=${{ github.run_id }} | |
# - name: install and upgrade deepflow agent | |
# if: ${{ env.AGENT_CHANGE == 'true' }} | |
# run: | | |
# helm upgrade --install deepflow -n deepflow deepflow/deepflow --create-namespace \ | |
# --set global.allInOneLocalStorage=true \ | |
# --set global.hostNetwork=true \ | |
# --set global.dnsPolicy=ClusterFirstWithHostNet \ | |
# --set global.nodePort.clickhouse="" \ | |
# --set global.nodePort.deepflowServerIngester="" \ | |
# --set global.nodePort.deepflowServerhealthCheck="" \ | |
# --set global.image.repository="ghcr.io/deepflowio/deepflow-ce" \ | |
# --set-string deepflow-agent.image.tag=${{ github.run_id }} \ | |
# --reuse-values | |
# - name: delete agent | |
# run: | | |
# sleep 10 | |
# kubectl delete pod -n deepflow -l component=deepflow-agent | |
# - name: get nodeport | |
# run: | | |
# CHECKNODEPORT=$(kubectl get svc -n deepflow deepflow-server -o json |jq '.spec.ports[]|select (.name=="health-check")|.nodePort') | |
# echo "CHECKNODEPORT=$CHECKNODEPORT" >> $GITHUB_ENV | |
# - name: check deepflow | |
# run: | | |
# sudo curl -o /usr/bin/deepflow-ctl https://deepflow-ce.oss-accelerate.aliyuncs.com/bin/ctl/latest/linux/amd64/deepflow-ctl | |
# sudo chmod a+x /usr/bin/deepflow-ctl | |
# timeout 600 bash -c -- \ | |
# '\ | |
# while true | |
# do | |
# kubectl get pods -n deepflow | |
# deepflow-ctl --api-port ${{ env.CHECKNODEPORT }} domain list | |
# deepflow-ctl --api-port ${{ env.CHECKNODEPORT }} agent list||true | |
# AgentCount=$(deepflow-ctl --api-port ${{ env.CHECKNODEPORT }} agent list |wc -l ) | |
# if [ "${AgentCount}" -eq "2" ] | |
# then | |
# echo "All Success." && break | |
# else | |
# echo "Something Wrong,Next loop " && sleep 2 | |
# fi | |
# done | |
# ' | |
# - name: Check agent restart | |
# run: | | |
# set +e | |
# kubectl get pods -n deepflow -l component=deepflow-agent -o jsonpath={.items[*].status.containerStatuses[*].restartCount}|awk -F" " '{for(i=1;i<=NF;i++) print $i}' |grep -v 0 | |
# if [ $? -eq 0 ] | |
# then | |
# kubectl logs -n deepflow -l app=deepflow -l component=deepflow-agent -p | |
# kubectl get pods -n deepflow | |
# echo "Agent has restart" | |
# exit 2 | |
# fi | |
# - name: logs deepflow | |
# if: ${{ always() }} | |
# run: | | |
# kubectl logs -n deepflow deepflow-server-0 -c deepflow-server | |
# kubectl logs -n deepflow -l app=deepflow -l component=deepflow-agent | |
# auto_test_upgrade: | |
# name: auto test upgrade | |
# needs: | |
# - build_server | |
# - build_agent | |
# runs-on: ubuntu-latest | |
# steps: | |
# - name: Checkout | |
# uses: actions/checkout@v3 | |
# with: | |
# submodules: recursive | |
# fetch-depth: 0 | |
# - name: get changes | |
# run: | | |
# set +e | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^server/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "SERVER_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^agent/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "AGENT_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# git diff-tree --no-commit-id --name-only --diff-filter=AMR -r origin/${GITHUB_HEAD_REF} |grep ^message/ | |
# if [ $? -eq 0 ] | |
# then | |
# echo "SERVER_CHANGE=true" >> $GITHUB_ENV | |
# echo "AGENT_CHANGE=true" >> $GITHUB_ENV | |
# fi | |
# set -e | |
# # - name: start minikube | |
# # uses: medyagh/setup-minikube@master | |
# # with: | |
# # minikube-version: 1.24.0 | |
# # driver: docker | |
# # container-runtime: containerd | |
# # kubernetes-version: v1.22.3 | |
# # memory: 4000m | |
# # cni: bridge | |
# - name: Setup Minikube | |
# uses: manusa/[email protected] | |
# with: | |
# minikube version: 'v1.26.0' | |
# kubernetes version: 'v1.24.1' | |
# github token: ${{ secrets.GITHUB_TOKEN }} | |
# - name: Interact with the cluster | |
# run: | | |
# kubectl get nodes | |
# kubectl get sc | |
# # - name: Create k8s Kind Cluster | |
# # uses: helm/[email protected] | |
# - name: Testing | |
# run: | | |
# kubectl cluster-info | |
# kubectl get pods -n kube-system | |
# kubectl get sc | |
# echo "current-context:" $(kubectl config current-context) | |
# echo "environment-kubeconfig:" ${KUBECONFIG} | |
# - name: Install Helm | |
# uses: azure/setup-helm@v1 | |
# with: | |
# version: v3.8.1 | |
# - name: install deepflow | |
# run: | | |
# helm repo add deepflow https://deepflowio.github.io/deepflow-charts | |
# helm repo update deepflow | |
# helm upgrade --install deepflow -n deepflow deepflow/deepflow --create-namespace \ | |
# --set global.allInOneLocalStorage=true \ | |
# --set global.hostNetwork=true \ | |
# --set global.dnsPolicy=ClusterFirstWithHostNet \ | |
# --set global.nodePort.clickhouse="" \ | |
# --set global.nodePort.deepflowServerIngester="" \ | |
# --set global.nodePort.deepflowServerhealthCheck="" \ | |
# --set global.image.repository="ghcr.io/deepflowio/deepflow-ce" \ | |
# --set-string image.server.tag="latest-6081" | |
# sudo curl -o /usr/bin/deepflow-ctl https://deepflow-ce.oss-accelerate.aliyuncs.com/bin/ctl/latest/linux/amd64/deepflow-ctl | |
# sudo chmod a+x /usr/bin/deepflow-ctl | |
# timeout 300 bash -c -- \ | |
# '\ | |
# while true | |
# do | |
# kubectl get pods -n deepflow | |
# set +e | |
# kubectl exec -it -n deepflow deploy/deepflow-mysql -- mysql -u root -pdeepflow -e "select * from deepflow.db_version;" | |
# kubectl exec -it -n deepflow deploy/deepflow-mysql -- mysql -u root -pdeepflow -e "select count(*) from deepflow.db_version;"|grep 1 | |
# if [ $? -eq 0 ] | |
# then | |
# break | |
# else | |
# continue | |
# fi | |
# sleep 2 | |
# done | |
# ' | |
# - name: upgrade deepflow server | |
# if: ${{ env.SERVER_CHANGE == 'true' }} | |
# run: | | |
# helm upgrade --install deepflow -n deepflow deepflow/deepflow --create-namespace \ | |
# --set global.allInOneLocalStorage=true \ | |
# --set global.hostNetwork=true \ | |
# --set global.dnsPolicy=ClusterFirstWithHostNet \ | |
# --set global.nodePort.clickhouse="" \ | |
# --set global.nodePort.deepflowServerIngester="" \ | |
# --set global.nodePort.deepflowServerhealthCheck="" \ | |
# --set global.image.repository="ghcr.io/deepflowio/deepflow-ce" \ | |
# --set-string image.server.tag=${{ github.run_id }} | |
# - name: upgrade deepflow agent | |
# if: ${{ env.AGENT_CHANGE == 'true' }} | |
# run: | | |
# helm upgrade --install deepflow -n deepflow deepflow/deepflow --create-namespace \ | |
# --set global.allInOneLocalStorage=true \ | |
# --set global.hostNetwork=true \ | |
# --set global.dnsPolicy=ClusterFirstWithHostNet \ | |
# --set global.nodePort.clickhouse="" \ | |
# --set global.nodePort.deepflowServerIngester="" \ | |
# --set global.nodePort.deepflowServerhealthCheck="" \ | |
# --set global.image.repository="ghcr.io/deepflowio/deepflow-ce" \ | |
# --set-string deepflow-agent.image.tag=${{ github.run_id }} \ | |
# --reuse-values | |
# - name: delete agent | |
# run: | | |
# sleep 10 | |
# kubectl delete pod -n deepflow -l component=deepflow-agent | |
# - name: get nodeport | |
# run: | | |
# CHECKNODEPORT=$(kubectl get svc -n deepflow deepflow-server -o json |jq '.spec.ports[]|select (.name=="health-check")|.nodePort') | |
# echo "CHECKNODEPORT=$CHECKNODEPORT" >> $GITHUB_ENV | |
# - name: Check deepflow | |
# run: | | |
# timeout 600 bash -c -- \ | |
# '\ | |
# while true | |
# do | |
# kubectl get pods -n deepflow | |
# deepflow-ctl --api-port ${{ env.CHECKNODEPORT }} domain list | |
# deepflow-ctl --api-port ${{ env.CHECKNODEPORT }} agent list||true | |
# CrashCount=$(deepflow-ctl --api-port ${{ env.CHECKNODEPORT }} agent list |wc -l ) | |
# if [ "${CrashCount}" -eq "2" ] | |
# then | |
# echo "All Success." && break | |
# else | |
# echo "Something Wrong,Next loop " && sleep 2 | |
# fi | |
# done | |
# ' | |
# - name: Check agent restart | |
# run: | | |
# set +e | |
# kubectl get pods -n deepflow -l component=deepflow-agent -o jsonpath={.items[*].status.containerStatuses[*].restartCount}|awk -F" " '{for(i=1;i<=NF;i++) print $i}' |grep -v 0 | |
# if [ $? -eq 0 ] | |
# then | |
# kubectl logs -n deepflow -l app=deepflow -l component=deepflow-agent -p | |
# kubectl get pods -n deepflow | |
# echo "Agent has restart" | |
# exit 2 | |
# fi | |
# - name: logs deepflow | |
# if: ${{ always() }} | |
# run: | | |
# kubectl logs -n deepflow deepflow-server-0 -c deepflow-server | |
# kubectl logs -n deepflow -l app=deepflow -l component=deepflow-agent | |
# remove_temp_docker_image: | |
# name: remove temp docker image | |
# needs: | |
# - auto_test_upgrade | |
# - auto_test_install | |
# if: ${{ always() }} | |
# runs-on: ubuntu-latest | |
# permissions: | |
# packages: write | |
# steps: | |
# - name: clean temp packages use version id | |
# if: ${{ always() }} | |
# run: | | |
# set +e | |
# gh api \ | |
# -H "Accept: application/vnd.github+json" \ | |
# /orgs/deepflowio/packages/container/deepflow-ce%2Fdeepflow-server/versions \ | |
# | jq '.[]|select (.metadata.container.tags[] == "${{ github.run_id }}")|.id' | |
# PACKAGE_VERSION_ID=$(gh api \ | |
# -H "Accept: application/vnd.github+json" \ | |
# /orgs/deepflowio/packages/container/deepflow-ce%2Fdeepflow-server/versions \ | |
# | jq '.[]|select (.metadata.container.tags[] == "${{ github.run_id }}")|.id') | |
# curl -i -X DELETE -H "Accept: application/vnd.github+json" -H "Authorization: token ${{ secrets.DELETE_PACKAGES_TOKEN }}" https://api.github.com/orgs/deepflowio/packages/container/deepflow-ce%2Fdeepflow-server/versions/$PACKAGE_VERSION_ID | |
# gh api \ | |
# -H "Accept: application/vnd.github+json" \ | |
# /orgs/deepflowio/packages/container/deepflow-ce%2Fdeepflow-agent/versions \ | |
# | jq '.[]|select (.metadata.container.tags[] == "${{ github.run_id }}")|.id' | |
# PACKAGE_VERSION_ID=$(gh api \ | |
# -H "Accept: application/vnd.github+json" \ | |
# /orgs/deepflowio/packages/container/deepflow-ce%2Fdeepflow-agent/versions \ | |
# | jq '.[]|select (.metadata.container.tags[] == "${{ github.run_id }}")|.id') | |
# curl -i -X DELETE -H "Accept: application/vnd.github+json" -H "Authorization: token ${{ secrets.DELETE_PACKAGES_TOKEN }}" https://api.github.com/orgs/deepflowio/packages/container/deepflow-ce%2Fdeepflow-agent/versions/$PACKAGE_VERSION_ID | |
# env: | |
# GITHUB_TOKEN: ${{ secrets.DELETE_PACKAGES_TOKEN }} |