Netty学习——Google Protobuf使用方式分析和环境搭建
Google Protobuf使用方式分析
在RPC框架中,Google Protobuf是很常用的一个库,和Apache Thrift 是同款的用于进行序列化的第三方库。
原理都是大同小异,无非就是使用方式的不同。
rmi:remote method invocation 远程方法调用
在A机器,调用B机器上的方法,
从使用者的角度,你是感知不到这个调用的,在A上用,就行了。
但是实际上是一种夸机器的一种调用。
一定是通过网络传输的方式来进行调用的。
而今天用的这个google Protobuf就是这个传输工具
这样就有一个客户端和一个服务端。通过序列化和反序列化的方式来进行传输
Client:序列化 -》 Server:反序列化
EJB rmi 缺陷:只使用于java
Client:stub 装
server:skeleton 骨架
stub 和 skeleton 通过socket完成序列化和反序列化。相互传输信息
序列化和反序列化:这是RPC或者RMI 的一个基础机制,也叫作编码(encode)与解码(decode)
RPC和RMI极其的相似
RPC:remote Procedure Call,远程过程调用
RPC的优点:许多RPC框架都是跨语言的。
比如:服务器端是java写的,客户端是phython写的,前台通过phython的方法进行调用后台服务器。
RPC的实现原理和使用场景:
1.定义一个接口说明文件(IDL):描述了对象(结构体)、结构成员,接口方法等一系列信息
2.通过RPC框架所提供的的编译器,将接口说明文件编译成具体语言文件。(如,在服务器端生成Java代码,在客户端生成phython代码)
3.在客户端和服务器端分别引入RPC编译器所生成的文件,即可像调用本地方法一样,调用远程方法。
如何判断一个RPC的性能?
1.编解码效率。编码解码的吞吐量大,效率就会高
2.在数据传递上:socket效率会高一些,HTTP协议会低一些
接下来开始正式了解Google Protobuf
官网 https://developers.google.com/protocol-buffers
message Person {
required string name = 1;
required int32 id = 2;
optional string email = 3;
}
//注意
//required 必填项 optional选填项
//后面的数字,不是给他们赋值,而是标识。 在PB里面,每一个成员变量都会有一个数字来进行标识
--------------------------------------------------------------------------------
什么是protocol buffers?
Protocol buffers are Google's language-neutral, platform-neutral, extensible mechanism for serializing structured data – think XML, but smaller, faster, and simpler. You define how you want your data to be structured once, then you can use special generated source code to easily write and read your structured data to and from a variety of data streams and using a variety of languages.
Protocol buffers 是谷歌的语言无关的、平台无关的、可扩展的序列化结构化数据的机制—想想XML,但是更小、更快、更简单。一旦定义了数据的结构化方式,就可以使用特殊生成的源代码轻松地在各种数据流之间和之间编写和读取结构化数据,并使用各种语言。
准备Protobuf环境,和资源包
1.在官网点击下载按钮:会跳转到项目的GitHub仓库、 官网地址:https://developers.google.com/protocol-buffers

2.对于非C++的用户,点击这个链接进行资源的下载

3.需要下载的东西有两个,一个是运行环境。一个是源代码。 下载地址:https://github.com/protocolbuffers/protobuf/releases


4.下载之后是这个样子 ,解压缩,到工作环境目录,然后配置环境变量。

(这里我就不给说如何配置环境变量了。和java完全一样。成功以后是这样的)

接下来需要配置环境变量:(和java环境变量大同小异)我的电脑,右键,属性,环境变量,Path中添加

验证:是否成功,win+R cmd :指令 protoc

5.根据GitHub的Readme文件,java运行Protobuf需要依赖的两个依赖包,分别是:protobuf-java 和 protobuf-java-util

