版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第GoLang與Java各自生成grpc代碼流程介紹目錄1.背景2.go生成grpc代碼2.1安裝2.2安裝對(duì)應(yīng)插件3.java生成grpc代碼3.1idea安裝protobuf插件3.2創(chuàng)建maven項(xiàng)目3.3生成grpc代碼
1.背景
由于公司的日志系統(tǒng)使用的是plumelog,最近生產(chǎn)環(huán)境老是報(bào)jedis連接池不夠,導(dǎo)致丟失日志,而且服務(wù)老是重啟,懷疑跟日志系統(tǒng)有關(guān),于是自己改造plumelog,使用gogrpc生成server端,使用javagrpc生成客戶端,將日志以grpc服務(wù)形式傳遞到server端。
2.go生成grpc代碼
2.1安裝
protc:/protocolbuffers/protobuf/releases
選擇自己所需版本,解壓后將protoc.exe拷貝至go環(huán)境的bin目錄下
2.2安裝對(duì)應(yīng)插件
goinstall/protobuf/cmd/protoc-gen-go@v1.28
goinstall/grpc/cmd/protoc-gen-go-grpc@v1.2
將生成的插件拷貝至go環(huán)境的bin目錄下
編寫(xiě).proto文件:
syntax="proto3";
//指定等會(huì)文件生成出來(lái)的package
packageserver;
optiongo_package="plumelog/rpc;server";
//定義requestmodel
messagePlumelogRequest{
stringmessage=1;//1代表順序
//定義responsemodel
messagePlumelogResponse{
stringmessage=1;//1代表順序
//定義服務(wù)主體
servicePlumelogService{
//定義方法
rpcGetPlumelog(PlumelogRequest)returns(PlumelogResponse);
}
項(xiàng)目結(jié)構(gòu)圖:
在終端cd到proto目錄下,執(zhí)行如下命令生成grpc代碼:
protoc--go_out=plugins=grpc:.to
server端:
main.go:
import(
"/grpc"
"log"
"net"
"plumelog/rpc"
"plumelog/server"
funcmain(){
//1.new一個(gè)grpc的server
rpcServer:=grpc.NewServer()
//2.將剛剛我們新建的ProdService注冊(cè)進(jìn)去
rpc.RegisterPlumelogServiceServer(rpcServer,new(server.RpcServer))
//3.新建一個(gè)listener,以tcp方式監(jiān)聽(tīng)8899端口
listener,err:=net.Listen("tcp",":8899")
iferr!=nil{
log.Fatal("服務(wù)監(jiān)聽(tīng)端口失敗",err)
//4.運(yùn)行rpcServer,傳入listener
_=rpcServer.Serve(listener)
}
server.go
packageserver
import(
"context"
"plumelog/rpc"
typeRpcServerstruct{
varpushProducer*plumelog.Producer
func(*RpcServer)GetProductStock(ctxcontext.Context,req*rpc.PlumelogRequest)(*rpc.PlumelogResponse,error){
fmt.Println(req.Message)
returnrpc.PlumelogResponse{Message:req.Message},nil
}
3.java生成grpc代碼
3.1idea安裝protobuf插件
3.2創(chuàng)建maven項(xiàng)目
pom.xml:
xmlversion="1.0"encoding="UTF-8"
projectxmlns="/POM/4.0.0"xmlns:xsi="/2001/XMLSchema-instance"
xsi:schemaLocation="/POM/4.0.0/xsd/maven-4.0.0.xsd"
parent
groupIdcom.plumelog/groupId
artifactIdplumelog/artifactId
version3.5/version
/parent
modelVersion4.0.0/modelVersion
artifactIdplumelog-logback/artifactId
nameplumelog-logback/name
packagingjar/packaging
dependencies
dependency
groupIdch.qos.logback/groupId
artifactIdlogback-core/artifactId
version1.2.3/version
/dependency
dependency
groupIdch.qos.logback/groupId
artifactIdlogback-classic/artifactId
version1.2.3/version
/dependency
dependency
groupIdcom.plumelog/groupId
artifactIdplumelog-core/artifactId
version${project.parent.version}/version
/dependency
dependency
groupIdtobuf/groupId
artifactIdprotobuf-java/artifactId
version3.5.1/version
/dependency
!--/artifact/tobuf/protobuf-java-util--
dependency
groupIdtobuf/groupId
artifactIdprotobuf-java-util/artifactId
version3.5.1/version
/dependency
!--/artifact/io.grpc/grpc-all--
dependency
groupIdio.grpc/groupId
artifactIdgrpc-all/artifactId
version1.12.0/version
/dependency
dependency
groupIdjavax.annotation/groupId
artifactIdjavax.annotation-api/artifactId
version1.3.2/version
scopecompile/scope
/dependency
dependency
groupIdjavax.annotation/groupId
artifactIdjavax.annotation-api/artifactId
version1.3.2/version
scopecompile/scope
/dependency
dependency
groupIdjavax.annotation/groupId
artifactIdjavax.annotation-api/artifactId
version1.3.2/version
scopecompile/scope
/dependency
/dependencies
build
plugins
!--依賴包插件--
plugin
groupIdorg.apache.maven.plugins/groupId
artifactIdmaven-dependency-plugin/artifactId
executions
execution
idcopy-dependencies/id
phasepackage/phase
goals
goalcopy-dependencies/goal
/goals
configuration
outputDirectory${project.build.directory}/lib/outputDirectory
!--是否不包含間接依賴--
excludeTransitivefalse/excludeTransitive
!--忽略版本--
stripVersionfalse/stripVersion
/configuration
/execution
/executions
/plugin
plugin
groupIdorg.xolstice.maven.plugins/groupId
artifactIdprotobuf-maven-plugin/artifactId
version0.5.0/version
configuration
protocArtifact
tobuf:protoc:3.1.0:exe:${os.detected.classifier}
/protocArtifact
pluginIdgrpc-java/pluginId
pluginArtifact
io.grpc:protoc-gen-grpc-java:1.11.0:exe:${os.detected.classifier}
/pluginArtifact
/configuration
!--executions--
!--execution--
!--goals--
!--goalcompile/goal--
!--goalcompile-custom/goal--
!--/goals--
!--/execution--
!--/executions--
/plugin
/plugins
extensions
extension
groupIdkr.motd.maven/groupId
artifactIdos-maven-plugin/artifactId
version1.6.2/version
/extension
/extensions
/build
/project
maven插件:
3.3生成grpc代碼
//這個(gè)就是protobuf的中間文件
//指定的當(dāng)前proto語(yǔ)法的版本,有2和3
syntax="proto3";
//指定等會(huì)文件生成出來(lái)的package
packageserver;
optionjava_package="com.plumelog.logback.rpc";
optionjava_multiple_files=false;
optionjava_outer_classname="RpcClient";
//定義requestmodel
messagePlumelogRequest{
stringmessage=1;//1代表順序
//定義responsemodel
messagePlumelogResponse{
stringmessage=1;//1代表順序
//定義服務(wù)主體
servicePlumelogService{
//定義方法
rpcGetPlumelog(PlumelogRequest)returns(PlumelogResponse);
}
ps:指定的package要與go那邊的proto指定的package一致,否則啟動(dòng)報(bào)找不到rpc服務(wù)
雙擊maven插件的protobuf:complie生成rpc代碼,雙擊maven插件的protobuf:custom生成grpc代碼
調(diào)用:
privateStringrpcHost="";
privateintrpcPort=8899;
ManagedChannelchannel=ManagedChannelBuilder.forAddress(rpcHost,rpcPort).usePlaintext().build();
@Override
protectedvoidappend(ILoggingEventevent){
if(event!=null){
send(event);
protectedvoidsend(ILoggingEventevent){
finalBaseLogMessagelogMessage=LogMessageUtil.getLogMessage(appName,env,event);
if(logMessageinstanceofRunLogMessage){
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026年農(nóng)業(yè)文化遺產(chǎn)活化利用指南
- 煙草制品經(jīng)營(yíng)風(fēng)險(xiǎn)防控管理手冊(cè)
- 2026青龍湖(河北)產(chǎn)業(yè)發(fā)展集團(tuán)有限公司招聘15人備考題庫(kù)及一套參考答案詳解
- 2026年原型設(shè)計(jì)工具高階應(yīng)用培訓(xùn)
- 計(jì)算機(jī)行業(yè)年度策略:AI應(yīng)用加快全球格局重塑中
- 職業(yè)健康風(fēng)險(xiǎn)評(píng)估與員工職業(yè)發(fā)展動(dòng)態(tài)調(diào)整機(jī)制
- 職業(yè)健康促進(jìn)與職業(yè)健康效益優(yōu)化
- 職業(yè)健康與心理健康的整合干預(yù)策略-2
- 陽(yáng)江2025年廣東陽(yáng)江陽(yáng)西縣新墟鎮(zhèn)招聘合同制禁毒工作人員筆試歷年參考題庫(kù)附帶答案詳解
- 邢臺(tái)2025年河北邢臺(tái)市襄都區(qū)招聘中小學(xué)幼兒園教師75人筆試歷年參考題庫(kù)附帶答案詳解
- 云南省玉溪市2025-2026學(xué)年八年級(jí)上學(xué)期1月期末物理試題(原卷版+解析版)
- 2026年哈爾濱通河縣第一批公益性崗位招聘62人考試參考試題及答案解析
- 六年級(jí)寒假家長(zhǎng)會(huì)課件
- 就業(yè)協(xié)議書(shū)解約函模板
- 物流鐵路專用線工程節(jié)能評(píng)估報(bào)告
- 2026天津市南開(kāi)區(qū)衛(wèi)生健康系統(tǒng)招聘事業(yè)單位60人(含高層次人才)備考核心試題附答案解析
- 重瞼手術(shù)知情同意書(shū)
- 研發(fā)部門(mén)員工加班管理細(xì)則
- 46566-2025溫室氣體管理體系管理手冊(cè)及全套程序文件
- 九師聯(lián)盟2026屆高三上學(xué)期12月聯(lián)考英語(yǔ)(第4次質(zhì)量檢測(cè))(含答案)
- 第21章 反比例函數(shù)(單元測(cè)試·綜合卷)(含答案)-滬科版(2024)九上
評(píng)論
0/150
提交評(píng)論