色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

搞一個grpc動態代理的想法,并初步實現

jf_wN0SrCdH ? 來源:Rust語言中文社區 ? 2023-02-08 16:13 ? 次閱讀

前言

?溝通服務間接口內容(尤其是前后端接口),是非常讓人頭疼的事。極其容易扯皮。接口文檔寫起來也很痛苦,每個字段的改動都需要及時更新,否則就會出問題。服務端通信如果用rpc通信的話,一般會有proto或者thrift文件。這個文件很長時間里被我們當成接口文檔用,用著用著發現,真tm好用。既減少了扯皮,還不用寫接口文檔。那可不可以用grpc和前端通信那,一開始我們的做法是用grpc-gateway。把grpc的接口映射成http接口。但這種方式需要編譯gateway的pb文件,對服務也是有侵入的。后來隨著我在公司的時間越來越長,接手的服務越來越多(經常需要發版的項目就有十幾個),這種方式維護起來十分糟心,后一直想尋求一種一勞永逸的解決方法? ?本人之前很長一段時間從事saas,paas的開發。對于一些服務而言,既要提供grpc訪問的能力,也要對外提供http訪問的能力(做saas就是這么卑微)。并且這種需求通常不是一開始就提出來的,而是對一個已經穩定運行的龐大的服務做改造。而這會導致爬屎山,鑒權不一致等一系列問題。那有沒有一種無侵入的協議轉換能力? ? grpc是基于http2協議,而http2是長連接。這對k8s部署的服務非常不友好。在這我猜肯定有很多小伙伴說可以用linked,istio等基于Service Mesh的解決方案。一是這些技術是近兩年才穩定下來的,以前問題很多,根本不敢用,當然現在istio已經流行起來了,可以很完美的做到grpc的負載均衡和很優秀的流量管理。但依然存在不滿足實際需求的情況,比如對grpc流量做精細過濾,細到每個請求的精準控制。這種二次開發的需求是很難在istio上完成。尤其是對一些小公司而言。基于很多原因的考慮,最終誕生了搞一個grpc動態代理的想法,并初步實現。

grpc

? 在云原生,容器化,微服務的大背景下。rpc也徹底奠定了服務間通信協議的霸主地位。眾多rpc框架中grpc和thrift是最流行最受歡迎的rpc框架。在實際開發中,我兩個框架都有深入的使用過。相較而言,我更喜歡grpc的風格。背靠google大樹(已經是CNCF孵化項目),多語言都支持,基于protobuf極致編碼和急速傳輸,等等優點就不一一詳述。有興趣的可以看grpc官網,上面吹的比我吹的好。

實踐

github地址

https://github.com/woshihaoren4/grpc-proxy

第一步

先將代碼clone下來到本地,我這里用的mac系統 因為編譯需要cargo環境,需要先安裝rust,參考教程:https://www.rust-lang.org/zh-CN/上面有很詳細的中文教程。我安裝的是:rustc 1.66.0 (69f9c33d7 2022-12-12)版本

第二步

先進入項目根目錄,運行起測試例子

	
		./example/helloworld server 沒有權限的話,需要先加權限,然后再運行 chmod +x ./example/helloworld
		這個例子使用golang編寫的簡單的grpc服務,實現上沒有啥特殊的部分,值得注意的是需要給grpc服務加上反射

	//grpc的HelloWorld方法實現,就是在字符串上加一個 world func (s *Service) HelloWorld(ctx context.Context, req *proto.HelloWorldRequest) (*proto.HelloWorldResponse, error) { return &proto.HelloWorldResponse{Response: req.Request + " world"}, nil } //這里相當于main函數 func server(ctx *wdevent.Context) error { ls, _ := net.Listen("tcp", ":8888") gs := grpc.NewServer() proto.RegisterHelloWorldServiceServer(gs, new(Service)) reflection.Register(gs) logrus.Infoln("grpc server start workd ....") gs.Serve(ls) return nil }
		再看一下pb文件,需要注意的是在option里指明 需要映射的http的路徑和方法

	
		syntax = "proto3"; package proto; option go_package = "./proto"; import "google/api/annotations.proto"; // HelloWorld Service service HelloWorldService { rpc HelloWorld(HelloWorldRequest) returns (HelloWorldResponse){ option (google.api.http) = { post: "/api/v2/hello" body: "*" }; }; } message HelloWorldRequest { string request = 1; } message HelloWorldResponse { string response = 1; }

