SlideShare a Scribd company logo
© Copyright 2017 Pivotal Software, Inc. All rights Reserved.
Kubernetes for n00bs
Paul Czarkowski
@pczarkowski
© Copyright 2017 Pivotal Software, Inc. All rights Reserved.
Kubernetes for n00bs
Paul Czarkowski-Golejewski
@pczarkowski
https://xkcd.com/327/
Kubernetes for the PHP developer
Cover w/ Image
Agenda
■ Who I Am
■ Deploying Apps
■ What is Kubernetes
■ Demo
■ Q & A
Deploying Apps
Kubernetes for the PHP developer
package main
...
...
func main() {
fmt.Println("starting hello world app")
healthHandler := health.NewHandler()
http.Handle("/health/", healthHandler)
http.HandleFunc("/", serve)
http.ListenAndServe(":8080", nil)
}
...
...
Kubernetes for the PHP developer
- name: install ntp
package:
name: ntp
- name: configure ntp
template:
src: ntp.conf
dest: /etc/ntp.conf
notify: restart ntp
- name: start ntp
service:
name: ntp
state: started
# -*- mode: ruby -*-
# vi: set ft=ruby :
# Vagrantfile API/syntax version. Don't touch unless you know what you're doing!
VAGRANTFILE_API_VERSION = "2"
Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
# https://vagrantcloud.com/ubuntu
config.vm.box = "ubuntu/xenial64"
config.vm.network "private_network", type: "dhcp"
# Forward ports
config.vm.network "forwarded_port", guest: 8080, host: 8080 # hello world
config.vm.provider "virtualbox" do |v|
v.memory = 4096
v.cpus = 2
end
variable "region" {
default = "europe-west1-d" // We're going to need it in several places in this config
}
provider "google" {
credentials = "${file("account.json")}"
project = "my-project"
region = "${var.region}"
}
resource "google_compute_instance" "test" {
count = 1 // Adjust as desired
name = "test${count.index + 1}" // yields "test1", "test2", etc. It's also the machine's name and hostname
machine_type = "f1-micro" // smallest (CPU & RAM) available instance
zone = "${var.region}" // yields "europe-west1-d" as setup previously. Places your VM in Europe
disk {
image = "debian-7-wheezy-v20160301" // the operative system (and Linux flavour) that your machine will run
}
network_interface {
network = "default"
access_config {
// Ephemeral IP - leaving this block empty will generate a new external IP and assign it to the machine
}
}
}
Kubernetes for the PHP developer
$ curl http://my-application.com
Hello World!
Kubernetes for the PHP developer
package main
...
...
func main() {
fmt.Println("starting hello world app")
healthHandler := health.NewHandler()
http.Handle("/health/", healthHandler)
http.HandleFunc("/", serve)
http.ListenAndServe(":8080", nil)
}
...
...
FROM golang:1.8
WORKDIR /go/src/app
COPY . .
RUN go-wrapper download
RUN go-wrapper build
EXPOSE 8080
ENTRYPOINT ["/hello-world"]
apiVersion: apps/v1beta1
kind: Deployment
metadata:
labels:
app: hello-world
name: hello-app
spec:
replicas: 2
template:
metadata:
labels:
app: hello-world
spec:
containers:
- image: paulczar/hello-world
name: hello-world
$ minikube start
$ docker build -t hello-world .
$ kubectl apply -f deployment.yaml
$ curl http://localhost:8080
Hello World!
Kubernetes for the PHP developer
Kubernetes for the PHP developer
What is Kubernetes ?
Kubernetes for the PHP developer
Kubernetes for the PHP developer
What is Docker ?
Popularized Linux Containers
Originated in 2013 by a small PaaS company called DotCloud.
Provided an easy to use interface to the [already existing] Linux Containers
Linux containers are like lightweight VMs that use the built in Linux features instead of virtualizing the
hardware.
Most linux containers contain a single application rather than a whole operating system.
100s of Containers per server vs a handful of VMs.
Easy to share artifacts called Images.
Friendly to Developer and Operator workflows alike.
You tell Docker how to build a container image via a fairly simple Dockerfile which should
generally live alongside your code in your version control system.
A build/test system (ex. Jenkins, Travis, Concourse) should be used to build and tag images
based on code changes and test results and push those images to a Registry.
There are a plethora of Registries to choose from and most have a decent UI, Access
Controls, and even vuln scanning.
● Docker Registry (either public in form of Docker Hub, or privately run)
● Your Cloud Provider (most public clouds have a Registry service)
● Harbor (extends opensource registry to have enterprise features)
● Artifactory (general purpose artifact repository manager)
● Quay ( one of the earliest third party registries )
Kubernetes for the PHP developer
What is Kubernetes ?
A container orchestration system.
Greek for “Helmsman” or “Pilot”
A Borg like platform using Docker as the execution engine originally built by a small team of Google
engineers (Joe Beda, Brendan Burns and Craig McLuckie) and Open Sourced in 2014.
GIFEE (Google Infrastructure For Everybody Else).
Production ready! (for some definition of the word production.)
Has a rapid release cycle of a new minor version every three months. (version 1.9 at writing of this)
First project donated to the Cloud Native Compute Foundation.
What is Kubernetes ?
An IaaS for Containers (CaaS)
Abstracts away your infrastructure and provides a declarative language for the user to declare their
desired state and then makes that actual state
Linux containers instead of VMs.
Applications not Operating Systems.
Provides a consistent user experience for providing Compute, Network and Storage resources and
running applications that consume them.
Extends Compute, Network and Storage resources with Controllers that create, monitor and
perform actions on them to create higher level abstractions.
Controllers are effectively a infinite loop that interacts with the
kubernetes API to ensure the actual state of a resource matches
the declared state.
#!/bin/bash
while true; do
count=$(kubectl get pods | grep nginx | wc -l)
if $count < 5; then
kubectl run --image=nginx nginx
fi
sleep 120
done
Kubernetes for the PHP developer
Kubernetes for the PHP developer
https://twitter.com/onsijoe/status/598235841635360768
Kubernetes for the PHP developer
How to
Get an
Kubernetes
Are you
in the
“cloud”?
yes
Which
cloud ?
GKEAKS EKS
Azure
Google
Amazon
Do you
want
help?
no
GLHF
Pivotal Container Service
…
...
https://kubernetes.io/partners
no
yes
Other
A
laptop ?
minikube
no
yes
Kubernetes for the PHP developer
Logical Kubernetes Architecture
API Server
Kube Scheduler
K8s Master
Controller
Manager
Etcd
Kubelet
Kube-proxy
K8s Worker
Pod
Pod
Pod
K8s Worker
Pod
Pod
Pod
K8s Worker
Pod
Pod
Pod
CNI CNI CNI
Docker
Kubelet
Kube-proxy
Docker
Kubelet
Kube-proxy
Docker
one or more application containers that are tightly coupled, sharing network and storage.
Example: a web front-end Pod that consists of an NGINX container and a PHP-FPM container with a shared
unix socket and a “init” container to transform their config files based on environment variables.
deployment a controller that ensures a set number of replicas of a Pod is running and
provides update and upgrade workflows for your Pods.
Example: cloud native Node app that scales horizontally and upgrades 2 pods at a time.
statefulset a controller that manages stateful application Deployments by providing sticky
identity for pods and strict ordering and uniqueness.
Example: Cassandra database. First pod is ‘cassandra-0’ thus all other pods in the set can be told to cluster
to ‘cassandra-0’ and it will form a ring, plus the storage will survive pod restarts.
Pods (Compute)
tracks Pods based on metadata and provides connectivity and service discovery (DNS, Env
variables) for them.
Published as
ClusterIP (default) exposes service on a cluster-internal IP.
NodePort extends ClusterIP to expose services on each node’s IP via a static port.
LoadBalancer extends NodePort to configure a cloud provider’s load balancer using the
cloud-controller-manager.
Ingress is a controller that manages an external entity to provide load balancing, SSL
termination and name-based virtual hosting to services based on a set of rules.
Service (network)
Is [effectively] a Directory, possibly with data in it, available to all containers in a Pod.
Usually Shares lifecycle of a Pod (Created when Pod is created, destroyed when Pod is
destroyed).
Can be mounted from local disk, or from a network storage device such as a EBS volume,
iscsi, NFS, etc.
Volumes (Storage)
Provides key-value pairs to be injected into a pod much like user-data is injected into a Virtual
Machine in the cloud.
Allows you to do last minute configuration of applications running on Kubernetes such as
setting a database host, or a admin password.
ConfigMaps store values as strings, Secrets store them as byte arrays (serialized as base64
encoded strings).
Secrets are [currently] not encrypted by default. This is likely to change.
Can be injected as files in a Volume, or as Environment Variables.
ConfigMaps/Secrets (user-data)
Kubernetes Manifest
apiVersion:
kind:
metadata:
spec:
Kubernetes Manifest
apiVersion: v1
kind: Service
metadata:
name: hello-svc
spec:
ports:
- port: 80
protocol: TCP
targetPort: 8080
selector:
app: hello-world
type: NodePort
apiVersion: apps/v1beta1
kind: Deployment
metadata:
labels:
app: hello-world
name: hello-app
spec:
replicas: 2
template:
metadata:
labels:
app: hello-world
spec:
containers:
- image: paulczar/hello-world
name: hello-world
hello-app Pod
app=hello-world
hello-app Pod
app=hello-world
hello-svc Service
app=hello-world
http 80
http 8080 - load balanced
Kubernetes Manifest
https://url
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: hello-goodbye
spec:
rules:
- http:
paths:
- path: /hello
backend:
serviceName: hello-svc
servicePort: 80
- http:
paths:
- path: /goodbye
backend:
serviceName: goodbye-svc
servicePort: 81
ingress-nginx
app=hello-world
hello-app Pod
app=hello-world
hello-svc Service
app=hello-world
http 8080
hello-app Pod
app=goodbye-world
goodbye-svc Service
app=goodbye-world
http 8080
http://url/hello http://url/goodbye
$ kubectl apply -f manifests/
deployment "hello-app" created
service "hello-svc" created
deployment "goodbye-app" created
service "goodbye-svc" created
ingress "hello-goodbye" created
$ curl -k https://$(minikube ip)/hello
Hello World!
$ curl -k https://$(minikube ip)/goodbye
Goodbye Cruel world!
apiVersion: v1
kind: ConfigMap
metadata:
name: hello-cm
data:
db: user:pass@host/db
apiVersion: apps/v1beta1
kind: Deployment
metadata:
name: hello-app
labels:
app: hello-world
...
...
spec:
containers:
- image: paulczar/hello-world
name: hello-world
volumeMounts:
- name: config
mountPath: /etc/hello
volumes:
- name: config
configMap:
name: hello-cm
apiVersion: v1
kind: Service
metadata:
name: hello-svc
labels:
app: hello-world
spec:
ports:
- port: 81
protocol: TCP
targetPort: 8080
selector:
app: hello-world
type: NodePort
Helm is the package manager for Kubernetes
Provides tooling to template, package, share, and run Kubernetes manifests for a given
application in the form of Charts.
Helm Client a CLI that helps you develop and run Charts.
Tiller Server runs in your cluster and translates Helm Charts into Running Applications.
~ 150 community managed Helm Charts at https://hub.kubeapps.com/
.
├── Chart.yaml
├── templates
│ ├── deployment.yaml
│ ├── ingress.yaml
│ ├── NOTES.txt
│ └── service.yaml
└── values.yaml
apiVersion: v1
kind: ConfigMap
metadata:
name: {{ .Chart.name}}-cm
data:
db: {{ .Value.db }}
apiVersion: apps/v1beta1
kind: Deployment
metadata:
name: {{ .Chart.name}}-app
labels:
app: {{ .Chart.name}}
...
...
spec:
containers:
- image: paulczar/hello-world
name: hello-world
volumeMounts:
- name: config
mountPath: /etc/hello
volumes:
- name: config
configMap:
name: {{ .Chart.name}}-cm
apiVersion: v1
kind: Service
metadata:
name: {{ .Chart.name}}-svc
labels:
app: {{ .Chart.name}}-world
spec:
ports:
- port: {{ .Value.port }}
protocol: TCP
targetPort: 8080
selector:
app: {{ .Chart.name}}-world
type: NodePort
$ helm install --name staging . 
--set db=’user:pass@staging.mysql/dbname’
$ helm install --name production . 
--set db=’user:pass@production.mysql/dbname’
DEMO
Just Enough Modernization for Kubernetes (JEMFORK)
I. Codebase — One codebase tracked in revision control, many deploys
II. Dependencies — Explicitly declare and isolate dependencies
III. Config — Store config in the environment
IV. Backing Services — Treat backing services as attached resources
V. Build, release, run — Strictly separate build and run stages
VI. Processes — Execute the app as one or more stateless processes
Just Enough Modernization for Kubernetes (JEMFORK)
VII. Port binding — Export services via port binding
VIII. Concurrency — Scale out via the process model
IX. Disposability — Maximize robustness with fast startup and graceful shutdown
X. Dev/prod parity — Keep development, staging, and production as similar as possible
XI. Logs — Treat logs as event streams
XII. Admin processes — Run admin/management tasks as one-off processes
Just Enough Modernization for Kubernetes (JEMFORK)
III. Config — Store config in the environment
Just Enough Modernization for Kubernetes (JEMFORK)
Environment Variables
Just Enough Modernization for Kubernetes (JEMFORK)
Environment Variables
https://scoutapark.com
ingress-nginx
scout-nginx Pod
app=scout-nginx
scout-nginx Service
app=scout-nginx
http 8080
wordpress Pod
app=wordpress
wordpress Service
app=wordpress
http 8080
http://scoutapark.com/ http://scoutapark.com/blog
scout-php Service
app=scout-php
tcp 9000
mysql Service
app=mysql
mysql Pod
app=mysql
tcp 3306
scout-php Pod
app=scout-php
<INSERT DEMO HERE>
Further Reading
Next Steps … Further reading.
● Kubernetes Docs, specifically the tutorials and troubleshooting sectiong
○ https://kubernetes.io/docs/home/
○ https://kubernetes.io/docs/tutorials/kubernetes-basics/
○ https://kubernetes.io/docs/tasks/debug-application-cluster/troubleshooting/
● Writing your first Helm Chart
○ https://medium.com/@pczarkowski/writing-your-first-helm-chart-f3433344f824
● Pivotal’s Enterprise Kubernetes Offering
○ https://pivotal.io/platform/pivotal-container-service
● Kelsey Hightower’s Kubecon Keynote showing CI/CD pipeline
○ https://www.youtube.com/watch?v=07jq-5VbBVQ
Q & A
© Copyright 2017 Pivotal Software, Inc. All rights Reserved.
Transforming How The World Builds Software

