日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Java Grpc實例創(chuàng)建負載均衡詳解

瀏覽:120日期:2022-09-04 09:59:31

Grpc是googe開發(fā)的,是一款語言中立、平臺中立、開源的遠程過程調用(RPC)系統。新公司的項目服務之間的調用使用的Grpc來實現服務間的調用,這邊一開始接到的工作內容是基于Nginx實現Grpc服務端的負載均衡。Nginx的1.13及以上版本是支持grpc的反向代理和負載均衡的。但是公司的nginx服務器的版本是1.10的,所以沒辦法直接使用grpc的代理。只能使用更底層的tcp層的負載均衡。最終服務跑起來是感覺挺簡單的,但是nginx的基礎太差,所以過程有點曲折。還是記錄下吧。

文章分兩部分,一個是創(chuàng)建簡單的Grpc客戶端和服務端的例子(其實也是用的網上的demo,這邊就貼一下源碼,講下更細的實現步驟),然后對比下Nginx的Grpc負載均衡和Tcp的負載均衡。

一、Java創(chuàng)建Grpc客戶端和服務端的例子(創(chuàng)建的配置信息相關的代碼基本網上博客的,忘記是哪篇文章了,所以暫時沒法給出轉載鏈接。)

1、在開發(fā)工具ide上創(chuàng)建一個maven project。打包方式選擇jar。

2、在POM.xml上增加grpc相關的依賴及maven的打包插件

<dependencies> <dependency> <groupId>io.grpc</groupId> <artifactId>grpc-netty</artifactId> <version>1.17.1</version> </dependency> <dependency> <groupId>io.grpc</groupId> <artifactId>grpc-protobuf</artifactId> <version>1.17.1</version> </dependency> <dependency> <groupId>io.grpc</groupId> <artifactId>grpc-stub</artifactId> <version>1.17.1</version> </dependency></dependencies><build> <extensions> <extension> <groupId>kr.motd.maven</groupId> <artifactId>os-maven-plugin</artifactId> <version>1.4.1.Final</version> </extension> </extensions> <plugins> <plugin> <groupId>org.xolstice.maven.plugins</groupId> <artifactId>protobuf-maven-plugin</artifactId> <version>0.5.0</version> <configuration><protocArtifact>com.google.protobuf:protoc:3.0.0:exe:${os.detected.classifier}</protocArtifact><pluginId>grpc-java</pluginId><pluginArtifact>io.grpc:protoc-gen-grpc-java:1.0.0:exe:${os.detected.classifier}</pluginArtifact> </configuration> <executions><execution> <goals> <goal>compile</goal> <goal>compile-custom</goal> </goals></execution> </executions> </plugin> <plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><version>2.3.2</version><configuration> <source>1.8</source> <target>1.8</target></configuration> </plugin> </plugins></build>

3、在項目下的路徑src/main下面創(chuàng)建proto文件夾,并在里面創(chuàng)建一個hello.proto文件。具體如下截圖。

Java Grpc實例創(chuàng)建負載均衡詳解

4、在hello.proto文件上輸入,相應的配置信息,用來映射生成java代碼。里面的內容就是生成一個MyRPC的服務提供一個sayHi的接口,接口需要傳遞一個request類的實例,該request實例只有一個name的字段。然后進行相應的業(yè)務代碼處理之后,返回一個response類的實例,也是只有一個name的字段。

如果進行到這邊,看到第2步添加依賴上面的<execution>標簽可能報錯,先暫時不要管他。直接進行第5步。

syntax = 'proto3';option java_package = 'com.qidai.proto';option java_outer_classname = 'MyThing';message Request { string name = 1;}message Response { string name = 2;}service MyRPC { rpc sayHi(Request) returns(Response);}

5、運行項目,右擊項目Run as -->maven build....->protobuf:compile以及protobuf:compile-custom,這樣就編譯生成了相應的代碼了。不過存放的路徑不對,需要自己拷貝到相應的項目目錄下。

