Kubesphere whizard-events
Use when working with WizTelemetry Events extension for KubeSphere, including installation, configuration, and event query API
git clone https://github.com/kubesphere/kubesphere
T=$(mktemp -d) && git clone --depth=1 https://github.com/kubesphere/kubesphere "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/whizard-events" ~/.claude/skills/kubesphere-kubesphere-whizard-events && rm -rf "$T"
skills/whizard-events/SKILL.mdWizTelemetry Events
Overview
WizTelemetry Events is an extension component in the KubeSphere Observability Platform for Kubernetes event collection, processing, and storage.
When to Use
- Installing or configuring the WizTelemetry Events extension
- Understanding event collection architecture
- Using the event query API to query events
Components
| Component | Description | Default Enabled |
|---|---|---|
| kube-events-exporter | Kubernetes event collection and export | true |
Dependencies
- WizTelemetry Platform Service (whizard-telemetry): Required
- WizTelemetry Data Pipeline (vector): Required
- OpenSearch (opensearch): Required
Installation
Prerequisites
REQUIRED: Complete all steps in order before generating InstallPlan.
Step 1: Get Available Clusters and Confirm Target
⚠️ 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
- If user explicitly specified target clusters in the request → Use those clusters directly, proceed to Step 2
- If user did NOT specify target clusters → Ask user to confirm which clusters to deploy to, then proceed to Step 2
Ask user (if not specified):
Available clusters: host, dev Which clusters do you want to deploy WizTelemetry Events to?
Step 2: Get Latest Version (if not provided by user)
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.
Install WizTelemetry Events
⚠️ IMPORTANT: Complete prerequisite steps BEFORE this step.
Based on your selections:
- Target clusters: User-confirmed cluster names
⚠️ CRITICAL: InstallPlan
MUST be metadata.name
. DO NOT use any other name.whizard-events
⚠️ CRITICAL:
field is YAML format. You MUST:config
- Use the config structure exactly as shown in the template
- DO NOT add configuration fields that are not shown in the template
- DO NOT modify the structure or hierarchy
⚠️ CRITICAL: All placeholders MUST be replaced with actual values. DO NOT leave them as placeholders.
Template
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:
: From Step 2 (e.g.,<VERSION>
)1.4.0
: User-confirmed cluster names<TARGET_CLUSTERS>
Note: OpenSearch sink configuration (endpoints, auth) is provided by the vector extension. Make sure vector is installed and configured with OpenSearch before installing events.
Enable Doris Sink
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>
Enable ISM Policy
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>
Configuration Parameters
OpenSearch Sink Parameters
| Parameter | Type | Default | Description |
|---|---|---|---|
| bool | true | Enable OpenSearch sink |
| string | "{{ .cluster }}-events" | Index prefix |
| string | "%Y.%m.%d" | Index time format |
Doris Sink Parameters
| Parameter | Type | Default | Description |
|---|---|---|---|
| bool | false | Enable Doris sink |
| string | "" | Doris Frontend address |
| string | "" | Doris Backend address |
| string | DAY | Partition unit |
| int | 7 | Retention partition |
| int | 2 | Replication number |
ISM Policy Parameters
| Parameter | Type | Default | Description |
|---|---|---|---|
| bool | false | Enable Index State Management policy |
| string | "7d" | Minimum index retention period |
Event Query API
Query Events
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 |
|---|---|---|---|
| string | query | Operation type: query/statistics/histogram/export |
| string | Comma-separated list of workspaces | |
| string | Fuzzy match workspace names | |
| string | Comma-separated list of namespaces (involvedObject.namespace) | |
| string | Fuzzy match namespace names | |
| string | Comma-separated list of object names | |
| string | Fuzzy match object names | |
| string | Comma-separated list of kinds | |
| string | Comma-separated list of reasons | |
| string | Fuzzy match reason | |
| string | Fuzzy match message | |
| string | Event type: Warning/Normal | |
| string | Start time (seconds since epoch) | |
| string | End time (seconds since epoch) | |
| string | 15m | Time interval for histogram |
| string | desc | Sort order: asc/desc |
| int | 0 | Offset |
| int | 10 | Number of results |
| string | host | Cluster name |
Extension Operations
Check Extension Status
kubectl get installplan -n kubesphere-system -l extension.kubesphere.io/name=whizard-events kubectl get extensionversions -n kubesphere-system whizard-events
Uninstall Extension
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