Skip to content

kenan435/spartakus

 
 

Repository files navigation

Spartakus

This project aims to collect information about Kubernetes clusters. This information will help the Kubernetes development team to understand what people are doing with it, and to make it a better product.

THIS DOES NOT REPORT ANY PERSONAL INFORMATION. Anything that might be identifying, including things like IP addresses, container images, and object names are anonymized. We take this very seriously. If you think something we are collecting might be considered personal information, PLEASE let us know!

This is a 100% voluntary effort. It is not baked into Kubernetes in any way, shape, or form. If you don't want to run it, you don't have to. If you want to run your own server and collect data yourself, you can do that, too. If you want to report less information, the source is here and we're open to feature requests to better tailor the reports to what people are comfortable with.

Overview

This project encompasses two things:

  1. collector: an HTTP API which receives reports from volunteers and stores them in Google Bigquery
  2. volunteer: a tool that periodically generates reports using the Kubernetes API and publishes it to the collector

What is in a report?

Reports include a user-provided cluster identifier (we recommend a random UUID), the version strings of your kubernetes master, and some information about each node in the cluster, including OS version, kubelet version, docker version, and CPU and memory capacity.

To repeat from above: THIS DOES NOT REPORT ANY PERSONAL INFORMATION. Anything that might be identifying, including things like IP addresses, container images, and object names are anonymized. We take this very seriously. If you think something we are collecting might be considered personal information, PLEASE let us know!

An example of a report payload:

{
    "version": "v1.0.0",
    "timestamp": "867530909031976",
    "clusterID": "2f9c93d3-156c-47aa-8802-578ffca9b50e",
    "masterVersion": "v1.3.5",
    "nodes": [
        {
            "id": "c8863d09ecc5be8d9791f72acd275fc2",
            "operatingSystem": "linux",
            "osImage": "Debian GNU/Linux 7 (wheezy)",
            "kernelVersion": "3.16.0-4-amd64",
            "architecture": "amd64",
            "containerRuntimeVersion": "docker://1.11.2",
            "kubeletVersion": "v1.3.2",
            "cloudProvider": "aws",
            "capacity": [
                {
                    "resource": "alpha.kubernetes.io/nvidia-gpu",
                    "value": "0"
                },
                {
                    "resource": "cpu",
                    "value": "4"
                },
                {
                    "resource": "memory",
                    "value": "15437428Ki"
                },
                {
                    "resource": "pods",
                    "value": "110"
                }
            ]
        },
        {
            "id": "5b919a15947b0680277acddf68d4b7aa",
            "operatingSystem": "linux",
            "osImage": "Debian GNU/Linux 7 (wheezy)",
            "kernelVersion": "3.16.0-4-amd64",
            "architecture": "amd64",
            "containerRuntimeVersion": "docker://1.11.2",
            "kubeletVersion": "v1.3.2",
            "cloudProvider": "aws",
            "capacity": [
                {
                    "resource": "alpha.kubernetes.io/nvidia-gpu",
                    "value": "0"
                },
                {
                    "resource": "cpu",
                    "value": "4"
                },
                {
                    "resource": "memory",
                    "value": "15437428Ki"
                },
                {
                    "resource": "pods",
                    "value": "110"
                }
            ]
        }
    ]
}

Future

We'd like to add more information to reports, but we're starting small. Anything we add will follow the same strict privacy rules outlined above. Some examples of things we would consider adding:

  • How many Namespaces exist
  • A histogram of how many Pods, Services, Deployments, etc. exist per-Namespace
  • Average lifetime of Namespaces, Pods, Services, etc.

What will we do with this information?

This information, in aggregate, will help the Kubernetes development teams prioritize our efforts. The better we understand what people are doing, the better we can focus on the important issues.

How do I run it?

The simplest way is to use kubectl run.

kubectl run spartakus \
    --image=gcr.io/google_containers/spartakus-amd64:v1.0.0 \
    -- \
    volunteer --cluster-id=$(uuidgen)

This will generate a Deployment called "spartakus" in your "default" Namespace, which sends a report once every 24 hours. It will report a random UUID as the cluster ID. If you ever need to stop this deployment and re-run it, the UUID will be different. If you want to generate a more durable UUID by hand, that's fine too.

If you want to save the YAML that this produces, you can simply run:

kubectl get deployment spartakus -o yaml

Also, you shouldn't worry about CPU and mem usage of this pod, as it is very lightweight. You can edit the deployment to request only a small amount of CPU and memory and make sure this won't consume more. For example, this will work totally fine with 1m CPU and 10Mi mem on a 5 nodes cluster.

So, don't be afraid about its CPU/mem usage :)

Extensions

Reports can be voluntarily extended to include additional information called extensions. Extensions are key-value pairs. Valid keys have two segments: an optional prefix and a name, separated by a slash (/). The name segment is required and the prefix is optional. If specified, the prefix must be a DNS subdomain: a series of DNS labels separated by dots (.), e.g. "example.com".

In order to submit extensions, run the volunteer with the --extensions flag. This flag should be set to the path of a file of arbitrary JSON key-value pairs you would like to report, e.g.:

spartakus volunteer --cluster-id=$(uuidgen) --extensions=/path/to/my/extensions.json

Where extensions.json could be:

{
  "example.com/hello": "world",
  "example.com/foo": "bar"
}

With this configuration, the volunteer will generate a report that looks like:

{
    "version": "v1.0.0",
    "timestamp": "867530909031976",
    "clusterID": "2f9c93d3-156c-47aa-8802-578ffca9b50e",
    "masterVersion": "v1.3.5",
    "extensions": [
      {
        "name": "example.com/hello",
        "value": "world"
      },
      {
        "name": "example.com/foo",
        "value": "bar"
      }
    ]
}

The --extensions flag can optionally be set to the path of a directory. In this case, all files in the provided directory, excluding those with a leading ., will be parsed.

Development

Simply run make or make test. The build is done through Docker.

About

Anonymous Usage Collector

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 88.6%
  • Makefile 7.5%
  • Shell 3.9%