专栏首页python3grpc python 和Java实现

grpc python 和Java实现

Grpc实战教程:

说一下目的:实现Python变成的服务端,Java作为客户端,实现二者的通信,实现的功能:传递过来的字符串全部转换为大写

一、安装(Java和Python)

1、  Python安装grpc

1)      gRPC 的安装,执行命令:pipinstall grpcio

2)      ProtoBuf 相关的 python 依赖库,执行:pipinstall protobuf

3)      安装 python grpc 的 protobuf 编译工具,执行:pipinstall grpcio-tools

2、  Java安装grpc

3、  参考:https://github.com/grpc/grpc-java,添加对应的jar包和插件,我的测试是在idea下maven工程下进行的,只需在pom文件中,添加对应的依赖和插件即可。

二、编写对应的客户端(java)和服务端(Python)

1、首先编写proto文件,由于是测试,proto文件如下:

注意:编译成Python和Java都是使用的此文件内容

2、编译成Python和Java对应的文件()

首先变成Python所需要的文件,我的目录结构如下:

首先找到data.proto所在的目录,执行下列命令:

python –m grpc_tools.protoc –I=. –python_out=.–grpc_python_out=.

完成对data.proto的编译,生成

首先实现对应的服务端代码,建立serviceMain模块:

编写客户端代码,建立clientMain模块:

Python服务端和客户端测试,首先启动服务端,然后启动客户端:

下面编译Java对应的文件和代码,为了方便,首先建立一个maven工程,并在maven工程下src/main目录下建立proto文件夹(这个proto文件夹只能在这里建立,是为了下面更好的编译,减少不必要的麻烦),具体目录如下:

建立data.proto文件,

将建立的data.proto文件到proto文件夹中,然后打开pom文件,按照https://github.com/grpc/grpc-java,添加对应的jar包和插件即可。

然后通过maven下载好这些jar和插件好,打开工程右边的maven projects,可以看到如下:

然后点击上图红色方框对应的按钮,就会编译data.proto(这也是上述为啥建立proto文件夹在src/main下的原因),等待编译完成就会在工程目录target\generated-sources\protobuf\java看到编译后的文件(包含自己指定的package和生成的java类)。

这时只是生成了对应rpc传输的数据结构类,还没有生成对应的服务端的代码,下面就该生成服务端的代码了,同样打开项目右侧的maven projects,点击“package”将项目打包,如下图

此时在target/generated-sources/protobuf下会生成grpc-java文件,生成的服务端代码就在此文件中,将生成的类剪切(是剪切,当然复制完成删除也可以,避免报错)拷贝工程中对应的package下,如下图红色框内的类就是生成的文件:

这时在Java package下建立package的层次关系,

剩下的就是实现java服务端和客户端的内容,首先定义了一个常量类:

实现具体服务端的内容如下(实现在data.proto中定义的函数):

具体java服务端的实现如下(注意观察红色方框内)如下,需要两步:

第一步,实现服务端的具体操作(注意此时还是没有建立服务启动内容,嘿嘿,因为还没有设定具体的端口号,仅仅实现了服务端要做的操作而已)

建立服务端的服务:

具体java客户端的实现:

Java服务端和客户端测试,首先启动服务端,再启动客户端,然后运行DefinedClient.java的main函数,可以看到下面的输出就表示成功!

三、跨语言的测试:

第一种情况:Java客户端,Python服务端,启动上述对应的代码模块(先启动服务,然后运行客户端):

可以看到也

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Java工程师学习指南第7部分:重新学习MySQL与Redis

    本文整理了微信公众号【Java技术江湖】发表和转载过的Mysql和Redis相关优质文章,想看到更多Java技术文章,就赶紧关注本公众号吧吧。

    Java技术江湖
  • Spark2.x新特性的介绍

    dataframe与dataset统一,dataframe只是dataset[Row]的类型别名

    我脱下短袖
  • 软件安全性测试(连载4)

    XSS测试就是在容易出现XSS注入的地方输入被测代码,提交后观察其显示是否会触发JavaScript脚本。常用的XSS测试JavaScript脚本主要就下面两个...

    小老鼠
  • 软件安全性测试(连载6)

    跨站请求伪造(Cross-Site Request Forgery:CSRF),也被称为 One-Click Attack 或者 Session Riding,...

    小老鼠
  • JAVA之线程状态(二)

    PS:通过API,演示前面说的几种状态,通过图和代码让大家对这6种状态了解透彻,线程状态的知识点就讲解到这里。下次咱们继续说说线程,一起说说线程终止。

    IT故事会
  • 第49次文章:Filter&Listener

    每周一约!哈哈!小白又来啦!这周我们来聊聊Javaweb的三大组件——servlet、filter、listener。servlet之前的文章已经讲过了,这次来...

    鹏-程-万-里
  • Java工程师学习指南第6部分:深入理解JVM虚拟机

    本文整理了微信公众号【Java技术江湖】发表和转载过的JVM虚拟机相关优质文章,想看到更多Java技术文章,就赶紧关注本公众号吧吧。

    Java技术江湖
  • JAVA多线程并发之线程实现,4种线程池,终止线程4种方式

    Thread 类本质上是实现了 Runnable 接口的一个实例,代表一个线程的实例。启动线程的唯一方 法就是通过 Thread 类的 start()实例方法。...

    三哥
  • Centos7下安装kafka

    本文为北溟有鱼QAQ原创文章,转载无需和我联系,但请注明来自北溟有鱼QAQ

    北溟有鱼QAQ
  • JVM性能

    JVM是Java Virtual Machine(Java虚拟机)的缩写,JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿真...

    小老鼠

扫码关注云+社区

领取腾讯云代金券