curl -L https://istio.io/downloadIstio | sh –
data:image/s3,"s3://crabby-images/012ad/012ad425553424b7a999b13f4e0d3b5fe1be3f93" alt=""
After installing Istio into a cluster, you will see the control plane and the egress and ingress gateway. As soon as we install applications and inject the service proxies into them, we will have a data plane as well
data:image/s3,"s3://crabby-images/70e54/70e54a24008e156c1847c78deccedc9665a62d06" alt=""
taichengl-macbookpro:istio-1.24.0 taichengl$ kubectl apply -f ./samples/addons
data:image/s3,"s3://crabby-images/c1db7/c1db779ce2dc9c6d6146a94c3e682bfa1aaac20f" alt=""
data:image/s3,"s3://crabby-images/7196d/7196d1ab8e58dec907f99d0cbd01713109e451e0" alt=""
Istio uses Kubernetes custom resources when deployed on kubernetes . Istio implements a controller that watches for these new CRs to be added and reacts to them accordingly.
data:image/s3,"s3://crabby-images/85b63/85b635caf450868bef6446e1028907d48e19ac78" alt=""
$istioctl kube-inject -f services/catalog/kubernetes/catalog.yaml
When we run kube-inject, we add another container named istio-proxy to the pod template in the Depolyment object. To enable automatically inject the sidecar proxy, kubectl label namespace istioinaction istio-injection=enabled
data:image/s3,"s3://crabby-images/38cbc/38cbc7ccdd6a30ab67d4919cb21607594eccc0e2" alt=""
kubectl port-forward deploy/webapp 8080:8080
data:image/s3,"s3://crabby-images/07038/07038c90b19020c5eb275595e836472376fe25bf" alt=""
data:image/s3,"s3://crabby-images/52a78/52a788bdde4c1227d5a22cfcf38c79da5917eda9" alt=""
./istioctl dashboard grafana http://localhost:3000