第三步

修改配置文件如下,路徑:./src/config/config.toml。當前項目中的配置文件已經寫好了這些內容,不需要再配置什么了。當然不放心也可以查看一下。

	[[proxy_sink]] name = "hello" addr = "127.0.0.1:8888"
  • 需要在addr中指明上面服務的地址和端口

第四步

另起終端,編譯并運行項目

	
		cargo run -- run
		國內沒有科學上網的話會有些慢,主要是下載包比較慢,可以用清華源或者其他的,教程參考:https://www.w3cschool.cn/cargo_guide/cargo_guide-uxdg3l62.html 服務啟動后會打印如下日志,說明服務啟動成功f79e9010-a787-11ed-bfe3-dac502259ad0.png

測試

發起一個http請求

	
		curl --location --request POST 'http://127.0.0.1:6789/api/v2/hello'  --header 'Content-Type: application/json' --data-raw '{ "request": "hello" }'
		可以看到返回內容:{"response": "hello world"}并且在代理服務上產生訪問日志:f7b5da68-a787-11ed-bfe3-dac502259ad0.png?到這里一個簡單的演示就成功了

結構和原理

主要是根據grpc的反射的描述,生成http路由,并動態完成json和proto的映射。更進一步的原理和結構,未完待續~

尾語

當前版本還只是一個比較初級的版本,功能還很初級。還有很多功能需要完善,架構也可能會有大的變動,所有上一節并沒有詳細描述。作者預計但不承諾會繼續完成下面的內容。
  • restful支持:這個功能是P0級,在我go版本的grpc動態代理服務中經常被用到,在可預計的規劃里一定會實現。
  • 事件系統:該功能是為了方便二次開發,很有必要。也有可能用中間件模式,類似traefik
  • 負載均衡/sidecar:負載均衡是為了用在服務網關上,sidecar是用在pod里,二者會選一個實現,我傾向于前者,和我之前寫的rust-ingress聯動上。這里自薦一波rust-ingress項目:https://gitee.com/yutiandou/rust-ingress
  • 性能優化,這個會一直持續做下去,歡迎有性能極致追求的小伙伴能夠共同前進
  • 實時反射:目前是通過配置文件,在啟動的時候加載服務源。好的(懶人)方案是proto文件變化后能夠實時監控到,下一步會完成這個功能。
歡迎有興趣的小伙伴提出建議,并熱烈歡迎大家參與進來。

審核編輯 :李倩


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 通信協議
    +關注

    關注

    28

    文章

    879

    瀏覽量

    40299
  • HTTP
    +關注

    關注

    0

    文章

    504

    瀏覽量

    31197
  • 編碼
    +關注

    關注

    6

    文章

    940

    瀏覽量

    54814

原文標題:尾語