More Related Content

PPTX
Kubernetes day 2 Operations
PPTX
Introduction to Kubernetes
PDF
A DevOps guide to Kubernetes
PPTX
Application Modernization with PKS / Kubernetes
PDF
Kubernetes extensibility
PPTX
Successful Patterns for running platforms
PDF
Fabio Ferrari | particles.io | Presentation
PDF
Helm - Package Manager for Kubernetes
Kubernetes day 2 Operations
Introduction to Kubernetes
A DevOps guide to Kubernetes
Application Modernization with PKS / Kubernetes
Kubernetes extensibility
Successful Patterns for running platforms
Fabio Ferrari | particles.io | Presentation
Helm - Package Manager for Kubernetes

What's hot (20)

PPTX
Docker Azure Friday OSS March 2017 - Developing and deploying Java & Linux on...
PDF
Docker Meetup - Melbourne 2015 - Kubernetes Deep Dive
PDF
MongoDB.local Austin 2018: MongoDB Ops Manager + Kubernetes
PPSX
Docker Kubernetes Istio
PDF
DCEU 18: Docker Enterprise Platform and Architecture
PPTX
Cloud Foundry Diego: The New Cloud Runtime - CloudOpen Europe Talk 2015
PDF
DCEU 18: From Legacy Mainframe to the Cloud: The Finnish Railways Evolution w...
PDF
Kubernetes or OpenShift - choosing your container platform for Dev and Ops
PDF
Cloud Native Applications on OpenShift
PPTX
DevOps Best Practices with Openshift - DevOpsFusion 2020
PPTX
Why kubernetes matters
PDF
DCEU 18: Docker Container Networking
PPTX
Kubernetes 101 VMworld 2019 workshop slides
PDF
Kubernetes Concepts And Architecture Powerpoint Presentation Slides
PDF
Red Hat Forum Benelux 2015
PDF
Kubernetes Architecture - beyond a black box - Part 1
PDF
Cloud infrastructure as code
PDF
Devops - Microservice and Kubernetes
PPTX
Cloud Foundry Vancouver Meetup July 2016
PPTX
What's New in Docker - February 2017
Docker Azure Friday OSS March 2017 - Developing and deploying Java & Linux on...
Docker Meetup - Melbourne 2015 - Kubernetes Deep Dive
MongoDB.local Austin 2018: MongoDB Ops Manager + Kubernetes
Docker Kubernetes Istio
DCEU 18: Docker Enterprise Platform and Architecture
Cloud Foundry Diego: The New Cloud Runtime - CloudOpen Europe Talk 2015
DCEU 18: From Legacy Mainframe to the Cloud: The Finnish Railways Evolution w...
Kubernetes or OpenShift - choosing your container platform for Dev and Ops
Cloud Native Applications on OpenShift
DevOps Best Practices with Openshift - DevOpsFusion 2020
Why kubernetes matters
DCEU 18: Docker Container Networking
Kubernetes 101 VMworld 2019 workshop slides
Kubernetes Concepts And Architecture Powerpoint Presentation Slides
Red Hat Forum Benelux 2015
Kubernetes Architecture - beyond a black box - Part 1
Cloud infrastructure as code
Devops - Microservice and Kubernetes
Cloud Foundry Vancouver Meetup July 2016
What's New in Docker - February 2017
Ad

