بنقرة واحدة
whizard-events
// Use when working with WizTelemetry Events extension for KubeSphere, including installation, configuration, and event query API
// Use when working with WizTelemetry Events extension for KubeSphere, including installation, configuration, and event query API
[HINT] تحميل مجلد المهارة الكامل بما في ذلك SKILL.md وجميع الملفات المرتبطة
| name | whizard-events |
| description | Use when working with WizTelemetry Events extension for KubeSphere, including installation, configuration, and event query API |
WizTelemetry Events is an extension component in the KubeSphere Observability Platform for Kubernetes event collection, processing, and storage.
| Component | Description | Default Enabled |
|---|---|---|
| kube-events-exporter | Kubernetes event collection and export | true |
REQUIRED: Complete all steps in order before generating InstallPlan.
⚠️ CRITICAL: DO NOT proceed until target clusters are determined.
Step 1.1: Get available clusters
kubectl get clusters -o jsonpath='{.items[*].metadata.name}'
Step 1.2: Determine target clusters
Ask user (if not specified):
Available clusters: host, dev
Which clusters do you want to deploy WizTelemetry Events to?
MUST do this to get the latest version:
kubectl get extensionversions -n kubesphere-system -l kubesphere.io/extension-ref=whizard-events -o jsonpath='{range .items[*]}{.spec.version}{"\n"}{end}' | sort -V | tail -1
This outputs the latest version (e.g., 1.4.0). Note this down - you'll use it in the InstallPlan.
⚠️ IMPORTANT: Complete prerequisite steps BEFORE this step.
Based on your selections:
⚠️ CRITICAL: InstallPlan metadata.name MUST be whizard-events. DO NOT use any other name.
⚠️ CRITICAL: config field is YAML format. You MUST:
⚠️ CRITICAL: All placeholders MUST be replaced with actual values. DO NOT leave them as placeholders.
apiVersion: kubesphere.io/v1alpha1
kind: InstallPlan
metadata:
name: whizard-events
namespace: kubesphere-system
spec:
extension:
name: whizard-events
version: <VERSION> # From Step 2
enabled: true
upgradeStrategy: Manual
clusterScheduling:
placement:
clusters:
- <TARGET_CLUSTERS>
Replace placeholders:
<VERSION>: From Step 2 (e.g., 1.4.0)<TARGET_CLUSTERS>: User-confirmed cluster namesNote: OpenSearch sink configuration (endpoints, auth) is provided by the vector extension. Make sure vector is installed and configured with OpenSearch before installing events.
To enable Doris sink for events storage:
apiVersion: kubesphere.io/v1alpha1
kind: InstallPlan
metadata:
name: whizard-events
namespace: kubesphere-system
spec:
extension:
name: whizard-events
version: <VERSION> # From Step 2
enabled: true
upgradeStrategy: Manual
config: |
kube-events-exporter:
sinks:
opensearch:
enabled: true
index:
prefix: "{{ .cluster }}-events"
timestring: "%Y.%m.%d"
doris:
enabled: true
fe: <DORIS_FE>
be: <DORIS_BE>
table:
partitionUnit: DAY
retentionPartition: 7
replicationNum: 2
clusterScheduling:
placement:
clusters:
- <TARGET_CLUSTERS>
apiVersion: kubesphere.io/v1alpha1
kind: InstallPlan
metadata:
name: whizard-events
namespace: kubesphere-system
spec:
extension:
name: whizard-events
version: <VERSION> # From Step 2
enabled: true
upgradeStrategy: Manual
config: |
kube-events-exporter:
sinks:
opensearch:
enabled: true
index:
prefix: "{{ .cluster }}-events"
timestring: "%Y.%m.%d"
ism_policy:
enable: true
min_index_age: "7d"
clusterScheduling:
placement:
clusters:
- <TARGET_CLUSTERS>
| Parameter | Type | Default | Description |
|---|---|---|---|
kube-events-exporter.sinks.opensearch.enabled | bool | true | Enable OpenSearch sink |
kube-events-exporter.sinks.opensearch.index.prefix | string | "{{ .cluster }}-events" | Index prefix |
kube-events-exporter.sinks.opensearch.index.timestring | string | "%Y.%m.%d" | Index time format |
| Parameter | Type | Default | Description |
|---|---|---|---|
kube-events-exporter.sinks.doris.enabled | bool | false | Enable Doris sink |
kube-events-exporter.sinks.doris.fe | string | "" | Doris Frontend address |
kube-events-exporter.sinks.doris.be | string | "" | Doris Backend address |
kube-events-exporter.sinks.doris.table.partitionUnit | string | DAY | Partition unit |
kube-events-exporter.sinks.doris.table.retentionPartition | int | 7 | Retention partition |
kube-events-exporter.sinks.doris.table.replicationNum | int | 2 | Replication number |
| Parameter | Type | Default | Description |
|---|---|---|---|
kube-events-exporter.ism_policy.enable | bool | false | Enable Index State Management policy |
kube-events-exporter.ism_policy.min_index_age | string | "7d" | Minimum index retention period |
curl -X GET "http://whizard-telemetry-apiserver.extension-whizard-telemetry.svc:80/kapis/logging.kubesphere.io/v1alpha2/events?operation=query&sort=desc&size=10&cluster=host" \
-H "X-Remote-User: admin"
Query Parameters:
| Parameter | Type | Default | Description |
|---|---|---|---|
operation | string | query | Operation type: query/statistics/histogram/export |
workspace_filter | string | Comma-separated list of workspaces | |
workspace_search | string | Fuzzy match workspace names | |
involved_object_namespace_filter | string | Comma-separated list of namespaces (involvedObject.namespace) | |
involved_object_namespace_search | string | Fuzzy match namespace names | |
involved_object_name_filter | string | Comma-separated list of object names | |
involved_object_name_search | string | Fuzzy match object names | |
involved_object_kind_filter | string | Comma-separated list of kinds | |
reason_filter | string | Comma-separated list of reasons | |
reason_search | string | Fuzzy match reason | |
message_search | string | Fuzzy match message | |
type_filter | string | Event type: Warning/Normal | |
start_time | string | Start time (seconds since epoch) | |
end_time | string | End time (seconds since epoch) | |
interval | string | 15m | Time interval for histogram |
sort | string | desc | Sort order: asc/desc |
from | int | 0 | Offset |
size | int | 10 | Number of results |
cluster | string | host | Cluster name |
kubectl get installplan -n kubesphere-system -l extension.kubesphere.io/name=whizard-events
kubectl get extensionversions -n kubesphere-system whizard-events
Uninstall from all clusters:
kubectl delete installplan -n kubesphere-system whizard-events
Uninstall from specific cluster:
To remove WizTelemetry Events from a specific cluster, update the InstallPlan by removing that cluster from clusterScheduling.placement.clusters:
apiVersion: kubesphere.io/v1alpha1
kind: InstallPlan
metadata:
name: whizard-events
namespace: kubesphere-system
spec:
extension:
name: whizard-events
version: <VERSION>
enabled: true
upgradeStrategy: Manual
clusterScheduling:
placement:
clusters:
- <REMAINING_CLUSTERS> # Remove the cluster you want to uninstall from