文章出處:【微信號:Rust語言中文社區,微信公眾號:Rust語言中文社區】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    GRPC的基礎使用方法

    語言的 gRPC 客戶端和服務器實現,它提供了簡單易用的 API,可以方便地創建和使用 gRPC 服務。 基礎用法 創建
    的頭像 發表于 09-19 16:08 ?941次閱讀

    JDK動態代理的原理

    在Java中,動態代理種機制,允許在運行時動態地創建代理對象來代替某個實際對象,從而在其前后執行額外的邏輯。 為什么JDK
    的頭像 發表于 09-30 10:51 ?578次閱讀

    特斯拉馬斯克稱在城市里飛行汽車是愚蠢的想法

    馬斯克稱在城市里飛行汽車是愚蠢的想法。同時,他還提到了自己的地下隧道計劃,馬斯克認為這項計劃雖然也非常瘋狂,但比飛行汽車好多了。
    發表于 02-18 11:24 ?1118次閱讀

    java的動態代理機制和作用

    的我們的功能,我們更需要學習的是其底層是怎么樣的原理,而AOP的原理就是java的動態代理機制,所以本篇隨筆就是對java的動態機制進行
    發表于 09-27 14:37 ?0次下載

    java動態代理分析

    定義:為其他對象提供代理以控制對這個對象的訪問。 動態代理使用 java動態代理機制以巧妙的
    發表于 09-27 15:14 ?0次下載

    java動態代理機制詳解的類和接口描述

    的我們的功能,我們更需要學習的是其底層是怎么樣的原理,而AOP的原理就是java的動態代理機制,所以本篇隨筆就是對java的動態機制進行
    發表于 09-28 13:33 ?0次下載

    java的動態代理

    代理類的對象與委托類的對象關聯,代理類的對象本身并不真正實現服務,而是通過調用委托類的對象的相關方法,來提供特定的服務。 按照
    發表于 03-12 14:12 ?0次下載

    基于JDK和CGLB分別實現動態代理

    本文檔內容介紹了基于JDK和CGLB分別實現動態代理及源代碼
    發表于 03-12 14:56 ?0次下載

    什么是動態ip代理電腦軟件?

    動態IP代理計算機軟件是計算機瀏覽器和Web群集服務器之間的網絡服務器。如果使用動態IP代理計算機軟件訪問Internet,則計算機瀏覽器不會立即轉到Web網絡服務器來檢索網頁,而是僅
    發表于 01-14 18:06 ?975次閱讀
    什么是<b class='flag-5'>動態</b>ip<b class='flag-5'>代理</b>電腦軟件?

    IP知識百科之什么是gRPC

    對網絡設備進行配置和管理的種方法。 gRPC vs REST REST(Representational State Transfer)表征狀態轉移,是種軟件架構風格,同樣為管理和配置網絡設備提供
    的頭像 發表于 11-16 15:13 ?3254次閱讀

    gRPC-Web訪問gRPC服務的Web客戶端

    ./oschina_soft/grpc-web.zip
    發表于 06-22 09:25 ?0次下載
    <b class='flag-5'>gRPC</b>-Web訪問<b class='flag-5'>gRPC</b>服務的Web客戶端

    正確使用gRPC與GraphQL

    TLDR:使用 GraphQL 進行客戶端-服務器通信,使用 gRPC 進行服務器到服務器通信。有關此規則的例外情況,請參閱“判定”部分。 我已經閱讀了很多關于這兩種協議的比較,想寫
    的頭像 發表于 12-08 15:47 ?1096次閱讀

    Golang實現簡單的http代理

    本文詳細介紹了Golang 實現 http 代理實現,在實際業務中有需求的同學可以學起來了!
    的頭像 發表于 04-10 11:29 ?1444次閱讀

    mybatis接口動態代理原理

    MyBatis是款輕量級的Java持久化框架,它通過XML或注解配置的方式,將數據庫操作與SQL語句解耦,提供了種簡單、靈活的數據訪問方式。在MyBatis中,使用動態代理技術來
    的頭像 發表于 12-03 11:52 ?937次閱讀

    使用go語言實現grpc攔截器

    在開發grpc服務時,我們經常會遇到些通用的需求,比如:日志、鏈路追蹤、鑒權等。這些需求可以通過grpc攔截器來實現。本文使用go語言來實現
    的頭像 發表于 12-18 10:13 ?656次閱讀
    使用go語言<b class='flag-5'>實現</b><b class='flag-5'>一</b><b class='flag-5'>個</b><b class='flag-5'>grpc</b>攔截器
    主站蜘蛛池模板: 欧美性喷潮xxxx| 久久国产精品无码视欧美| 国产偷抇久久精品A片蜜臀A| 捏揉舔水插按摩师| 一区二区中文字幕在线观看 | caoporn 超碰免费视频| 交换邻居波多野结衣中文字幕 | 性夜夜春夜夜爽AA片A| 高清mv视频免费观看| 日本片bbbxxx| 岛国片在线看| 日韩吃奶摸下AA片免费观看| 办公室日本肉丝OL在线| 日本精品久久久久中文字幕| 草莓视频在线观看完整高清免费 | 99精品免费久久久久久久久日本| 久久综合色超碰人人| 在线播放一区| 两个客户一起吃我的奶| 97人人爽人人爽人人人片AV| 内射少妇36P亚洲区| www免费看.男人的天堂| 日韩免费一区| 国产精品视频免费视频| 亚洲精品久久7777777| 久久囯产精品777蜜桃传媒| 中文字幕爆乳JULIA女教师| 美女叉腿掰阴大胆艺术照| acg全彩无遮挡口工漫画网址| 全免费午夜一级毛片| 国产成人精品久久一区二区三区| 午夜理伦片免费| 久久99国产精品一区二区| 最近的中文字幕2019国语| 青青草国拍2018| 国产不卡视频在线| 亚洲精品乱码久久久久久中文字幕 | 三叶草未满十八岁| 含羞草完整视频在线播放免费| 中文字幕无线手机在线| 青草国产在线视频免费|