Similar to Kubernetes for the PHP developer (20)

PPTX
Kubernetes
PDF
Kubernetes Intro
PDF
Intro to Kubernetes
PPTX
Kubernetes Introduction
PDF
Kubernetes for Beginners
PPTX
Introduction to kubernetes
PPTX
Kubernetes Internals
PDF
Kubernetes for Java developers
PDF
Kubernetes From Scratch .pdf
PDF
Cluster management with Kubernetes
PPTX
Kubernetes: від знайомства до використання у CI/CD
PPTX
01 - VMUGIT - Lecce 2018 - Fabio Rapposelli, VMware
PPTX
Kubernetes Introduction
PPTX
Kubernetes Intro @HaufeDev
PPTX
Docker and kubernetes
PDF
Craig Box (Google) - The road to Kubernetes 1.0
PDF
Why do we even have Kubernetes?
PDF
Kubernetes deep dive - - Huawei 2015-10
PPTX
Kubernetes 101
PDF
Kubernetes meetup - 2018-05-23
Kubernetes
Kubernetes Intro
Intro to Kubernetes
Kubernetes Introduction
Kubernetes for Beginners
Introduction to kubernetes
Kubernetes Internals
Kubernetes for Java developers
Kubernetes From Scratch .pdf
Cluster management with Kubernetes
Kubernetes: від знайомства до використання у CI/CD
01 - VMUGIT - Lecce 2018 - Fabio Rapposelli, VMware
Kubernetes Introduction
Kubernetes Intro @HaufeDev
Docker and kubernetes
Craig Box (Google) - The road to Kubernetes 1.0
Why do we even have Kubernetes?
Kubernetes deep dive - - Huawei 2015-10
Kubernetes 101
Kubernetes meetup - 2018-05-23
Ad

