Compare commits
1 Commits
auto-updat
...
auto-updat
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
f7d056260d |
@@ -11,64 +11,11 @@ spec:
|
|||||||
labels:
|
labels:
|
||||||
app: iperf3-server
|
app: iperf3-server
|
||||||
spec:
|
spec:
|
||||||
serviceAccountName: iperf3-server
|
hostname: iperf3-$(NODE_NAME)
|
||||||
subdomain: iperf3
|
subdomain: iperf3
|
||||||
initContainers:
|
|
||||||
- name: create-service
|
|
||||||
image: bitnami/kubectl:latest
|
|
||||||
env:
|
|
||||||
- name: NODE_NAME
|
|
||||||
valueFrom:
|
|
||||||
fieldRef:
|
|
||||||
fieldPath: spec.nodeName
|
|
||||||
- name: POD_IP
|
|
||||||
valueFrom:
|
|
||||||
fieldRef:
|
|
||||||
fieldPath: status.podIP
|
|
||||||
command:
|
|
||||||
- /bin/bash
|
|
||||||
- -c
|
|
||||||
- |
|
|
||||||
# Clean node name for service name
|
|
||||||
NODE_CLEAN=$(echo "$NODE_NAME" | cut -d'.' -f1 | tr '[:upper:]' '[:lower:]' | tr '_' '-')
|
|
||||||
SERVICE_NAME="iperf3-${NODE_CLEAN}"
|
|
||||||
|
|
||||||
# Create service for this pod
|
|
||||||
kubectl apply -f - <<EOF
|
|
||||||
apiVersion: v1
|
|
||||||
kind: Service
|
|
||||||
metadata:
|
|
||||||
name: ${SERVICE_NAME}
|
|
||||||
namespace: iperf3
|
|
||||||
labels:
|
|
||||||
app: iperf3-node-service
|
|
||||||
target-node: "${NODE_NAME}"
|
|
||||||
spec:
|
|
||||||
type: ClusterIP
|
|
||||||
ports:
|
|
||||||
- name: iperf3
|
|
||||||
port: 5201
|
|
||||||
protocol: TCP
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: Endpoints
|
|
||||||
metadata:
|
|
||||||
name: ${SERVICE_NAME}
|
|
||||||
namespace: iperf3
|
|
||||||
labels:
|
|
||||||
app: iperf3-node-service
|
|
||||||
target-node: "${NODE_NAME}"
|
|
||||||
subsets:
|
|
||||||
- addresses:
|
|
||||||
- ip: ${POD_IP}
|
|
||||||
ports:
|
|
||||||
- name: iperf3
|
|
||||||
port: 5201
|
|
||||||
protocol: TCP
|
|
||||||
EOF
|
|
||||||
containers:
|
containers:
|
||||||
- name: iperf3-server
|
- name: iperf3-server
|
||||||
image: networkstatic/iperf3:latest
|
image: ghcr.io/edgard/iperf3_exporter:1.2.2
|
||||||
args: ["-s"]
|
args: ["-s"]
|
||||||
ports:
|
ports:
|
||||||
- containerPort: 5201
|
- containerPort: 5201
|
||||||
|
|||||||
@@ -14,63 +14,9 @@ spec:
|
|||||||
labels:
|
labels:
|
||||||
app: iperf3-exporter
|
app: iperf3-exporter
|
||||||
spec:
|
spec:
|
||||||
serviceAccountName: iperf3-server
|
|
||||||
initContainers:
|
|
||||||
- name: create-exporter-service
|
|
||||||
image: bitnami/kubectl:latest
|
|
||||||
env:
|
|
||||||
- name: NODE_NAME
|
|
||||||
valueFrom:
|
|
||||||
fieldRef:
|
|
||||||
fieldPath: spec.nodeName
|
|
||||||
- name: POD_IP
|
|
||||||
valueFrom:
|
|
||||||
fieldRef:
|
|
||||||
fieldPath: status.podIP
|
|
||||||
command:
|
|
||||||
- /bin/bash
|
|
||||||
- -c
|
|
||||||
- |
|
|
||||||
# Clean node name for service name
|
|
||||||
NODE_CLEAN=$(echo "$NODE_NAME" | cut -d'.' -f1 | tr '[:upper:]' '[:lower:]' | tr '_' '-')
|
|
||||||
SERVICE_NAME="iperf3-exporter-${NODE_CLEAN}"
|
|
||||||
|
|
||||||
# Create service for this exporter pod
|
|
||||||
kubectl apply -f - <<EOF
|
|
||||||
apiVersion: v1
|
|
||||||
kind: Service
|
|
||||||
metadata:
|
|
||||||
name: ${SERVICE_NAME}
|
|
||||||
namespace: iperf3
|
|
||||||
labels:
|
|
||||||
app: iperf3-exporter-service
|
|
||||||
target-node: "${NODE_NAME}"
|
|
||||||
spec:
|
|
||||||
type: ClusterIP
|
|
||||||
ports:
|
|
||||||
- name: metrics
|
|
||||||
port: 9579
|
|
||||||
protocol: TCP
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: Endpoints
|
|
||||||
metadata:
|
|
||||||
name: ${SERVICE_NAME}
|
|
||||||
namespace: iperf3
|
|
||||||
labels:
|
|
||||||
app: iperf3-exporter-service
|
|
||||||
target-node: "${NODE_NAME}"
|
|
||||||
subsets:
|
|
||||||
- addresses:
|
|
||||||
- ip: ${POD_IP}
|
|
||||||
ports:
|
|
||||||
- name: metrics
|
|
||||||
port: 9579
|
|
||||||
protocol: TCP
|
|
||||||
EOF
|
|
||||||
containers:
|
containers:
|
||||||
- name: iperf3-exporter
|
- name: iperf3-exporter
|
||||||
image: ghcr.io/edgard/iperf3_exporter:1.2.2
|
image: edgardlt/iperf3_exporter:latest
|
||||||
ports:
|
ports:
|
||||||
- containerPort: 9579
|
- containerPort: 9579
|
||||||
name: metrics
|
name: metrics
|
||||||
|
|||||||
@@ -2,7 +2,6 @@ apiVersion: kustomize.config.k8s.io/v1beta1
|
|||||||
kind: Kustomization
|
kind: Kustomization
|
||||||
|
|
||||||
resources:
|
resources:
|
||||||
- rbac.yaml
|
|
||||||
- daemonset.yaml
|
- daemonset.yaml
|
||||||
- service-headless.yaml
|
- service-headless.yaml
|
||||||
- iperf3-exporter-daemonset.yaml
|
- iperf3-exporter-daemonset.yaml
|
||||||
|
|||||||
@@ -1,36 +0,0 @@
|
|||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: ServiceAccount
|
|
||||||
metadata:
|
|
||||||
name: iperf3-server
|
|
||||||
namespace: iperf3
|
|
||||||
labels:
|
|
||||||
app: iperf3-server
|
|
||||||
---
|
|
||||||
apiVersion: rbac.authorization.k8s.io/v1
|
|
||||||
kind: Role
|
|
||||||
metadata:
|
|
||||||
name: iperf3-service-manager
|
|
||||||
namespace: iperf3
|
|
||||||
labels:
|
|
||||||
app: iperf3-server
|
|
||||||
rules:
|
|
||||||
- apiGroups: [""]
|
|
||||||
resources: ["services", "endpoints"]
|
|
||||||
verbs: ["get", "list", "create", "update", "patch", "delete"]
|
|
||||||
---
|
|
||||||
apiVersion: rbac.authorization.k8s.io/v1
|
|
||||||
kind: RoleBinding
|
|
||||||
metadata:
|
|
||||||
name: iperf3-service-manager
|
|
||||||
namespace: iperf3
|
|
||||||
labels:
|
|
||||||
app: iperf3-server
|
|
||||||
roleRef:
|
|
||||||
apiGroup: rbac.authorization.k8s.io
|
|
||||||
kind: Role
|
|
||||||
name: iperf3-service-manager
|
|
||||||
subjects:
|
|
||||||
- kind: ServiceAccount
|
|
||||||
name: iperf3-server
|
|
||||||
namespace: iperf3
|
|
||||||
@@ -3,6 +3,7 @@ apiVersion: monitoring.coreos.com/v1
|
|||||||
kind: ServiceMonitor
|
kind: ServiceMonitor
|
||||||
metadata:
|
metadata:
|
||||||
name: iperf3-exporter
|
name: iperf3-exporter
|
||||||
|
namespace: default
|
||||||
labels:
|
labels:
|
||||||
app: iperf3-exporter
|
app: iperf3-exporter
|
||||||
release: prometheus
|
release: prometheus
|
||||||
@@ -16,30 +17,21 @@ spec:
|
|||||||
interval: 5m
|
interval: 5m
|
||||||
scrapeTimeout: 30s
|
scrapeTimeout: 30s
|
||||||
params:
|
params:
|
||||||
target:
|
|
||||||
- "iperf3-ch.iperf3.svc.cluster.local:5201"
|
|
||||||
- "iperf3-us.iperf3.svc.cluster.local:5201"
|
|
||||||
- "iperf3-iris.iperf3.svc.cluster.local:5201"
|
|
||||||
- "iperf3-home.iperf3.svc.cluster.local:5201"
|
|
||||||
- "iperf3-master.iperf3.svc.cluster.local:5201"
|
|
||||||
- "iperf3-it.iperf3.svc.cluster.local:5201"
|
|
||||||
- "iperf3-nas.iperf3.svc.cluster.local:5201"
|
|
||||||
- "iperf3-spb.iperf3.svc.cluster.local:5201"
|
|
||||||
duration:
|
duration:
|
||||||
- "10"
|
- "10"
|
||||||
streams:
|
streams:
|
||||||
- "4"
|
- "4"
|
||||||
relabelings:
|
relabelings:
|
||||||
|
- sourceLabels: [__address__]
|
||||||
|
targetLabel: __param_target
|
||||||
|
regex: (.+):9579
|
||||||
|
replacement: iperf3-${1}.iperf3.default.svc.cluster.local:5201
|
||||||
- sourceLabels: [__param_target]
|
- sourceLabels: [__param_target]
|
||||||
targetLabel: instance
|
targetLabel: instance
|
||||||
- sourceLabels: [__param_target]
|
- targetLabel: __address__
|
||||||
targetLabel: __param_target
|
replacement: iperf3-exporter.default.svc.cluster.local:9579
|
||||||
- sourceLabels: [__param_target]
|
|
||||||
targetLabel: __address__
|
|
||||||
regex: iperf3-(.+)\.iperf3\.svc\.cluster\.local:5201
|
|
||||||
replacement: iperf3-exporter-${1}.iperf3.svc.cluster.local:9579
|
|
||||||
metricRelabelings:
|
metricRelabelings:
|
||||||
- sourceLabels: [__name__]
|
- sourceLabels: [__name__]
|
||||||
regex: iperf3_(.+)
|
regex: iperf3_(.+)
|
||||||
targetLabel: __name__
|
targetLabel: __name__
|
||||||
replacement: network_${1}
|
replacement: network_${1}
|
||||||
Reference in New Issue
Block a user