我们这里使用Gradle来进行项目的构建,代码如下
这些包是从Maven仓库找的,maven仓库地址:
dependencies {
compile(
"io.netty:netty-all:4.1.43.Final",
"com.google.protobuf:protobuf-java-util:3.11.0",
"com.google.protobuf:protobuf-java:3.11.0"
)
}
以上就已经环境和源码就准备完毕了,可以自行查阅开发指南进行学习:
https://developers.google.com/protocol-buffers/docs/javatutorial
Netty学习——Google Protobuf使用方式分析和环境搭建的更多相关文章
- Netty学习——Google Protobuf的初步了解
学习参考的官网: https://developers.google.com/protocol-buffers/docs/javatutorial 简单指南详解:这个文档写的简直是太详细了. 本篇从下 ...
- Java开发学习心得(一):SSM环境搭建
目录 Java开发学习心得(一):SSM环境搭建 1 SSM框架 1.1 Spring Framework 1.2 Spring MVC Java开发学习心得(一):SSM环境搭建 有一点.NET的开 ...
- Android基础-系统架构分析,环境搭建,下载Android Studio,AndroidDevTools,Git使用教程,Github入门,界面设计介绍
系统架构分析 Android体系结构 安卓结构有四大层,五个部分,Android分四层为: 应用层(Applications),应用框架层(Application Framework),系统运行层(L ...
- netty 的 Google protobuf 开发
根据上一篇博文 Google Protobuf 使用 Java 版 netty 集成 protobuf 的方法非常简单.代码如下: server package protobuf.server.imp ...
- kibana5.6 源码分析以--环境搭建&技术准备
Kibana是一个开源的分析与可视化平台,设计出来用于和Elasticsearch一起使用的.你可以用kibana搜索.查看.交互存放在Elasticsearch索引里的数据,使用各种不同的图表.表格 ...
- protobuf 协议 windows 下 C++ 环境搭建
1. 下载protobuf https://code.google.com/p/protobuf/downloads/list Protocol Buffers 2.5.0 full source - ...
- 【菜鸟学习Linux】-第三章- Linux环境搭建-使用VMware9安装Ubuntu 12.04系统
上一步,我们安装了VMware9虚拟机,现在我们就是用它来安装Ubuntu12.04系统,至于Ubuntu是什么,我就不废话了,大家google一下,比我讲的清楚,好了,开始干活! Ubuntu官网下 ...
- 新手嘛,先学习下 Vue2.0 新手入门 — 从环境搭建到发布
Vue2.0 新手入门 — 从环境搭建到发布 转自:http://www.runoob.com/w3cnote/vue2-start-coding.html 具体文章详细就不搬了,步骤可过去看,我这就 ...
- [软件测试]Linux环境中简单清爽的Google Test (GTest)测试环境搭建(初级使用)
本文将介绍单元测试工具google test(GTEST)在linux操作系统中测试环境的搭建方法.本文属于google test使用的基础教程.在linux中使用google test之前,需要对如 ...
随机推荐
- regexp盲注的一些改进
index.php?id=1 and 1=(SELECT 1 FROM information_schema.tables WHERE TABLE_SCHEMA="blind_sqli&qu ...
- NOIP模拟 3
序列 以为自己很对然后光荣T20 (路丽姐姐原谅我吧)果然是把等比数列的定义记错了,一直没发现等比数列里的项是互成倍数的 正解首先就跟据上点初步判断两项能否成为子段的开头 然后处理出可能的最小公比(用 ...
- Laravel用户认证
前期准备 Laravel的权限配置文件位于 config/auth.php,Laravel的认证组件由"guards"和"providers"组成, Guard ...
- Java nio 空轮询bug到底是什么
编者注:Java nio 空轮询bug也就是Java nio在Linux系统下的epoll空轮询问题. epoll机制是Linux下一种高效的IO复用方式,相较于select和poll机制来说.其高效 ...
- SSM配置梳理
这两天梳理了一下 SSM 的配置,做一个小总结 可能有一些不对的地方,如果您发现了什么错误,非常希望能帮忙指出,谢谢 我参考了很多文章,都标明了来源(链接),可能会影响阅读的连贯性,抱歉 ...
- .NET后端知识汇总
C#.net系列后端知识点汇总(也有些许数据库.svn等),他山之石. 1..net相关技术:XML.webservice.SOAP,其中webservice使用三大技术:XML.SOAP.WSDL. ...
- 微信小程序this.data和this.setData({})的区别
this.data.xx是用来获取页面data对象的----------只是js(逻辑层)数据的更改: this.setData是用来更新界面的---------用于更新view层的.
- C语音中最简单的排序冒泡排序和选择排序代码实现(非指针)
#include<stdio.h> int main() { int a[5] = { 2,5,7,3,-1 }; int n = sizeof(a) / sizeof(a[0]);//元 ...
- thinkphp 比RBAC更好的权限认证方式(Auth类认证)
Auth 类已经在ThinkPHP代码仓库中存在很久了,但是因为一直没有出过它的教程, 很少人知道它, 它其实比RBAC更方便 . RBAC是按节点进行认证的,如果要控制比节点更细的权限就有点困难了, ...
- 微擎框架商业版 V2.1.2 去后门一键安装版+去除云平台+无附带模块
下载地址:http://dd.ma/AdVvoDu5 关注微信公众号codervip,点击公众号菜单,获取提取码! 这个是一键安装版本,所以微擎安装比较简单,不用大家手动去改数据库了,而且修复上个2. ...