- Published on
Istio setup
- Authors
- Name
- Marcelo Carmona
- @carmonamarcelo
data:image/s3,"s3://crabby-images/aa857/aa8573707d2c5661526eb94a5c1fc3500e0596d3" alt="istio and kubernetes logo"
Istio is an open source service mesh that layers transparently onto existing distributed applications. Istio's powerful features provide a uniform and more efficient way to secure, connect, and monitor services. https://istio.io
Install Istio (mac os x)
check kubernetes namespaces kubectl get ns
data:image/s3,"s3://crabby-images/5c263/5c263269c04f571c84a5e7cbd8ba325f027e5ab2" alt="check kubernetes namespaces"
Install istioctl
brew install istioctl
istioctl install
data:image/s3,"s3://crabby-images/623eb/623eb4398eb4c92a08a9dd1fe78ee1e45dba0c5d" alt="istioctl install"
With kubectl get ns
you are going to see the new namespace created by istioctl
data:image/s3,"s3://crabby-images/dd7b9/dd7b97d6d8b72c50c5b561a9212ca71903d10702" alt="check kubernetes namespaces after install istioctl"
With kubectl get pod -n istio-system
you are going to see the new pods created by istio
data:image/s3,"s3://crabby-images/7cb84/7cb844643013877d91c49f0d11a95e4650b26725" alt="check kubernetes namespaces after install istioctl"
data:image/s3,"s3://crabby-images/3108b/3108b1f8c8fcef1cda1b0b98e92146ff43dbd429" alt="istio mesh diagram"
Istio is a very feature-rich service mesh that includes the following capabilities.
- Traffic Management: This is the most basic feature of Istio.
- Policy Control: Enables access control systems, telemetry capture, quota management, billing, etc.
- Observability: Implemented in the sidecar proxy.
- Security Authentication: The Citadel component does key and certificate management.
Run an example in Kubernetes
I'm going to use this example microservices-demo
git clone https://github.com/GoogleCloudPlatform/microservices-demo.git
# or download https://github.com/GoogleCloudPlatform/microservices-demo/blob/master/release/kubernetes-manifests.yaml
cd microservices-demo/release
Run the demo manifest kubectl apply -f kubernetes-manifests.yaml
data:image/s3,"s3://crabby-images/f83f8/f83f86e9a09977f320f8107b0647996f10b4c0ea" alt="run the demo manifest"
Run kubectl get pod
and wait until the status is running
data:image/s3,"s3://crabby-images/b5995/b5995533c3fdb8bb48a37d7124752e5c0703d1dc" alt="wait until the status is running"
data:image/s3,"s3://crabby-images/f6c4f/f6c4f07560f2b60f55ceb8691e5656ed928d209f" alt="the demo is running"
To configure the Envoy proxy injection we need to label the default namespace with istio-injection=enabled
Let see the current labels with kubectl get ns default --show-labels
data:image/s3,"s3://crabby-images/ab7fd/ab7fde9b44e0a6ce358404da06b667e346a8e14c" alt="show kubernetes labels"
Run kubectl label namespace default istio-injection=enabled
data:image/s3,"s3://crabby-images/046a9/046a9385951028d0f788bd9a34164763ad309575" alt="show kubernetes labels with istio-injection=enabled"
So now we can shut down all the pods and re-create them to see the proxies been injected
Run kubectl delete -f kubernetes-manifests.yaml
data:image/s3,"s3://crabby-images/77aac/77aac052d9b38dbc2a36d563e50ad60331e220eb" alt="delete pods"
Run kubectl get pod
data:image/s3,"s3://crabby-images/8b3b0/8b3b0382c2c50d847556de5800c5600a366d8172" alt="check that we don't have pods"
Run kubectl apply -f kubernetes-manifests.yaml
Run kubectl get pod
data:image/s3,"s3://crabby-images/f1d2f/f1d2f09fd9dac126ec3f6d452c9619f89448abf1" alt="check the news pods"
You can see now the proxy inside of any pod with kubectl describe pod <a-pod-name>
data:image/s3,"s3://crabby-images/21303/21303a801444da7d6a8525d2bf1bc92bbbcb20c3" alt="see the istio container inside the pod"
Install Istio integrations for visualization and monitoring (kiali grafana promeheus and jeager)
We are going to use this addons
git clone https://github.com/istio/istio.git
cd istio
# To quickly deploy all addons:
kubectl apply -f samples/addons
data:image/s3,"s3://crabby-images/51cb7/51cb79f095f72f4e81ac525ad06177bda389aa4c" alt="install istio integrations"
You can see the new pods running with kubectl get pod -n istio-system
data:image/s3,"s3://crabby-images/9a3c8/9a3c8cf5a61fa39d76bb477b16e33b3733b7dfc8" alt="show addons"
To see the services run kubectl get svc -n istio-system
data:image/s3,"s3://crabby-images/d4693/d4693c166850e0741849756db1bdaa31a70794dc" alt="show services"
port-foward to access to the frontend and kiali
Run kubectl port-forward svc/kiali -n istio-system 8081:80
data:image/s3,"s3://crabby-images/a4863/a4863914a07dcb9c715e06c878df12803c643056" alt="port foward frontend"
Run kubectl port-forward svc/kiali -n istio-system 20001
data:image/s3,"s3://crabby-images/d502b/d502b14b161c670b274a0b3ee4591302d7a13e7a" alt="port foward kiali"
Go to http://localhost:20001/ and you will see the Kiali dashboard
data:image/s3,"s3://crabby-images/4a763/4a7631bc9b8d70120aa3e9e23189324dd75037c8" alt="kiali screen shot"