Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Kubernetes Anywhere

Kubernetes Anywhere

Kubernetes Anywhere is a coherent, platform-agnostic way to provision Kubernetes clusters. Presented at the Berlin Kubernetes Meetup, 6 April 2016. https://github.com/weaveworks/kubernetes-anywhere

Peter Bourgon

April 06, 2016
Tweet

More Decks by Peter Bourgon

Other Decks in Technology

Transcript

  1. weaveworks-
    Kubernetes Anywhere
    Coherent, platform-agnostic provisioning

    View Slide

  2. weaveworks-
    @mfdii

    View Slide

  3. weaveworks-
    @mfdii

    View Slide

  4. weaveworks-
    kube-apiserver

    View Slide

  5. weaveworks-
    kube-apiserver
    etcd

    View Slide

  6. weaveworks-
    kube-controller-manager
    kube-apiserver
    etcd

    View Slide

  7. weaveworks-
    kube-controller-manager
    kube-scheduler
    kube-apiserver
    etcd

    View Slide

  8. weaveworks-
    kube-controller-manager
    kube-scheduler
    kube-apiserver
    kube-proxy
    kubelet
    etcd

    View Slide

  9. weaveworks-
    kube-controller-manager
    kube-scheduler
    kube-apiserver
    kube-proxy
    kubelet
    etcd

    View Slide

  10. weaveworks-
    kube-controller-manager
    kube-scheduler
    kube-apiserver
    kube-proxy
    kubelet
    etcd

    View Slide

  11. weaveworks-
    kubelet
    kube-proxy
    kube-controller-manager
    kube-scheduler
    kube-apiserver
    kube-proxy
    kubelet
    etcd

    View Slide

  12. weaveworks-
    kubelet
    kube-proxy
    kube-controller-manager
    kube-scheduler
    kube-apiserver
    kube-proxy
    kubelet
    etcd

    View Slide

  13. weaveworks-
    etcd
    etcd
    kubelet
    kube-proxy
    kube-controller-manager
    kube-scheduler
    kube-apiserver
    kube-proxy
    kubelet
    etcd

    View Slide

  14. weaveworks-
    etcd
    etcd
    kubelet
    kube-proxy
    kube-controller-manager
    kube-scheduler
    kube-apiserver
    kube-proxy
    kubelet
    etcd
    etcdN.cluster.internal
    k0.cluster.internal
    kN.cluster.internal

    View Slide

  15. weaveworks-
    Deployment choices
    • Bare metal?
    • Cloud provider — DigitalOcean, Linode?
    • Cloud platform — AWS, GCE, Azure?
    • Fully hosted — GKE, Deis?

    View Slide

  16. weaveworks-
    Deployment choices
    • Container OS — CoreOS, Atomic, Snappy?
    • Automation tools — Puppet, Chef, Salt, Ansible?

    View Slide

  17. weaveworks-
    Deployment choices
    • Network — base, overlay, IPVLAN? L2, L3?
    • Storage — platform-provided, NFS, Ceph, Flocker, Quobyte?
    • Monitoring — host-only, exception tracking, instrumenting?

    View Slide

  18. weaveworks-
    Deployment choices
    • Databases — hosted, containerized, separate deployment?
    • Cluster management — live upgrades, rebuild?
    • Access control?

    View Slide

  19. weaveworks-
    Deployment choices
    • Artifact repository — fileserver, internal registry, hosted registry?
    • Integration testing — none, Jenkins, Circle?
    • Deployment — ad-hoc, version-tracked, CD pipeline?

    View Slide

  20. weaveworks-
    @mfdii

    View Slide

  21. weaveworks-
    Kubernetes interacts with it all
    • Some is lightweight e.g. monitoring (cAdvisor, Prometheus)
    • Some is deeply coupled e.g. networking (Flannel, Weave, Calico)
    • Some sits in between e.g. container runtime (Docker, rkt)

    View Slide

  22. weaveworks-
    All choices are valid
    • Choices are driven by
    • Legacy systems
    • Institutional experience and knowledge
    • Individual opinions

    View Slide

  23. weaveworks-
    Wouldn't it be nice
    • Solve the problems
    • Make as few choices as possible
    • No opaque magic to hide a bunch of complexity

    View Slide

  24. weaveworks-

    View Slide

  25. weaveworks-

    View Slide

  26. weaveworks-
    Weave Net
    • Start with the network and everything falls into place
    • Weave as bootstrap/management network (& network for pods)
    • Fully self-contained, no external requirements e.g. etcd
    • Comes with DNS
    • ‛ Each Kubernetes component gets its own DNS name

    View Slide

  27. weaveworks-
    Kubernetes Anywhere
    • 100% containerized Kubernetes (including TLS!! if you want it)
    • Zero config scale-out & in-place upgrades
    • Almost no opinions baked in
    • Weave Net + bare metal = ✓
    • Weave Net + Terraform + EC2 = ✓
    • Weave Net + docker-machine + DigitalOcean = ✓

    View Slide

  28. weaveworks-
    Kubernetes Anywhere

    View Slide

  29. weaveworks-
    Kubernetes Anywhere

    View Slide

  30. weaveworks-
    Kubernetes Anywhere

    View Slide

  31. weaveworks-
    Kubernetes Anywhere

    View Slide

  32. weaveworks-
    Kubernetes Anywhere

    View Slide

  33. weaveworks-
    Kubernetes Anywhere

    View Slide

  34. weaveworks-
    Kubernetes Anywhere

    View Slide

  35. weaveworks-
    Kubernetes Anywhere

    View Slide

  36. weaveworks-
    Kubernetes Anywhere

    View Slide

  37. weaveworks-
    kubectl
    Kubernetes Anywhere

    View Slide

  38. weaveworks-
    Demo

    View Slide

  39. weaveworks-
    ABCDEs of cloud-native apps
    • Write the App, to your own requirements
    • Build and test it
    • Provision a Cluster to run the app
    • Deploy to the cluster
    • Execute the app e.g. move traffic to it

    View Slide

  40. weaveworks-
    Thanks!
    github.com/weaveworks/kubernetes-anywhere

    View Slide