【博客園 總入口 】html
本篇是 netty+Protobuf 整合實戰的 第一篇,完成一個 基於Netty + Protobuf 實戰案例。java
要實現高併發、大流量,首先須要高傳輸效率的協議,Protobuf 是迄今爲止最高性能之一的傳輸格式,咱們首先將 Protobuf 和Netty整合起來。git
順便說明下: 本文的內容只是一個初稿、初稿,本文的知識,在《Netty Zookeeper Redis 高併發實戰》一書時,進行大篇幅的完善和更新,而且進行的源碼的升級。 博客和書不同,書的內容更加系統化、全面化,更加層層升入、井井有條、更屢次的錯誤排查,請你們以書的內容爲準。 本文的最終內容, 具體請參考瘋狂創客圈 傾力編著,機械工業出版社出版的 《Netty Zookeeper Redis 高併發實戰》一書 。 github
源代碼下載連接: netty+protobuf (整合源代碼)面試
在建立好**.proto協議文件以後,就須要按照好了對應版本的 protoc.exe工具。 protoc.exe工具是生成Java文件的工具軟件。 安裝的方法,前面已經講了。windows
這裏須要提示一下版本。Java 的maven 配置文件中 proto 包的版本,和 .proto文件的版本, 以及生成java 代碼的protoc.exe的版本,三者須要一致。架構
下面開始生成 消息的 Java代碼。 須要用到下面的指令:併發
protoc.exe --java_out=輸出的Java文件路徑名稱 .proto文件路徑名稱maven
例如:分佈式
protoc.exe --java_out=./src/main/java/ ./proto/ProtoMsg.proto
輸入完以後,回車便可在目標目錄看到已經生成好的Java文件,而後將該文件放到項目中該文件指定的路徑下便可。
本案例的工程中,以及給你們準備好了**.bat** windows 的命令文件,在 .bat 目錄 下執行**.bat** 文件便可。 .bat 文件以下:
d: cd D:\crazymakercircleJava\nettydemo\chatcommon protoc.exe --java_out=./src/main/java/ ./proto/ProtoMsg.proto
使用的時候,注意調整爲實際的目錄。
使用protoc.exe指令生成java代碼時,提示沒有設置協議版本。錯誤以下:
D:\crazymakercircleJava\nettydemo\chatcommon>protoc.exe --java_out=./src/main/java/ ./proto/ProtoMsg.proto
[libprotobuf WARNING T:\src\github\protobuf\src\google\protobuf\compiler\parser.cc:562] No syntax specified for the proto file: proto/ProtoMsg.proto. Please use 'syntax = "proto2";' or 'syntax = "proto3";' to specify a syntax version. (Defaulted to proto2 syntax.)
實際上,協議版本是已經設置好了的。
經過切換到老的protobuf代碼生成器版本,比方說2.6.1 ,這時候,會沒有錯誤提示了。
可是,新的問題來了,在代碼生成的目標目錄下,就是看不到生成Java代碼。說明代碼仍是沒有生成成功。
爬出這兩個大坑,會浪費大量的時間。
其實,天無絕人之路。
一條更好的路等着你來。這就是maven插件。
使用protobuf-maven-plugin,能夠很是方便的生成Java代碼。
插件的配置以下:
<plugin> <groupId>org.xolstice.maven.plugins</groupId> <artifactId>protobuf-maven-plugin</artifactId> <version>0.5.0</version> <extensions>true</extensions> <configuration> <!--默認值--> <protoSourceRoot>${project.basedir}/proto/protoConfig</protoSourceRoot> <!--默認值--> <!--<outputDirectory>${project.build.directory}/generated-sources/protobuf/java</outputDirectory>--> <outputDirectory>${project.build.sourceDirectory}</outputDirectory> <!--設置是否在生成java文件以前清空outputDirectory的文件,默認值爲true,設置爲false時也會覆蓋同名文件--> <clearOutputDirectory>false</clearOutputDirectory> <!--默認值--> <temporaryProtoFileDirectory>${project.build.directory}/protoc-temp</temporaryProtoFileDirectory> <protocExecutable>${project.basedir}/proto/protobin/protoc3.6.1.exe</protocExecutable> </configuration> <executions> <execution> <goals> <goal>compile</goal> <goal>test-compile</goal> </goals> </execution> </executions> </plugin>
插件的配置項中,須要配置的內容以下:
(1)protoSourceRoot : protobuf 協議文件的路徑
(2)outputDirectory :java 文件的目標路徑
(3)protocExecutable : protobuf 代碼生成工具的路徑
配置好以後,執行插件的compile命令, Java代碼就利索的生成了。
億級流量 高併發 IM後臺 開源項目實戰
Netty 源碼、原理、JAVA NIO 原理
Java 面試題 一網打盡
瘋狂創客圈 【 博客園 總入口 】
原文出處:https://www.cnblogs.com/crazymakercircle/p/10093385.html