Network Observability for Kubernetes
Gain unparalleled insight into every aspect of your Kubernetes (K8s) cluster!
Kubeshark equips SREs, DevOps, and security teams with:
- Cluster-wide API traffic visibility
- Zero-touch, comprehensive distributed tracing
- Unlimited GenAI-assisted network insights
Think Wireshark re-invented for Kubernetes, deployed everywhere, continuously capturing and analyzing traffic at all times.
Cluster-wide Visibility
Kubeshark provides real-time, identity-aware, protocol-level visibility into API traffic, enabling users to observe firsthand the activities within every (even hidden) segment of their K8s clusters.
Monitor all traffic, including encrypted (TLS) data and payloads, as they enter, exit, and move through containers, pods, namespaces, nodes, and clusters.
Protocol Support
Kubeshark utilizes various packet capture technologies (e.g., eBPF, AF_PACKET) to capture cluster-wide Layer 4 (TCP, UDP, SCTP) traffic, dissecting and reassembling it into application-layer protocols. Supported protocols include:
- HTTP/1.0
- HTTP/1.1
- HTTP/2
- WebSocket
- AMQP
- Apache Kafka
- Redis
- gRPC over HTTP/2
- GraphQL over HTTP/1.1
- GraphQL over HTTP/2
- LDAP
- ICMP
- DNS
- UDP
- SCTP
- TLS
- TCP
Kubeshark can intercept encrypted (TLS) traffic within your cluster without decryption. It hooks into specific functions in libraries such as OpenSSL, Go’s crypto/tls package, and Google’s BoringSSL.
Kubeshark integrates seamlessly with service mesh solutions like Istio, Linkerd, and others, presenting mTLS traffic in plain text.
Traffic Recording & Offline Analysis
When issues aren’t immediately apparent during observation, you can schedule traffic recording or trigger it based on specific events. This data is available for offline analysis and can be uploaded to immutable storage solutions (e.g., AWS S3, GCS) for extended retention.
Automatic Distributed Tracing
Kubeshark allows you to inspect all aspects of each API call, including latency, throughput, and bandwidth, in addition to inspecting its complete payload. You can further evaluate complete traces and create a mix of spans within the traces using a rich query language. Each span or trace is enriched with information related to:
- Network context: Examine entire payloads—including encrypted ones—not just headers.
- Kubernetes context: Understand spans and traces within the Kubernetes environment, including identities, labels, namespaces, and more.
- Linux operating system context: Access details such as process IDs, names, paths, and socket information.
Kubeshark operates without requiring code instrumentation, CNI or CNI chaining, sidecars, proxies, service meshes, or any architectural changes.
GenAI-Assisted Network Insights
Kubeshark continuously monitors all traffic. It leverages advancements in Generative AI to create custom metrics, reports, and automations based on specific logic and network information.
Network Processors
Network processors utilize a scripts that combine hooks for real-time traffic processing and helpers to initiate actions. These network processors can generate custom reports, metrics, and various automations.
Kubeshark can run multiple network processors concurrently, each analyzing all traffic to serve a specific purpose (e.g., creating custom metrics for Prometheus or exporting traffic to API security scanning tools).
Custom Reports & Automations
Here are examples of custom reports and automations, many available out-of-the-box within the dashboard:
Cost Optimization
- Report: Top 5 DNS consumers as well as the most requested DNS endpoints to avoid DNS rate limiting
- Report: Inactive pods
Security
- Report & Automation: Identify (and block) pods and processes with suspicious external communication
- Automation: Export traffic for API security scanning
Reliability, Performance & Troubleshooting
- Report: Theoretical impact of network policies on live pods
- Report: API latency anomalies
- Automation: Store the last 5 minutes of traffic from crashed pods