Recently uploaded (20)

PDF
Machine learning based COVID-19 study performance prediction
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PPT
Teaching material agriculture food technology
PPTX
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
PPTX
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
PDF
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
PDF
Dropbox Q2 2025 Financial Results & Investor Presentation
PPTX
MYSQL Presentation for SQL database connectivity
PPTX
20250228 LYD VKU AI Blended-Learning.pptx
PDF
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
PDF
Empathic Computing: Creating Shared Understanding
PDF
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
PDF
[발표본] 너의 과제는 클라우드에 있어_KTDS_김동현_20250524.pdf
PDF
Review of recent advances in non-invasive hemoglobin estimation
PPTX
breach-and-attack-simulation-cybersecurity-india-chennai-defenderrabbit-2025....
PDF
Modernizing your data center with Dell and AMD
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
DOCX
The AUB Centre for AI in Media Proposal.docx
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
Machine learning based COVID-19 study performance prediction
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
Teaching material agriculture food technology
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
Dropbox Q2 2025 Financial Results & Investor Presentation
MYSQL Presentation for SQL database connectivity
20250228 LYD VKU AI Blended-Learning.pptx
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
Empathic Computing: Creating Shared Understanding
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
[발표본] 너의 과제는 클라우드에 있어_KTDS_김동현_20250524.pdf
Review of recent advances in non-invasive hemoglobin estimation
breach-and-attack-simulation-cybersecurity-india-chennai-defenderrabbit-2025....
Modernizing your data center with Dell and AMD
Advanced methodologies resolving dimensionality complications for autism neur...
Mobile App Security Testing_ A Comprehensive Guide.pdf
The AUB Centre for AI in Media Proposal.docx
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx

Kubernetes for the PHP developer

  • 1. © Copyright 2017 Pivotal Software, Inc. All rights Reserved. Kubernetes for n00bs Paul Czarkowski @pczarkowski
  • 2. © Copyright 2017 Pivotal Software, Inc. All rights Reserved. Kubernetes for n00bs Paul Czarkowski-Golejewski @pczarkowski
  • 5. Cover w/ Image Agenda ■ Who I Am ■ Deploying Apps ■ What is Kubernetes ■ Demo ■ Q & A
  • 8. package main ... ... func main() { fmt.Println("starting hello world app") healthHandler := health.NewHandler() http.Handle("/health/", healthHandler) http.HandleFunc("/", serve) http.ListenAndServe(":8080", nil) } ... ...
  • 10. - name: install ntp package: name: ntp - name: configure ntp template: src: ntp.conf dest: /etc/ntp.conf notify: restart ntp - name: start ntp service: name: ntp state: started
  • 11. # -*- mode: ruby -*- # vi: set ft=ruby : # Vagrantfile API/syntax version. Don't touch unless you know what you're doing! VAGRANTFILE_API_VERSION = "2" Vagrant.configure(VAGRANTFILE_API_VERSION) do |config| # https://vagrantcloud.com/ubuntu config.vm.box = "ubuntu/xenial64" config.vm.network "private_network", type: "dhcp" # Forward ports config.vm.network "forwarded_port", guest: 8080, host: 8080 # hello world config.vm.provider "virtualbox" do |v| v.memory = 4096 v.cpus = 2 end
  • 12. variable "region" { default = "europe-west1-d" // We're going to need it in several places in this config } provider "google" { credentials = "${file("account.json")}" project = "my-project" region = "${var.region}" } resource "google_compute_instance" "test" { count = 1 // Adjust as desired name = "test${count.index + 1}" // yields "test1", "test2", etc. It's also the machine's name and hostname machine_type = "f1-micro" // smallest (CPU &amp; RAM) available instance zone = "${var.region}" // yields "europe-west1-d" as setup previously. Places your VM in Europe disk { image = "debian-7-wheezy-v20160301" // the operative system (and Linux flavour) that your machine will run } network_interface { network = "default" access_config { // Ephemeral IP - leaving this block empty will generate a new external IP and assign it to the machine } } }
  • 16. package main ... ... func main() { fmt.Println("starting hello world app") healthHandler := health.NewHandler() http.Handle("/health/", healthHandler) http.HandleFunc("/", serve) http.ListenAndServe(":8080", nil) } ... ...
  • 17. FROM golang:1.8 WORKDIR /go/src/app COPY . . RUN go-wrapper download RUN go-wrapper build EXPOSE 8080 ENTRYPOINT ["/hello-world"]
  • 18. apiVersion: apps/v1beta1 kind: Deployment metadata: labels: app: hello-world name: hello-app spec: replicas: 2 template: metadata: labels: app: hello-world spec: containers: - image: paulczar/hello-world name: hello-world
  • 19. $ minikube start $ docker build -t hello-world . $ kubectl apply -f deployment.yaml $ curl http://localhost:8080 Hello World!
  • 25. What is Docker ? Popularized Linux Containers Originated in 2013 by a small PaaS company called DotCloud. Provided an easy to use interface to the [already existing] Linux Containers Linux containers are like lightweight VMs that use the built in Linux features instead of virtualizing the hardware. Most linux containers contain a single application rather than a whole operating system. 100s of Containers per server vs a handful of VMs. Easy to share artifacts called Images. Friendly to Developer and Operator workflows alike.
  • 26. You tell Docker how to build a container image via a fairly simple Dockerfile which should generally live alongside your code in your version control system. A build/test system (ex. Jenkins, Travis, Concourse) should be used to build and tag images based on code changes and test results and push those images to a Registry. There are a plethora of Registries to choose from and most have a decent UI, Access Controls, and even vuln scanning. ● Docker Registry (either public in form of Docker Hub, or privately run) ● Your Cloud Provider (most public clouds have a Registry service) ● Harbor (extends opensource registry to have enterprise features) ● Artifactory (general purpose artifact repository manager) ● Quay ( one of the earliest third party registries )
  • 28. What is Kubernetes ? A container orchestration system. Greek for “Helmsman” or “Pilot” A Borg like platform using Docker as the execution engine originally built by a small team of Google engineers (Joe Beda, Brendan Burns and Craig McLuckie) and Open Sourced in 2014. GIFEE (Google Infrastructure For Everybody Else). Production ready! (for some definition of the word production.) Has a rapid release cycle of a new minor version every three months. (version 1.9 at writing of this) First project donated to the Cloud Native Compute Foundation.
  • 29. What is Kubernetes ? An IaaS for Containers (CaaS) Abstracts away your infrastructure and provides a declarative language for the user to declare their desired state and then makes that actual state Linux containers instead of VMs. Applications not Operating Systems. Provides a consistent user experience for providing Compute, Network and Storage resources and running applications that consume them. Extends Compute, Network and Storage resources with Controllers that create, monitor and perform actions on them to create higher level abstractions.
  • 30. Controllers are effectively a infinite loop that interacts with the kubernetes API to ensure the actual state of a resource matches the declared state. #!/bin/bash while true; do count=$(kubectl get pods | grep nginx | wc -l) if $count < 5; then kubectl run --image=nginx nginx fi sleep 120 done
  • 35. How to Get an Kubernetes Are you in the “cloud”? yes Which cloud ? GKEAKS EKS Azure Google Amazon Do you want help? no GLHF Pivotal Container Service … ... https://kubernetes.io/partners no yes Other A laptop ? minikube no yes
  • 37. Logical Kubernetes Architecture API Server Kube Scheduler K8s Master Controller Manager Etcd Kubelet Kube-proxy K8s Worker Pod Pod Pod K8s Worker Pod Pod Pod K8s Worker Pod Pod Pod CNI CNI CNI Docker Kubelet Kube-proxy Docker Kubelet Kube-proxy Docker
  • 38. one or more application containers that are tightly coupled, sharing network and storage. Example: a web front-end Pod that consists of an NGINX container and a PHP-FPM container with a shared unix socket and a “init” container to transform their config files based on environment variables. deployment a controller that ensures a set number of replicas of a Pod is running and provides update and upgrade workflows for your Pods. Example: cloud native Node app that scales horizontally and upgrades 2 pods at a time. statefulset a controller that manages stateful application Deployments by providing sticky identity for pods and strict ordering and uniqueness. Example: Cassandra database. First pod is ‘cassandra-0’ thus all other pods in the set can be told to cluster to ‘cassandra-0’ and it will form a ring, plus the storage will survive pod restarts. Pods (Compute)
  • 39. tracks Pods based on metadata and provides connectivity and service discovery (DNS, Env variables) for them. Published as ClusterIP (default) exposes service on a cluster-internal IP. NodePort extends ClusterIP to expose services on each node’s IP via a static port. LoadBalancer extends NodePort to configure a cloud provider’s load balancer using the cloud-controller-manager. Ingress is a controller that manages an external entity to provide load balancing, SSL termination and name-based virtual hosting to services based on a set of rules. Service (network)
  • 40. Is [effectively] a Directory, possibly with data in it, available to all containers in a Pod. Usually Shares lifecycle of a Pod (Created when Pod is created, destroyed when Pod is destroyed). Can be mounted from local disk, or from a network storage device such as a EBS volume, iscsi, NFS, etc. Volumes (Storage)
  • 41. Provides key-value pairs to be injected into a pod much like user-data is injected into a Virtual Machine in the cloud. Allows you to do last minute configuration of applications running on Kubernetes such as setting a database host, or a admin password. ConfigMaps store values as strings, Secrets store them as byte arrays (serialized as base64 encoded strings). Secrets are [currently] not encrypted by default. This is likely to change. Can be injected as files in a Volume, or as Environment Variables. ConfigMaps/Secrets (user-data)
  • 43. Kubernetes Manifest apiVersion: v1 kind: Service metadata: name: hello-svc spec: ports: - port: 80 protocol: TCP targetPort: 8080 selector: app: hello-world type: NodePort apiVersion: apps/v1beta1 kind: Deployment metadata: labels: app: hello-world name: hello-app spec: replicas: 2 template: metadata: labels: app: hello-world spec: containers: - image: paulczar/hello-world name: hello-world hello-app Pod app=hello-world hello-app Pod app=hello-world hello-svc Service app=hello-world http 80 http 8080 - load balanced
  • 44. Kubernetes Manifest https://url apiVersion: extensions/v1beta1 kind: Ingress metadata: name: hello-goodbye spec: rules: - http: paths: - path: /hello backend: serviceName: hello-svc servicePort: 80 - http: paths: - path: /goodbye backend: serviceName: goodbye-svc servicePort: 81 ingress-nginx app=hello-world hello-app Pod app=hello-world hello-svc Service app=hello-world http 8080 hello-app Pod app=goodbye-world goodbye-svc Service app=goodbye-world http 8080 http://url/hello http://url/goodbye
  • 45. $ kubectl apply -f manifests/ deployment "hello-app" created service "hello-svc" created deployment "goodbye-app" created service "goodbye-svc" created ingress "hello-goodbye" created $ curl -k https://$(minikube ip)/hello Hello World! $ curl -k https://$(minikube ip)/goodbye Goodbye Cruel world!
  • 46. apiVersion: v1 kind: ConfigMap metadata: name: hello-cm data: db: user:pass@host/db apiVersion: apps/v1beta1 kind: Deployment metadata: name: hello-app labels: app: hello-world ... ... spec: containers: - image: paulczar/hello-world name: hello-world volumeMounts: - name: config mountPath: /etc/hello volumes: - name: config configMap: name: hello-cm apiVersion: v1 kind: Service metadata: name: hello-svc labels: app: hello-world spec: ports: - port: 81 protocol: TCP targetPort: 8080 selector: app: hello-world type: NodePort
  • 47. Helm is the package manager for Kubernetes Provides tooling to template, package, share, and run Kubernetes manifests for a given application in the form of Charts. Helm Client a CLI that helps you develop and run Charts. Tiller Server runs in your cluster and translates Helm Charts into Running Applications. ~ 150 community managed Helm Charts at https://hub.kubeapps.com/ . ├── Chart.yaml ├── templates │ ├── deployment.yaml │ ├── ingress.yaml │ ├── NOTES.txt │ └── service.yaml └── values.yaml
  • 48. apiVersion: v1 kind: ConfigMap metadata: name: {{ .Chart.name}}-cm data: db: {{ .Value.db }} apiVersion: apps/v1beta1 kind: Deployment metadata: name: {{ .Chart.name}}-app labels: app: {{ .Chart.name}} ... ... spec: containers: - image: paulczar/hello-world name: hello-world volumeMounts: - name: config mountPath: /etc/hello volumes: - name: config configMap: name: {{ .Chart.name}}-cm apiVersion: v1 kind: Service metadata: name: {{ .Chart.name}}-svc labels: app: {{ .Chart.name}}-world spec: ports: - port: {{ .Value.port }} protocol: TCP targetPort: 8080 selector: app: {{ .Chart.name}}-world type: NodePort
  • 49. $ helm install --name staging . --set db=’user:[email protected]/dbname’ $ helm install --name production . --set db=’user:[email protected]/dbname’
  • 50. DEMO
  • 51. Just Enough Modernization for Kubernetes (JEMFORK) I. Codebase — One codebase tracked in revision control, many deploys II. Dependencies — Explicitly declare and isolate dependencies III. Config — Store config in the environment IV. Backing Services — Treat backing services as attached resources V. Build, release, run — Strictly separate build and run stages VI. Processes — Execute the app as one or more stateless processes
  • 52. Just Enough Modernization for Kubernetes (JEMFORK) VII. Port binding — Export services via port binding VIII. Concurrency — Scale out via the process model IX. Disposability — Maximize robustness with fast startup and graceful shutdown X. Dev/prod parity — Keep development, staging, and production as similar as possible XI. Logs — Treat logs as event streams XII. Admin processes — Run admin/management tasks as one-off processes
  • 53. Just Enough Modernization for Kubernetes (JEMFORK) III. Config — Store config in the environment
  • 54. Just Enough Modernization for Kubernetes (JEMFORK) Environment Variables
  • 55. Just Enough Modernization for Kubernetes (JEMFORK) Environment Variables
  • 56. https://scoutapark.com ingress-nginx scout-nginx Pod app=scout-nginx scout-nginx Service app=scout-nginx http 8080 wordpress Pod app=wordpress wordpress Service app=wordpress http 8080 http://scoutapark.com/ http://scoutapark.com/blog scout-php Service app=scout-php tcp 9000 mysql Service app=mysql mysql Pod app=mysql tcp 3306 scout-php Pod app=scout-php
  • 59. Next Steps … Further reading. ● Kubernetes Docs, specifically the tutorials and troubleshooting sectiong ○ https://kubernetes.io/docs/home/ ○ https://kubernetes.io/docs/tutorials/kubernetes-basics/ ○ https://kubernetes.io/docs/tasks/debug-application-cluster/troubleshooting/ ● Writing your first Helm Chart ○ https://medium.com/@pczarkowski/writing-your-first-helm-chart-f3433344f824 ● Pivotal’s Enterprise Kubernetes Offering ○ https://pivotal.io/platform/pivotal-container-service ● Kelsey Hightower’s Kubecon Keynote showing CI/CD pipeline ○ https://www.youtube.com/watch?v=07jq-5VbBVQ
  • 60. Q & A
  • 61. © Copyright 2017 Pivotal Software, Inc. All rights Reserved. Transforming How The World Builds Software