A version of the Kubernetes Guestbook
application using Pulumi. Unlike the straight port of the original YAML, this variant
leverages real code to eliminate boilerplate. A ServiceDeployment
class is used that combines the common pattern
of deploying a container image using a Kubernetes Deployment
, and then scaling it using a Service
.
Follow the steps in Pulumi Installation and Kubernetes Setup to get Pulumi working with Kubernetes.
Install dependencies:
npm install
Create a new stack:
$ pulumi stack init
Enter a stack name: testbook
This example will attempt to expose the Guestbook application to the Internet with a Service
of
type LoadBalancer
. Since minikube does not support LoadBalancer
, the Guestbook application
already knows to use type ClusterIP
instead; all you need to do is to tell it whether you're
deploying to minikube:
pulumi config set guestbook:isMinikube <value>
Perform the deployment:
$ pulumi up
Updating stack 'k8sjs-guestbook'
Performing changes:
Type Name Status Info
+ pulumi:pulumi:Stack guestbook-testbook created
+ ├─ k8sjs:service:ServiceDeployment redis-master created
+ │ ├─ kubernetes:apps:Deployment redis-master created
+ │ └─ kubernetes:core:Service redis-master created
+ ├─ k8sjs:service:ServiceDeployment redis-replica created
+ │ ├─ kubernetes:apps:Deployment redis-replica created
+ │ └─ kubernetes:core:Service redis-replica created
+ └─ k8sjs:service:ServiceDeployment frontend created
+ ├─ kubernetes:apps:Deployment frontend created
+ └─ kubernetes:core:Service frontend created
---outputs:---
frontendIp: "35.232.147.18"
info: 10 changes performed:
+ 10 resources created
Update duration: 18.829381902s
Permalink: https://app.pulumi.com/acmecorp/k8sjs-guestbook/updates/1
And finally - open the application in your browser to see the running application. If you're running macOS you can simply run:
open $(pulumi stack output frontendIp)
Note: minikube does not support type
LoadBalancer
; if you are deploying to minikube, make sure to runkubectl port-forward svc/frontend 8080:80
to forward the cluster port to the local machine and access the service vialocalhost:8080
.