日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Serverless之Knative部署应用实例;

發布時間:2023/12/20 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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是Google2018的Google Cloud Next大會上發布的一款基于kubernetes的Serverless框架。
  • knative的目的是在kubernetes之上提供一個簡單、一致的層,以解決在開發人員和平臺之間創建更牢固的邊界,使得開發人員可以專注他們的業務邏輯。knative是建立在kubernetes和Istio平臺之上的,使用了kubernetes提供的容器管理組件(deployment、service、Pod、ConfigMap等)以及Istio提供的網絡管理組件(Ingress、LB);
  • Knative中有兩個重要的組件,分別是為其提供流量的Serving(服務)組件以及確保應用程序能夠輕松消費事件的Eventing組件;
  • 部署、升級和路由。
    應用部署應該是全部部署或者全部不部署嗎?knative支持漸進式交付,并不是所有的HTTP請求都會到達生產環境系統中的一個軟件版本上,而是所有的HTTP請求都會到達整個分布式系統上,由該軟件的多個版本共同響應,在系統中可以同時運行多個版本,并在這些版本之間分配流量,這意味著部署可以按請求而不是實例的粒度進行;
  • 自動擴/縮容
    系統中的流量是不固定的,有時沒有流量,有時候流量過大,當沒有流量時,系統的部分資源是浪費的,當流量過大時,系統就會承受過大的壓力。Knative使用Knative Pod自動縮放器(KPA)進行擴/縮容,它是一種基于請求指標的自動縮放器,已與Knative的路由、緩沖和指標組件深度集成。自動縮放器無法解決所有問題,但是可以解決大部分流量的問題。
  • 2. 什么是Serving?

    2.1 Serving服務

  • Serving模塊提供了一組特定的對象,包括Service(服務)、Configuration(配置)、Revision(修訂版本)、Route(路由)。Knative通過kubernetes CRD(自定義資源)的方式實現了這些對象。
  • 在kubernetes創建一個應用的時候需要定義什么?
    APP->Deployment->Service->ConfigMap->Secrets甚至我們還需要定義一個Ingress;但是在Knative當中,一個Service就可以搞定。這里的Service不是kubernetes的Service,而是Knative中的service,可以簡寫為kvc,在資源規范里可以看見;
  • [root@knative-k8s-master-139 ~]# kubectl api-resources | grep "knative" services kservice,ksvc serving.knative.dev/v1 true Service
  • 創建一個Service(kservice)的時候會自動生成一個Configuration,基于Configuration創建Revision,再創建Route,客戶端請求的流量也是由Route發給Revision;
  • 2.2 Serving組件;

  • Configuration: 配置是待運行軟件的期望狀態,包含所需的容器鏡像、環境變量等詳細信息。Knative將此信息轉換為底層的Kubernetes概念,例如部署。實際上,那些熟悉kubernetes的人可能知道Knative到底在做什么。即使沒有Knative,開發人員也可以自己創建和提交一個部署;
  • Revision: 修訂版本是配置的快照,每次更改配置時,Knative都會創建一個修訂版本,實際上修訂版本還會轉換為底層Kubernetes資源。如果單純只是保存修訂版本,則有些浪費資源,畢竟Git就可以進行版本控制,為什么用Knative?因為Knative并不只是支持藍/綠部署,實際上,Knative還支持多版本之間更詳細的流量配置規則;
  • Route: Knative中的Route提供了一種將流量路由到正在運行代碼的機制,它將一個HTTP可尋端點映射到一個或者多個Revision。可以做流量的切割和金絲雀發布;
  • 3. 部署一個應用;

    3.1 安裝Knative的CLI

  • 這里已經確保安裝了kn,kn是Knative的"官方"客戶端,但它不是官方的第一個客戶端。在kn出現之前,Knative已經有了很多可選的客戶端,比如knctl。這些工具有助于探索Knative客戶端的不同使用體驗;
  • kn有兩個作用。(1)客戶端本身是專門給Knative設計的,你不需要詳細了解kubectl;kn淘汰了Knative的Golang API,讓knative的Golang API盡在其他使用Go語言編寫的和Knative交互的工具使用;
  • Knative CLI官方文檔:https://knative.dev/docs/client/
  • 我的上一篇博文有部署文檔Knative Serving安裝
  • 3.2 部署一個簡單的應用

    在這里你必須有一個kubernetes集群并且安裝了Knative;安裝部署文檔在我上篇博客有說明;

    3.2.1 使用kn創建服務;

  • 部署hello world實例;
  • # 可以使用--help來查看如何部署; [root@knative-k8s-master-139 ~]# kn service --help [root@knative-k8s-master-139 ~]# kn service create --help# [root@knative-k8s-master-139 ~]# kn service create helloworld-example \ # name就叫做hello-example; --image gcr.io/knative-samples/helloworld-go \ # 引用的容器鏡像,使用knative提供的簡單應用; --env TRAGET="First" # 注入示例應用需要的環境變量; Creating service 'helloworld-example' in namespace 'default': # 未指定namespace,在默認的default名稱空間下;0.042s The Route is still working to reflect the latest desired specification.0.050s ...0.090s Configuration "helloworld-example" is waiting for a Revision to become ready. 575.648s ... 575.679s Ingress has not yet been reconciled. 575.748s Waiting for load balancer to be ready 575.951s Ready to serve.Service 'helloworld-example' created to latest revision 'helloworld-example-00001' is available at URL: http://helloworld-example.default.example.com
  • 通過kn service list來查看;
  • [root@knative-k8s-master-139 ~]# kn service list NAME URL LATEST AGE CONDITIONS READY REASONhelloworld-example http://helloworld-example.default.example.com helloworld-example-00001 12h 3 OK / 3 True

    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 12h

    2.為我們創建了一個Service,所有的SVC都是要注冊到isto-ingressgateway上面的。它提供了一個外部訪問入口和一個集群內部的訪問入口;

    [root@knative-k8s-master-139 ~]# kubectl get svc helloworld-example ExternalName knative-local-gateway.istio-system.svc.cluster.local 80/TCP

    3.我們為什么看不見創建的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 12h

    3.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部署应用实例;的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。