Serverless之Knative部署应用实例;
生活随笔
收集整理的這篇文章主要介紹了
Serverless之Knative部署应用实例;
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
🚀 優質資源分享 🚀
| 🧡 Python實戰微信訂餐小程序 🧡 | 進階級 | 本課程是python flask+微信小程序的完美結合,從項目搭建到騰訊云部署上線,打造一個全棧訂餐系統。 |
| 💛Python量化交易實戰💛 | 入門級 | 手把手帶你打造一個易擴展、更安全、效率更高的量化交易系統 |
- 1.什么是Knative?
- 2. 什么是Serving?
- 2.1 Serving服務
- 2.2 Serving組件;
- 3. 部署一個應用;
- 3.1 安裝Knative的CLI
- 3.2 部署一個簡單的應用
1.什么是Knative?
應用部署應該是全部部署或者全部不部署嗎?knative支持漸進式交付,并不是所有的HTTP請求都會到達生產環境系統中的一個軟件版本上,而是所有的HTTP請求都會到達整個分布式系統上,由該軟件的多個版本共同響應,在系統中可以同時運行多個版本,并在這些版本之間分配流量,這意味著部署可以按請求而不是實例的粒度進行;
系統中的流量是不固定的,有時沒有流量,有時候流量過大,當沒有流量時,系統的部分資源是浪費的,當流量過大時,系統就會承受過大的壓力。Knative使用Knative Pod自動縮放器(KPA)進行擴/縮容,它是一種基于請求指標的自動縮放器,已與Knative的路由、緩沖和指標組件深度集成。自動縮放器無法解決所有問題,但是可以解決大部分流量的問題。
2. 什么是Serving?
2.1 Serving服務
APP->Deployment->Service->ConfigMap->Secrets甚至我們還需要定義一個Ingress;但是在Knative當中,一個Service就可以搞定。這里的Service不是kubernetes的Service,而是Knative中的service,可以簡寫為kvc,在資源規范里可以看見;
2.2 Serving組件;
3. 部署一個應用;
3.1 安裝Knative的CLI
3.2 部署一個簡單的應用
在這里你必須有一個kubernetes集群并且安裝了Knative;安裝部署文檔在我上篇博客有說明;
3.2.1 使用kn創建服務;
3.2.2觀察knative到底做了什么?
1.首先它給我們創建了一個deployment,我們可以看到此時的Pod Ready是處于0的,這是Knative獨有的冷啟動,在后續會說明;
[root@knative-k8s-master-139 ~]# kubectl get deploy NAME READY UP-TO-DATE AVAILABLE AGE helloworld-example-00001-deployment 0/0 0 0 12h tools-test 1/1 1 1 12h2.為我們創建了一個Service,所有的SVC都是要注冊到isto-ingressgateway上面的。它提供了一個外部訪問入口和一個集群內部的訪問入口;
[root@knative-k8s-master-139 ~]# kubectl get svc helloworld-example ExternalName knative-local-gateway.istio-system.svc.cluster.local 80/TCP3.我們為什么看不見創建的Pod呢?因為在沒有人訪問的情況下,Pod是無法啟動會被置為0的狀態;這就是Knative的KPA,Pod縮放至0;
[root@knative-k8s-master-139 ~]# kubectl get pods NAME READY STATUS RESTARTS AGE tools-test-8444596cb5-rvpf9 1/1 Running 0 12h3.2.3 應用測試訪問;
1.我們啟動一個終端訪問這個Service是沒有問題的;
[root@tools-test-8444596cb5-rvpf9 /]# curl helloworld-example.default.svc Hello World! [root@tools-test-8444596cb5-rvpf9 /]# while true; do curl --connect-timeout 1 helloworld-example.default; sleep .2; done Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World!2.我們觀察Pod的狀態與deploy的狀態,當我們持續訪問的時候,Pod是會被拉起的;
[root@knative-k8s-master-139 ~]# kubectl get deploy NAME READY UP-TO-DATE AVAILABLE AGE helloworld-example-00001-deployment 1/1 1 1 12h tools-test 1/1 1 1 12h[root@knative-k8s-master-139 ~]# kubectl get pods helloworld-example-00001-deployment-7787f5cf4f-rfwhb 2/2 Running 0 12s tools-test-8444596cb5-rvpf9 1/1 Running 0 12h總結
以上是生活随笔為你收集整理的Serverless之Knative部署应用实例;的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 转:海外购之Amazon亚马逊购物手把手
- 下一篇: Knative部署应用以及应用的更新、应