1. Description
GRPC définit l'interface basée sur protobuf. Divisé en côté serveur et côté client. Le côté serveur assure l'implémentation de l'interface et le client obtient les données attendues en appelant l'interface côté serveur.
2. Partie publique
2.1 Ajouter une dépendance
<dependency> <groupId>net.devh</groupId> <artifactId>grpc-spring-boot-starter</artifactId> <version>2.12.0.RELEASE</version> </dependency> <dependency> <!-- Java 9+ compatibility --> <groupId>javax.annotation</groupId> <artifactId>javax.annotation-api</artifactId> </dependency>
Ajouter un plug-in (Remarque : si wagon-provider-api ne peut pas être introduit automatiquement, vous pouvez l'introduire maintenant dans les dépendances pour faciliter le téléchargement des dépendances, puis supprimer le coordonnées de dépendance)
<plugin> <!-- protobuf生成插件--> <groupId>org.xolstice.maven.plugins</groupId> <artifactId>protobuf-maven-plugin</artifactId> <version>0.6.1</version> <configuration> <protocArtifact>com.google.protobuf:protoc:3.17.3:exe:${os.detected.classifier} </protocArtifact> <pluginId>grpc-java</pluginId> <pluginArtifact>io.grpc:protoc-gen-grpc-java:1.39.0:exe:${os.detected.classifier} </pluginArtifact> <!--默认值--> <protoSourceRoot>${project.basedir}/src/main/proto</protoSourceRoot> <outputDirectory>${project.basedir}/src/main/java</outputDirectory> <clearOutputDirectory>false</clearOutputDirectory> </configuration> <executions> <execution> <goals> <goal>compile</goal> <goal>compile-custom</goal> </goals> </execution> </executions> </plugin>
2.2 Ajouter un fichier de dépendance proto
Ajoutez le répertoire src/main/proto
, et définissez le répertoire sur Source Root
, puis ajoutez le répertoire src/main/proto Ajoutez le fichier hello.proto
sous , le contenu est le suivantsrc/main/proto
,并将目录设置为Source Root
,然后在目录src/main/proto
下添加文件hello.proto
,内容如下
syntax = "proto3"; //指定proto版本 package com.server; // 生成的Java代码的包名 option java_package = "com.grpc.server"; // 请求参数 message HelloReq{ string name = 1; } // 返回参数 message HelloResp{ string ret = 1; } // rpc service service HelloService{ // service中需要进行调用的具体方法 rpc hello(HelloReq) returns (HelloResp){} }
2.3 通过protobuf生成Java代码
插件导入成功后,点击下图选中的protobuf:compile
和protbuf:compile-custom
import io.grpc.stub.StreamObserver; import net.devh.boot.grpc.server.service.GrpcService; @GrpcService public class HelloService extends HelloServiceGrpc.HelloServiceImplBase { @Override public void hello(Hello.HelloReq request, StreamObserver<Hello.HelloResp> responseObserver) { Hello.HelloResp resp = Hello.HelloResp.newBuilder().setRet("你好-->"+request.getName()).build(); responseObserver.onNext(resp); responseObserver.onCompleted(); } }2.3 Générez du code Java via protobuf
Une fois le plug-in importé avec succès , cliquez sur le
protobuf:compile
sélectionné dans l'image ci-dessous > et protbuf:compile-custom
générez le code Java correspondant (c'est-à-dire le code de dépendance de l'interface) dans l'ordre
3. L'implémentation spécifique de l'interface côté serveurle code de service est la suivante
import org.junit.jupiter.api.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; @SpringBootTest public class GrpcTest { @Autowired private HelloSerivce helloSerivce; @Test public void test1() throws Exception{ helloSerivce.haha("牛哈哈"); } }4 côté client L'implémentation spécifique de l'interface🎜🎜le code d'appel de test côté client est la suivante🎜rrreee
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Java est indépendant de la plate-forme en raison de sa philosophie de conception "écrire une fois, exécuter partout", qui repose sur les machines virtuelles Java (JVM) et Bytecode. 1) Le code Java est compilé en bytecode, interprété par le JVM ou compilé à la mouche localement. 2) Faites attention aux dépendances de la bibliothèque, aux différences de performances et à la configuration de l'environnement. 3) L'utilisation de bibliothèques standard, des tests multiplateformes et de la gestion des versions est la meilleure pratique pour assurer l'indépendance de la plate-forme.

Java'splatformIndependanceisNotsImple; itinVolvesComplexités.1)

Java'splatformIndependanceBenefitsWebapplicationsByAllowingCodetorunonanySystemwithajvm, simplifierDploymentAndScaling.Etenables: 1) EasyDeploymentAcRossditifferentServers, 2) SeamlesscalingacrosePloudPlatforms, et3) cohérentDevelopmentTodePloymentProceProced

ThejvmistherunTimeenvironmentForexEcutingJavabytecode, Crucialforjava "writeOnce, runanywhere" capability.itManagesMemory, les exécutions, les anciens et les antendus, le fait de faire en sorte

JavareMainsatopChoicefordEveloversDuetoitsPlatformIndependence, objet-orienteddesign, forts -ypyping, automatiqueMemory Management et ComprehensivestandardLibrary.

Java'splatformIndependenceMeansDevellersCanwriteCodeonCeandUniTonanyDevicewithoUtRecompiler.

Pour configurer le JVM, vous devez suivre les étapes suivantes: 1) Télécharger et installer le JDK, 2) Définir les variables d'environnement, 3) Vérifiez l'installation, 4) Définissez l'IDE, 5) Testez le programme Runner. La configuration d'un JVM ne consiste pas seulement à le faire fonctionner, cela implique également d'optimiser l'allocation de la mémoire, la collecte des ordures, le réglage des performances et la gestion des erreurs pour assurer un fonctionnement optimal.

Toensurejavaplateformindependence, suivant lestiné: 1) compilisendrunyourApplicationonMultipleplatformSusingdifferentosandjvmversions.2) utilizeci / cdpipelines lienjenkinsorgithubactionsforautomatedcross-PlateformSting.3)


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Navigateur d'examen sécurisé
Safe Exam Browser est un environnement de navigation sécurisé permettant de passer des examens en ligne en toute sécurité. Ce logiciel transforme n'importe quel ordinateur en poste de travail sécurisé. Il contrôle l'accès à n'importe quel utilitaire et empêche les étudiants d'utiliser des ressources non autorisées.

ZendStudio 13.5.1 Mac
Puissant environnement de développement intégré PHP

Listes Sec
SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

PhpStorm version Mac
Le dernier (2018.2.1) outil de développement intégré PHP professionnel

MinGW - GNU minimaliste pour Windows
Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.
