Skip to content

Latest commit

 

History

History
150 lines (93 loc) · 3.13 KB

README.md

File metadata and controls

150 lines (93 loc) · 3.13 KB

servicemesh-demo

A servicemesh demo using Hybrid services on Digital Ocean with Consul

requirements

In order to run this demo, you need some stuff installed.

  • kubectl
  • helm (version 3)
  • consul cli

Obviously, you also need a Digital Ocean account.

demo steps

spin up infrastructure

Make sure your API key for Digital Ocean is exported.

cd infra
terraform init
terraform plan # Optional
terraform apply

This will create all infrastructure necessary to follow along with the demo. Make sure to remove your infrastructure if you are not using it, since you pay by the hour.

initial deployment of applications

We'll be using a set of fake services, written by Nic Jackson and are a nice way to demo the service mesh idea.

As we are using a physical DB server of which we cannot predict the IP. (in this example) Next to this being an example on how a service mesh can help out, we also need to use some cli magic to update the DB ip in all manifests.

Get the IP of the DB server.

doctl compute droplet list | grep DB

Use the found IP in the sed command to update the manifests

find k8s -name "*yaml" | xargs sed -i 's/0.0.0.0/REAL_IP/g' 

Now, fetch the Kubernetes configuration file

doctl kubernetes cluster kubeconfig save ams-cluster 

Now deploy the application

kubectl apply -f k8s/initial-setup.yaml

Now, we use a trick to access the web service within the container using a port-forward trick buildin to Kubernetes

kubectl port-forward web-6fb86c6f99-nx5fd 9090:9090

Open your browser and access localhost:9090/ui to access the web service. All services should be visible and report healthy.

install consul with helm

helm repo add hashicorp https://helm.releases.hashicorp.com/
helm install consul hashicorp/consul -f helm/config.yaml

You can now port-forward, like with web

kubectl port-forward consul-server-0 8501:8501

Consul is now locally accessible

Get the secret generated by Consul's bootstrap process to access the UI

kubectl get secret consul-bootstrap-acl-token --template={{.data.token}} | base64 -d

inject consul connect sidecart in applications

Show diff to the potential audience! ;-)

kubectl apply -f k8s/add-connect.yaml

reconfigure applications to only listen on localhost

Show diff to the potential audience! ;-)

kubectl apply -f k8s/local-listen.yaml

setup service mesh connection

Show diff to the potential audience! ;-)

kubectl apply -f k8s/configure-connect.yaml

acls

Use the consul console to add an acl for web -> app

do same thing for DB

Start consul services

Reconfigure app service

rate service in FRA1

setup federation

mesh the rate service

connect app to rate

cleanup

resources

I used the consul on Kubernetes workshop by Luke Kysow as a convinient starting point