Java Grpc實例創(chuàng)建負載均衡詳解

6、grpc的客戶端和服務端代碼需要自己編寫。不過這一塊的demo已經很全了。c+v然后改成自己的自己需要的就行了。

服務端demo:

package server;import com.qidai.proto.MyRPCGrpc;import com.qidai.proto.MyThing;import io.grpc.ServerBuilder;import io.grpc.stub.StreamObserver;import service.RequestImpl;import java.io.IOException;public class Server { private static final int PORT = 2222; private final io.grpc.Server server; public Server() throws IOException { //這個部分啟動server this.server = ServerBuilder.forPort(PORT).addService(new RequestImpl()).build().start(); System.out.println('Server1 Started ...'); } private void stop() { if (server != null) { server.shutdown(); } } private void blockUntilShutdown() throws InterruptedException { if (server != null) { server.awaitTermination(); } } public static void main(String[] args) throws IOException, InterruptedException { Server server = new Server(); //block Server防止關閉 server.blockUntilShutdown(); } }

客戶端demo

package client;import com.qidai.proto.MyRPCGrpc;import com.qidai.proto.MyRPCGrpc.MyRPCBlockingStub;import com.qidai.proto.MyThing;import io.grpc.ManagedChannel;import io.grpc.ManagedChannelBuilder;import java.util.concurrent.TimeUnit;public class Client { private final ManagedChannelBuilder<?> managedChannelBuilder; private final MyRPCBlockingStub blockingStub; private final ManagedChannel channel; public Client(String name, int port) { managedChannelBuilder = ManagedChannelBuilder.forAddress(name, port); channel = managedChannelBuilder.usePlaintext().build(); blockingStub = MyRPCGrpc.newBlockingStub(channel); } public void shutdown() throws InterruptedException { channel.shutdown().awaitTermination(5, TimeUnit.SECONDS); } public void sayHi(String name){ MyThing.Request request = MyThing.Request.newBuilder().setName(name).build(); MyThing.Response response = blockingStub.sayHi(request); System.out.println(response.getName()); } public static void main(String[] args) throws Exception{ Client client = new Client('localhost', 5005); for (int i = 0; i < 10; i++) { Thread.sleep(1000); //進行rpc調用的真正邏輯 client.sayHi('Hello Server1111 ->5005 ' + i); } client.shutdown(); Client client2 = new Client('localhost', 5005); for (int i = 0; i < 10; i++) { Thread.sleep(1000); //進行rpc調用的真正邏輯 client2.sayHi('Hello Server2222 ->5005 ' + i); } client2.shutdown(); }}

7、接下來就是才是比較關鍵的一步,實現自己的grpc服務端的業(yè)務代碼。主要的關鍵步驟就是繼承grpc自動映射出來的抽象類。是不是很熟悉,沒錯就是proto文件里面配置的服務。然后重寫服務里面配置的方法即可。最后放心大膽的去根據傳遞的request參數去做相關的業(yè)務邏輯的處理。并用response封裝需要返回的接口。(此處的request與response均是grcp根據proto配置文件映射出來的相關實體類。)

package service;import com.qidai.proto.MyRPCGrpc.MyRPCImplBase;import com.qidai.proto.MyThing.Response;public class RequestImpl extends MyRPCImplBase { @Override public void sayHi(com.qidai.proto.MyThing.Request request, io.grpc.stub.StreamObserver<com.qidai.proto.MyThing.Response> responseObserver) { //proto文件上定義的response返回信息 Response response;System.out.println('Request>>>say::' + request.getName()); //AccountQryResponse response = QryAccountProto.AccountQryResponse.newBuilder().setRc(1).setAmount(666).build(); response = Response.newBuilder().setName('Response11111>>>say:::hello_client'+request.getName()).build(); responseObserver.onNext(response); responseObserver.onCompleted();} }

二、Grpc服務基于nginx(1.12.2)實現負載均衡。下面直接貼nginx相關的配置,服務端和客戶端的代碼改動都很小。只需調整ip和port的值即可。其他的不需要改動。

TCP層負載均衡配置

stream { log_format proxy ’$remote_addr [$time_local] ’ ’$protocol $status $bytes_sent $bytes_received ’ ’$session_time '$upstream_addr' ’ ’'$upstream_bytes_sent' '$upstream_bytes_received' '$upstream_connect_time'’; include ./conf.d/*.tcpstream; upstream grpc { server 127.0.0.1:2223; server 127.0.0.1:2222; } server { error_log logs/device5001_error.log; access_log logs/device5001_access.log proxy; listen 5005; proxy_pass grpc; } }

grpc的負載均衡配置(grpc的支持在nginx1.13之后才有,所以這里是1.17.0)

http { include mime.types; default_type application/octet-stream; log_format main ’$remote_addr - $remote_user [$time_local] '$request' ’ ’$status $body_bytes_sent '$http_referer' ’ ’'$http_user_agent' '$http_x_forwarded_for'’; access_log logs/access.log main; sendfile on; keepalive_timeout 65; gzip on; upstream grpcservers { server 127.0.0.1:2222; server 127.0.0.1:2223; } server { listen 8080 http2; server_name localhost; location / { grpc_pass grpc://grpcservers; } }}

最后分別啟動nginx1.12.2和nginx1.17.0,并在ide上啟動服務端和客戶端,更改相應的客戶端端口。就可以看到控制臺打印不同的信息了。tcp和grcp的負載均衡的效果是不一樣的。這也是我客戶端new 了一個client,然后又new 了一個client2的原因。比較懶,效果圖就不貼了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
97精品视频在线看| 免费在线日韩av| 国产拍在线视频| 日韩不卡免费高清视频| 日韩综合在线| 99久久视频| 亚洲欧美久久| 久久国产视频网| 国产在视频一区二区三区吞精| 在线天堂资源www在线污| 免费视频一区二区三区在线观看| 国内自拍视频一区二区三区| 在线天堂资源www在线污| 精品一区三区| 亚洲精品黄色| 嫩草伊人久久精品少妇av杨幂| 97精品国产| 亚洲免费一区二区| 国产精品午夜av| 亚洲手机视频| 国产日韩欧美中文在线| av高清一区| 三级欧美在线一区| 免费一级欧美片在线观看网站 | 欧美日本精品| av高清不卡| 亚洲精品国产精品粉嫩| 日本一二区不卡| 国产aⅴ精品一区二区三区久久| 精品女同一区二区三区在线观看| 国产成人精品福利| 91亚洲无吗| 国产精品亲子伦av一区二区三区| 日韩二区三区四区| 中文字幕亚洲影视| av日韩中文| 三级小说欧洲区亚洲区| 欧美aa在线观看| 欧美手机在线| 免费av一区| 国产精品普通话对白| 久久精品国产68国产精品亚洲| 欧美日韩中文字幕一区二区三区 | 欧美一区久久久| 国产精品一卡| 国产精品自拍区| 国产一区观看| 国产精品女主播一区二区三区| 亚洲精品在线a| 久久久久久久欧美精品| 一区二区三区网站| 麻豆视频在线看| 亚洲天堂日韩在线| 国产一区二区三区四区五区| 免费日本视频一区| 久久久久观看| 爽好多水快深点欧美视频| 久久精品国产亚洲一区二区三区| 欧美三级精品| 日韩高清在线不卡| 国产精品99免费看| 国产精品任我爽爆在线播放| 夜夜精品视频| 国产66精品| 日韩国产在线观看一区| 亚洲二区精品| 国产一区二区三区不卡av| 亚洲视频国产| 亚洲高清激情| 精品日韩在线| 日韩在线观看一区二区| 高清日韩欧美| 欧美日本一区| 日韩精品一区第一页| 欧产日产国产精品视频| 国产精品一区高清| 免费成人性网站| 久久久久久久久久久妇女| 国产高清亚洲| 日韩av中文字幕一区| 亚洲欧美不卡| 国产91久久精品一区二区| 久久精品一区二区三区中文字幕| 日本亚洲视频在线| 亚洲欧美网站| 亚洲va中文在线播放免费| 国产精品网址| 日韩激情中文字幕| 国产亚洲在线| 99视频精品全国免费| 国产精品成人a在线观看| 国产精品网站在线看| 日本一区二区三区中文字幕| 亚洲欧美视频| 99国产精品视频免费观看一公开 | 亚洲一区国产一区| 亚洲精品2区| 欧美一区激情| 视频在线在亚洲| 亚洲精品极品少妇16p| 精品网站aaa| 日韩一区精品| 日本伊人久久| 婷婷五月色综合香五月| 亚洲精品护士| 日韩一区二区三区免费视频| 不卡视频在线| 国产69精品久久| 国产欧美日韩一级| 一区二区91| 黄色不卡一区| 精品国产黄a∨片高清在线| 久久国产主播| 成人亚洲精品| 国产精品白丝av嫩草影院| 日韩精品a在线观看91| 中文字幕av一区二区三区人| 午夜在线视频观看日韩17c| 不卡在线一区二区| 激情婷婷亚洲| 久久蜜桃av| 久久亚洲成人| 欧美不卡视频| 日韩三区在线| 精品国模一区二区三区| 亚洲啊v在线| 婷婷激情一区| 欧美亚洲国产一区| 伊人久久婷婷| 亚洲一区二区三区中文字幕在线观看| 夜久久久久久| 伊人www22综合色| 青草国产精品久久久久久| 欧美日韩精品一区二区三区视频 | 亚洲人成网77777色在线播放 | 91免费精品| 日韩免费高清| 香蕉精品视频在线观看| 欧美日韩激情| 国产精品久久久久蜜臀| 欧美三级网址| 欧美精品一二| 免费观看久久久4p| 欧美日韩一区二区国产| 国产日韩欧美一区二区三区在线观看| 国产经典一区| 成人va天堂| 夜久久久久久| 人人爱人人干婷婷丁香亚洲| 精品视频一区二区三区四区五区 | 精品国产亚洲日本| 成人国产综合| 91精品91| 日韩一区二区三区在线看| 免费一级欧美在线观看视频| 成人看片网站| 蜜臀va亚洲va欧美va天堂| 久久精品97| 日本蜜桃在线观看视频| 悠悠资源网久久精品| 日韩欧美中文在线观看| 精品中文在线| 尤物tv在线精品| 日本99精品| 麻豆精品蜜桃| 在线精品福利| 欧美激情麻豆| 欧美亚洲在线日韩| 日本成人手机在线| 色一区二区三区| 亚洲精品伊人| 日本一区二区免费高清| 亚洲主播在线| 免费在线日韩av| 欧美1区免费| 清纯唯美亚洲综合一区| 亚洲1234区| 日本欧美韩国一区三区| 中文字幕在线视频久| 蜜桃视频一区二区三区在线观看 | 桃色av一区二区| 免费在线观看成人| 国产精品99一区二区三区| 石原莉奈一区二区三区在线观看| 美女精品一区二区| 天使萌一区二区三区免费观看| 国产极品久久久久久久久波多结野| 欧美日韩激情| 久久午夜影院| 中文字幕av亚洲精品一部二部| 久草免费在线视频| 日韩在线观看一区二区三区| 日韩精品免费一区二区三区| 国产精品天天看天天狠| 午夜久久免费观看| 国产在线观看91一区二区三区| 中文字幕日韩亚洲| 久久久久久黄| 麻豆成人在线观看| 亚洲欧美久久精品|