istio1.0安裝教程,快速入門

來源:互聯網
上載者:User
廣告 | kubernetes各版本離線安裝包

祝賀istio1.0發布, 在此獻上教程一份

安裝

安裝k8s 強勢插播廣告

三步安裝,不多說

安裝helm, 推薦生產環境用helm安裝,可以調參

release地址

如我使用的2.9.1版本

yum install -y socat # 這個不裝會報錯
[root@istiohost ~]# wget https://storage.googleapis.com/kubernetes-helm/helm-v2.9.1-linux-amd64.tar.gz[root@istiohost ~]# tar zxvf helm-v2.9.1-linux-amd64.tar.gz[root@istiohost ~]# cp linux-amd64/helm /usr/bin

先建立一個service account 把管理員權限給helm:

[root@istiohost ~]# cat helmserviceaccount.yamlapiVersion: v1kind: ServiceAccountmetadata:  name: tiller  namespace: kube-system---kind: ClusterRoleBindingapiVersion: rbac.authorization.k8s.io/v1beta1metadata:  name: tiller-clusterrolebindingsubjects:- kind: ServiceAccount  name: tiller  namespace: kube-systemroleRef:  kind: ClusterRole  name: cluster-admin  apiGroup: ""
kubectl create -f  helmserviceaccount.yaml

安裝helm 服務端 tiller :

helm init  --service-account tiller #  如果已安裝更新加 --upgrade 參數helm list #沒任何返回表示成功
安裝istio
curl -L https://git.io/getLatestIstio | sh -cd istio-1.0.0/export PATH=$PWD/bin:$PATH

helm 2.10.0以前的版本需要裝一下CRD:

kubectl apply -f install/kubernetes/helm/istio/templates/crds.yamlkubectl apply -f install/kubernetes/helm/istio/charts/certmanager/templates/crds.yaml

安裝istio, 由於你沒有LB所以用NodePort代替:

helm install install/kubernetes/helm/istio  --name istio --namespace istio-system --set gateways.istio-ingressgateway.type=NodePort --set gateways.istio-egressgateway.type=NodePort

安裝成功:

[root@istiohost istio-1.0.0]# kubectl get pod -n istio-systemNAME                                        READY     STATUS    RESTARTS   AGEistio-citadel-7d8f9748c5-ntqnp              1/1       Running   0          5mistio-egressgateway-676c8546c5-2w4cq        1/1       Running   0          5mistio-galley-5669f7c9b-mkxjg                1/1       Running   0          5mistio-ingressgateway-5475685bbb-96mbr       1/1       Running   0          5mistio-pilot-5795d6d695-gr4h4                2/2       Running   0          5mistio-policy-7f945bf487-gkpxr               2/2       Running   0          5mistio-sidecar-injector-d96cd9459-674pk      1/1       Running   0          5mistio-statsd-prom-bridge-549d687fd9-6cbzs   1/1       Running   0          5mistio-telemetry-6c587bdbc4-jndjn            2/2       Running   0          5mprometheus-6ffc56584f-98mr9                 1/1       Running   0          5m[root@istiohost istio-1.0.0]# kubectl get svc -n istio-systemNAME                       TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)                                                                                                     AGEistio-citadel              ClusterIP   10.108.253.89    <none>        8060/TCP,9093/TCP                                                                                           5mistio-egressgateway        NodePort    10.96.151.14     <none>        80:30830/TCP,443:30038/TCP                                                                                  5mistio-galley               ClusterIP   10.102.83.130    <none>        443/TCP,9093/TCP                                                                                            5mistio-ingressgateway       NodePort    10.99.194.13     <none>        80:31380/TCP,443:31390/TCP,31400:31400/TCP,15011:31577/TCP,8060:30037/TCP,15030:31855/TCP,15031:30775/TCP   5mistio-pilot                ClusterIP   10.101.4.143     <none>        15010/TCP,15011/TCP,8080/TCP,9093/TCP                                                                       5mistio-policy               ClusterIP   10.106.221.68    <none>        9091/TCP,15004/TCP,9093/TCP                                                                                 5mistio-sidecar-injector     ClusterIP   10.100.5.170     <none>        443/TCP                                                                                                     5mistio-statsd-prom-bridge   ClusterIP   10.107.28.242    <none>        9102/TCP,9125/UDP                                                                                           5mistio-telemetry            ClusterIP   10.105.66.20     <none>        9091/TCP,15004/TCP,9093/TCP,42422/TCP                                                                       5mprometheus                 ClusterIP   10.103.128.152   <none>        9090/TCP

使用教程

官網案例 Bookinfo Application

  • productpage 調用details和reviews渲染頁面
  • details包含書本資訊
  • reviews 書本反饋,調用ratings服務
  • ratings 書本租借資訊

