Skip to content

Latest commit

 

History

History
 
 

pxl_scripts

PXL Scripts Overview

Pixie open sources all of its scripts, which serve as examples of scripting in the PxL language. To learn more about PxL, take a look at our documentation.

  • px/agent_status: This script gets the status of all the pixie agents (PEMs/Collectors) running.
  • px/cluster: This view lists the namespaces and the node that are available on the current cluster.
  • px/cql_data: Shows a sample of CQL (Cassandra) requests in the cluster.
  • px/cql_stats: This live view calculates the latency, error rate, and throughput of a pod's CQL (Cassandra) requests.
  • px/demo_script: Shows a sample of HTTP requests in the cluster with a very terse display format.
  • px/dns_data: Show a sample of DNS traffic in the cluster.
  • px/dns_flow_graph: Overview of DNS requests in the cluster, with latency stats.
  • px/dns_query_summary: Overview of DNS queries from pods in a namespace, grouped by the name being resolved and the rates of success.
  • px/funcs: Gets a list all of the funcs available in Pixie.
  • px/http_data: Shows most recent HTTP messages in the cluster.
  • px/http_data_filtered: Show a sample of HTTP requests in the Cluster filtered by service, pod & req-path.
  • px/http_post_requests: Show a sample of HTTP requests in the Cluster that have method POST.
  • px/http_request_stats: HTTP request statistics aggregated by Service
  • px/jvm_data: JVM stats for Java processes running on the cluster
  • px/jvm_stats: Returns the JVM Stats per Pod. You can filter this by node.
  • px/largest_http_request: Calculates the largest HTTP Request according to the passed in filter value.
  • px/most_http_data: Finds the endpoint on a specific Pod that passes the most HTTP Data. Optionally, you can uncomment a line to see a table summarizing data per service, endpoint pair.
  • px/mysql_data: Shows most recent MySQL messages in the cluster.
  • px/mysql_stats: This live view calculates the latency, error rate, and throughput of a pod's MySQL requests.
  • px/namespace: This view gives a top-level summary of the pods and services in a given namespace, as well as a service map.
  • px/namespaces: This view lists the namespaces on the current cluster and their pod and service counts. It also lists the high-level resource consumption by namespace.
  • px/net_flow_graph: The mapping of all outgoing connections for the specified k8s pods in the namespace.
  • px/network_stats: Get network stats time series
  • px/node: This view summarizes the process and network stats for a given input node in a cluster. It computes CPU, memory consumption, as well as network traffic statistics. It also displays a list of pods that were on that node during the time window.
  • px/nodes: This view summarizes the process and network stats for each node in a cluster. It computes CPU, memory consumption, as well as network traffic statistics, per node. It also displays a list of pods that were on each node during the time window.
  • px/pid_memory_usage: Get the Virtual memory usage and average memory for all processes in the k8s cluster.
  • px/pixie_quality_metrics: Metrics that sample Pixie's collector data.
  • px/pod: Overview of a specific Pod monitored by Pixie with its high level application metrics (latency, error-rate & rps) and resource usage (cpu, writes, reads).
  • px/pod_edge_stats: Gets pod latency, error rate and throughput according to another service. Edit the requestor filter to the name of the incoming service you want to filter by. Visualize these in three separate time series charts.
  • px/pod_lifetime_resource: Total resource usage of a pod over it's lifetime.
  • px/pod_memory_usage: Get the Virtual memory usage and average memory for all processes in the k8s cluster.
  • px/pods: List of Pods monitored by Pixie in a given Namespace with their high level application metrics (latency, error-rate & rps) and resource usage (cpu, writes, reads).
  • px/postgres_data: Shows most recent PGSQL (Postgres) messages in the cluster.
  • px/psql_data: Shows a sample of PostgreSQL request in the cluster.
  • px/psql_stats: This live view calculates the latency, error rate, and throughput of a pod's PostgreSQL requests.
  • px/schemas: Get all the table schemas available in the system
  • px/service: This script gets an overview of an individual service, summarizing its request statistics.
  • px/service_edge_stats: Gets service latency, error rate and throughput according to another service. Edit the requestor filter to the name of the incoming service you want to filter by. Visualize these in three separate time series charts.
  • px/service_memory_usage: Get the Virtual memory usage and average memory for all services in the k8s cluster.
  • px/service_stats: Gets service latency, error rate and throughput. Visualize them in three separate time series charts.
  • px/services: This script gets an overview of the services in a namespace, summarizing their request statistics.
  • px/slow_http_requests: This view shows a sample of slow requests by service.
  • px/tcp_drops: Shows TCP drop counts in the cluster.
  • px/tcp_retransmits: Shows TCP retransmission counts in the cluster.
  • px/tracepoint_status: Returns information about tracepoints running on the cluster.
  • px/upids: Shows a list of UPIDs running in a given namespace.
  • sotw/dns_external_fqdn_list: Lists external, fully qualified domain names (FQDNs) from all DNS traffic on the cluster for a specified amount of time.
  • sotw/dns_queries_filtered: Lists all DNS queries filtered by a specific query name.

Contributing

If you want to contribute a new PxL script, please discuss your idea on a Github issue. Since the scripts are exposed to all community users there is a comprehensive review process.

You can contribute a PxL script by forking our repo, adding a new script then creating a pull request. Once the script is accepted it will automatically deploy once the CI process completes.

To learn in more details, you can review this tutorial on Contributing PxL Scripts