在Java中使用gRPC進(jìn)行服務(wù)調(diào)用,你需要遵循以下步驟:
在你的項(xiàng)目中添加gRPC的Java庫(kù)依賴。如果你使用Maven,可以在pom.xml文件中添加以下依賴:
<dependency>
<groupId>io.grpc</groupId>
<artifactId>grpc-netty-shaded</artifactId>
<version>1.42.1</version>
</dependency>
<dependency>
<groupId>io.grpc</groupId>
<artifactId>grpc-protobuf</artifactId>
<version>1.42.1</version>
</dependency>
<dependency>
<groupId>io.grpc</groupId>
<artifactId>grpc-stub</artifactId>
<version>1.42.1</version>
</dependency>
創(chuàng)建一個(gè).proto
文件,定義你的服務(wù)接口。例如,創(chuàng)建一個(gè)名為greeter.proto
的文件:
syntax = "proto3";
package greeter;
service Greeter {
rpc SayHello (HelloRequest) returns (HelloReply) {}
}
message HelloRequest {
string name = 1;
}
message HelloReply {
string message = 1;
}
使用protoc
編譯器生成Java代碼。在命令行中運(yùn)行以下命令:
protoc --java_out=./src/main/java --grpc_out=./src/main/java --plugin=protoc-gen-grpc=`which grpc_java_plugin` greeter.proto
這將在src/main/java
目錄下生成Java代碼,包括服務(wù)接口、請(qǐng)求和響應(yīng)類。
創(chuàng)建一個(gè)實(shí)現(xiàn)上述服務(wù)接口的類。例如,創(chuàng)建一個(gè)名為GreeterServiceImpl.java
的文件:
package greeter;
import io.grpc.stub.StreamObserver;
public class GreeterServiceImpl extends GreeterGrpc.GreeterImplBase {
@Override
public void sayHello(HelloRequest req, StreamObserver<HelloReply> responseObserver) {
HelloReply reply = HelloReply.newBuilder().setMessage("Hello, " + req.getName()).build();
responseObserver.onNext(reply);
responseObserver.onCompleted();
}
}
創(chuàng)建一個(gè)gRPC服務(wù)器,將服務(wù)實(shí)現(xiàn)綁定到服務(wù)器上。例如,創(chuàng)建一個(gè)名為Server.java
的文件:
package greeter;
import io.grpc.Server;
import io.grpc.ServerBuilder;
public class Server {
public static void main(String[] args) throws Exception {
Server server = ServerBuilder.forPort(8080)
.addService(new GreeterServiceImpl())
.build()
.start();
server.awaitTermination();
}
}
創(chuàng)建一個(gè)gRPC客戶端,調(diào)用遠(yuǎn)程服務(wù)。例如,創(chuàng)建一個(gè)名為Client.java
的文件:
package greeter;
import io.grpc.ManagedChannel;
import io.grpc.ManagedChannelBuilder;
public class Client {
public static void main(String[] args) {
ManagedChannel channel = ManagedChannelBuilder.forAddress("localhost", 8080)
.usePlaintext()
.build();
GreeterGrpc.GreeterStub stub = GreeterGrpc.newStub(channel);
HelloRequest request = HelloRequest.newBuilder().setName("World").build();
stub.sayHello(request, response -> {
System.out.println("Response: " + response.getMessage());
});
}
}
現(xiàn)在,你可以運(yùn)行服務(wù)器和客戶端代碼,客戶端將調(diào)用遠(yuǎn)程服務(wù)并打印響應(yīng)消息。