reviews服務有三個版本:

  • V1 不請求ratings
  • V2 請求ratings,返回1到5個黑星
  • V3 請求ratings,返回1到5個紅星

資料平面:

安裝應用:

kubectl apply -f <(istioctl kube-inject -f samples/bookinfo/platform/kube/bookinfo.yaml)

安裝完成:

[root@istiohost istio-1.0.0]# kubectl get servicesNAME          TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)    AGEdetails       ClusterIP   10.104.66.31    <none>        9080/TCP   2mkubernetes    ClusterIP   10.96.0.1       <none>        443/TCP    4hproductpage   ClusterIP   10.109.68.13    <none>        9080/TCP   2mratings       ClusterIP   10.99.55.110    <none>        9080/TCP   2mreviews       ClusterIP   10.102.19.129   <none>        9080/TCP   2m[root@istiohost istio-1.0.0]# kubectl get podsNAME                              READY     STATUS    RESTARTS   AGEdetails-v1-fc9649d9c-dpnlp        2/2       Running   0          2mproductpage-v1-58845c779c-7g8th   2/2       Running   0          2mratings-v1-6cc485c997-fb7nh       2/2       Running   0          2mreviews-v1-76987687b7-x5n7z       2/2       Running   0          2mreviews-v2-86749dcd5-xchzb        2/2       Running   0          2mreviews-v3-7f4746b959-nthrq       2/2       Running   0          2m

建立一個gateway,這是為了叢集外可以訪問

kubectl apply -f samples/bookinfo/networking/bookinfo-gateway.yaml

瀏覽器訪問url:
47.254.28.88是我的節點ip,使用nodeport模式

http://47.254.28.88:31380/productpage 

連續點擊三次,你會發現右邊沒星星-> 黑星星-> 紅星星切換,對應三個版本的review,預設策略是輪詢

建立destination rules, 配置路由訪問規則,現在還是輪詢

kubectl apply -f samples/bookinfo/networking/destination-rule-all.yaml

智能路由

請求路由 request routing

根據版本路由

把所有路由切換到v1版本

kubectl apply -f samples/bookinfo/networking/virtual-service-all-v1.yaml

這樣執行完後,不管怎麼刷頁面,我們都看不到星星,因為v1版本沒星

可以看到destination是這樣的:

  http:  - route:    - destination:        host: details        subset: v1

試想如此我們做版本切換將是何等簡單

根據使用者路由

kubectl apply -f samples/bookinfo/networking/virtual-service-reviews-test-v2.yaml

你會發現用jason使用者登入就能看到黑星星,而其它方式看到的頁面都是無星星

因為這個user走了v2版本,能不強大? 那當然還能根據header什麼的做路由了,就不多說了

  http:  - match:    - headers:        end-user:          exact: jason    route:    - destination:        host: reviews        subset: v2  - route:    - destination:        host: reviews        subset: v1

故障注入 Fault injection

kubectl apply -f samples/bookinfo/networking/virtual-service-all-v1.yamlkubectl apply -f samples/bookinfo/networking/virtual-service-reviews-test-v2.yaml

假設代碼裡有個bug,使用者jason, reviews:v2 訪問ratings時會卡10s, 我們任然希望端到端的測試能正常走完

kubectl apply -f samples/bookinfo/networking/virtual-service-ratings-test-delay.yaml

注入錯誤讓jason使用者有個7s的延遲

  hosts:  - ratings  http:  - fault:      delay:        fixedDelay: 7s        percent: 100    match:    - headers:        end-user:          exact: jason    route:    - destination:        host: ratings        subset: v1  - route:    - destination:        host: ratings        subset: v1

這時訪問頁面顯然會出錯,因為我們希望7s內能返回,這樣我們就發現了一個延遲的bug

Error fetching product reviews!Sorry, product reviews are currently unavailable for this book.

所以我們就可能通過故障注入去發現這些異常現象

鏈路切換 Traffic Shifting

我們先把50%流量發送給reviews:v1 50%流量發送給v3,然後再把100%的流量都切給v3

把100%流量切到v1

kubectl apply -f samples/bookinfo/networking/virtual-service-all-v1.yaml

此時不論刷幾遍,都沒有星星

v1 v3各50%流量

kubectl apply -f samples/bookinfo/networking/virtual-service-reviews-50-v3.yaml
  - route:    - destination:        host: reviews        subset: v1      weight: 50    - destination:        host: reviews        subset: v3      weight: 50

此時一會有星,一會沒星,但是已經不是輪詢演算法了

全切v3

kubectl apply -f samples/bookinfo/networking/virtual-service-reviews-v3.yaml

這時不管怎麼刷都是紅心了

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.