iis服务器助手广告
返回顶部
首页 > 资讯 > 后端开发 > GO >Golang基于泛化调用与Nacos实现Dubbo代理的方法是什么
  • 902
分享到

Golang基于泛化调用与Nacos实现Dubbo代理的方法是什么

2023-07-05 20:07:59 902人浏览 八月长安
摘要

这篇“golang基于泛化调用与Nacos实现dubbo代理的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Gol

这篇“golang基于泛化调用与Nacos实现dubbo代理的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Golang基于泛化调用与Nacos实现Dubbo代理的方法是什么”文章吧。

准备

由于是通用的 dubbo 代理,因此肯定需要使用泛化调用。而我们使用的注册中心是 nacos,因此也需要使用 nacos-sdk 来获取 provider 的实例信息。

实现

项目结构


├── dubbo/                 
│    ├─ generic.go   # 泛化调用 dubbo 接口
│    ├─ models.go    # 数据模型
│    └─ nacos.go     # 获取 nacos 元信息
├── WEB/                       
│    └─ server.go    # 对外 Http 接口

├── main.go          # main 入口函数
└── go.mod           # 模块描述文件

go.mod

module dubbo-proxygo 1.20require (dubbo.apache.org/dubbo-go/v3 v3.0.5GitHub.com/apache/dubbo-go-hessian2 v1.12.0github.com/gin-gonic/gin v1.9.0github.com/nacos-group/nacos-sdk-go/v2 v2.1.2)

返回数据格式

dubbo/models.go:

type DataResult struct {Env     string `JSON:"env,omitempty"`  // 当前调用环境Code    string `json:"code,omitempty"` // 返回结果码Data    any    `json:"data,omitempty"` // 返回结果Message string `json:"message,omitempty"` // 返回消息}

获取 nacos 元信息

根据环境创建 nacos client

func buildClient(env string, serverCfgs []constant.ServerConfig) naming_client.INaminGClient {client, _ := clients.NewNamingClient(vo.NacosClientParam{ClientConfig: constant.NewClientConfig(constant.WithNamespaceId(env),constant.WithNotLoadCacheAtStart(true),),ServerConfigs: serverCfgs,},)return client}

获取服务实例

func SelectInstance(env, servName string) (string, bool) {cli, ok := cliMap[env]if !ok {return "client not found from " + env, false}instances, e := cli.SelectInstances(vo.SelectInstancesParam{ServiceName: fmt.Sprintf("providers:%s:1.0.0:", servName),HealthyOnly: true,})if e != nil {return "instance not found, " + e.Error(), false}if len(instances) <= 0 {return "instance not found", false}return fmt.Sprintf("dubbo://%s:%d", instances[0].Ip, instances[0].Port), true}

完整代码

dubbo/nacos.go:

package dubboimport ("fmt""github.com/nacos-group/nacos-sdk-go/v2/clients""github.com/nacos-group/nacos-sdk-go/v2/clients/naming_client""github.com/nacos-group/nacos-sdk-go/v2/common/constant""github.com/nacos-group/nacos-sdk-go/v2/vo")var cliMap = make(map[string]naming_client.INamingClient)func init() {serverCfgs := []constant.ServerConfig{*constant.NewServerConfig("127.0.0.1", 6801, constant.WithContextPath("/nacos")),}cliMap["local"] = buildClient("local", serverCfgs)cliMap["dev"] = buildClient("develop", serverCfgs)cliMap["test"] = buildClient("test", serverCfgs)}func buildClient(env string, serverCfgs []constant.ServerConfig) naming_client.INamingClient {client, _ := clients.NewNamingClient(vo.NacosClientParam{ClientConfig: constant.NewClientConfig(constant.WithNamespaceId(env),constant.WithNotLoadCacheAtStart(true),),ServerConfigs: serverCfgs,},)return client}func SelectInstance(env, servName string) (string, bool) {cli, ok := cliMap[env]if !ok {return "client not found from " + env, false}instances, e := cli.SelectInstances(vo.SelectInstancesParam{ServiceName: fmt.Sprintf("providers:%s:1.0.0:", servName),HealthyOnly: true,})if e != nil {return "instance not found, " + e.Error(), false}if len(instances) <= 0 {return "instance not found", false}return fmt.Sprintf("dubbo://%s:%d", instances[0].Ip, instances[0].Port), true}

泛化调用

dubbo root 配置

var dubboRoot = cfg.NewRootConfigBuilder().SetProtocols(map[string]*cfg.ProtocolConfig{dubbo.DUBBO: {Params: map[string]interface{}{"getty-session-param": map[string]interface{}{"max-msg-len": 1024000,},},},}).Build()

泛化调用

func GenericInvoke(iName, method, env string, req []byte) DataResult {instance, ok := SelectInstance(env, iName)if !ok {return DataResult{Code:    "ERROR",Message: instance,}}cfg.Load(cfg.WithRootConfig(dubboRoot))refConf := cfg.ReferenceConfig{InterfaceName: iName,Cluster:       "failover",Protocol:      dubbo.DUBBO,Generic:       "true",Version:       "1.0.0",URL:           instance,}refConf.Init(dubboRoot)refConf.GenericLoad("dubbo-proxy")var args = utils.Unmarshal(req, &map[string]hessian.Object{})raw, err := refConf.GetrpcService().(*generic.GenericService).Invoke(context.Background(), method, nil, []hessian.Object{args})if err != nil {panic(err)}rawResult := raw.(map[interface{}]interface{})result := DataResult{Code:    rawResult["code"].(string),Message: rawResult["message"].(string),Data:    utils.ConvertAs(rawResult["data"], map[string]interface{}{}),}return result}

注意25-30行要根据业务自身的返回数据格式包装结果:

rawResult := raw.(map[interface{}]interface{})result := DataResult{Code:    rawResult["code"].(string),Message: rawResult["message"].(string),Data:    rawResult["data"],}

完整代码

dubbo/generic.go:

package dubboimport ("context""dubbo-proxy/utils"cfg "dubbo.apache.org/dubbo-go/v3/config""dubbo.apache.org/dubbo-go/v3/config/generic"_ "dubbo.apache.org/dubbo-go/v3/imports""dubbo.apache.org/dubbo-go/v3/protocol/dubbo"hessian "github.com/apache/dubbo-go-hessian2")var dubboRoot = cfg.NewRootConfigBuilder().SetProtocols(map[string]*cfg.ProtocolConfig{dubbo.DUBBO: {Params: map[string]interface{}{"getty-session-param": map[string]interface{}{"max-msg-len": 1024000,},},},}).Build()func GenericInvoke(iName, method, env string, req []byte) DataResult {instance, ok := SelectInstance(env, iName)if !ok {return DataResult{Code:    "ERROR",Message: instance,}}cfg.Load(cfg.WithRootConfig(dubboRoot))refConf := cfg.ReferenceConfig{InterfaceName: iName,Cluster:       "failover",Protocol:      dubbo.DUBBO,Generic:       "true",Version:       "1.0.0",URL:           instance,}refConf.Init(dubboRoot)refConf.GenericLoad("dubbo-proxy")var args = utils.Unmarshal(req, &map[string]hessian.Object{})raw, err := refConf.GetRPCService().(*generic.GenericService).Invoke(context.Background(), method, nil, []hessian.Object{args})if err != nil {panic(err)}rawResult := raw.(map[interface{}]interface{})result := DataResult{Code:    rawResult["code"].(string),Message: rawResult["message"].(string),Data:    utils.ConvertAs(rawResult["data"], map[string]interface{}{}),}return result}

提供 http 服务

dubbo/generic.go:

package webimport ("dubbo-proxy/dubbo""github.com/gin-gonic/gin""net/http")func Run() {router := gin.Default()router.POST("/:intf/:method", func(c *gin.Context) {intf := c.Param("intf")method := c.Param("method")env := c.Query("env")data, err := c.GetRawData()if err != nil {    panic(err)}res := dubbo.GenericInvoke(intf, method, env, data)res.Env = envc.JSON(http.StatusOK, res)})panic(router.Run(":7788"))}

启动

main.go:

package mainimport "dubbo-proxy/web"func main() {web.Run()}

效果

Golang基于泛化调用与Nacos实现Dubbo代理的方法是什么

以上就是关于“Golang基于泛化调用与Nacos实现Dubbo代理的方法是什么”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网GO频道。

您可能感兴趣的文档:

--结束END--

本文标题: Golang基于泛化调用与Nacos实现Dubbo代理的方法是什么

本文链接: https://www.lsjlt.com/news/355426.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Golang基于泛化调用与Nacos实现Dubbo代理的方法是什么
    这篇“Golang基于泛化调用与Nacos实现Dubbo代理的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Gol...
    99+
    2023-07-05
  • Golang基于泛化调用与Nacos实现Dubbo代理
    目录前言准备实现项目结构go.mod返回数据格式获取 nacos 元信息泛化调用提供 http 服务启动效果前言 由于工作中使用的 rpc 框架是 dubbo,经常需要调试不同环境的...
    99+
    2023-05-14
    Golang实现Dubbo代理 Golang Dubbo代理 Golang Dubbo
  • 基于SpringBoot的Dubbo泛化调用的实现代码
    目录1、服务端定义1.1 服务定义及实现1.2 服务提供者配置1.3 启动类1.4 pom文件2、消费端定义2.1 Dubbo配置类2.2 启动类2.3 pom文件3、 运行结果4 ...
    99+
    2024-04-02
  • golang基于errgroup实现并发调用的方法
    目录串行调用基于sync.WaitGroup实现简单的并发调用基于errgroup.Group实现并发调用总结串行调用 在用go编写web/rpc服务器的时候,经常会出现需要对下游多...
    99+
    2024-04-02
  • java类实例化调用的方法是什么
    Java类实例化调用的方法是通过使用类的构造方法来创建类的对象,并通过对象调用类的成员方法。具体步骤如下:1. 使用关键字`new`...
    99+
    2023-08-15
    java
  • recorder.js基于Html5录音功能的实现方法是什么
    这篇文章主要讲解了“recorder.js基于Html5录音功能的实现方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“recorder.js基于Ht...
    99+
    2024-04-02
  • Android开发基于ArcSoft实现人脸识别的方法是什么
    本篇内容主要讲解“Android开发基于ArcSoft实现人脸识别的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android开发基于ArcSoft实现人脸识别的方法是什么”吧!效果...
    99+
    2023-06-25
  • Java动态代理的原理及实现方法是什么
    本篇内容主要讲解“Java动态代理的原理及实现方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java动态代理的原理及实现方法是什么”吧!代理是指:某些场景下对象会找一个代理对象,来辅助...
    99+
    2023-07-02
  • Python基于域相关实现图像增强的方法是什么
    这篇文章主要讲解了“Python基于域相关实现图像增强的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python基于域相关实现图像增强的方法是什么”吧!介绍当在图像上训练深度神经...
    99+
    2023-06-26
  • Java/Go/Python/JS/C基数排序算法的原理与实现方法是什么
    这篇文章主要介绍“Java/Go/Python/JS/C基数排序算法的原理与实现方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java/Go/Python/JS/C基数排序算法的原理与实现...
    99+
    2023-07-05
  • SpringMVC MethodArgumentResolver的作用与实现方法是什么
    这篇文章主要介绍“SpringMVC MethodArgumentResolver的作用与实现方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“SpringMVC Meth...
    99+
    2023-07-06
  • C++中线程的原理与实现方法是什么
    这篇文章主要介绍“C++中线程的原理与实现方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++中线程的原理与实现方法是什么”文章能帮助大家解决问题。在C++中有多种实现线程的方式C++11...
    99+
    2023-07-05
  • JUC中wait与notify方法的实现原理是什么
    今天小编给大家分享一下JUC中wait与notify方法的实现原理是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1.O...
    99+
    2023-07-05
  • golang定时器Timer的用法和实现原理是什么
    本篇内容介绍了“golang定时器Timer的用法和实现原理是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!TimerTimer是一种单...
    99+
    2023-07-06
  • web前端模板的原理与实现方法是什么
    这篇文章主要讲解了“web前端模板的原理与实现方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“web前端模板的原理与实现方法是什么”吧!时下流行什么...
    99+
    2024-04-02
  • vue权限控制与管理的实现方法是什么
    本篇内容介绍了“vue权限控制与管理的实现方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、 菜单权限菜单权限:控制用户在系统中能...
    99+
    2023-07-05
  • vue各种权限控制与管理实现的方法是什么
    这篇“vue各种权限控制与管理实现的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue各种权限控制与管理实现的方...
    99+
    2023-07-05
  • Matlab中图像数字水印算法的原理与实现方法是什么
    本篇内容主要讲解“Matlab中图像数字水印算法的原理与实现方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Matlab中图像数字水印算法的原理与实现方法是什么”吧!基本原理图像数字水印...
    99+
    2023-07-06
  • R语言数据可视化tidyr与ggplot2多个变量分层展示的实现方法是什么
    本篇内容主要讲解“R语言数据可视化tidyr与ggplot2多个变量分层展示的实现方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“R语言数据可视化tidyr与ggplot2多个变量分层展...
    99+
    2023-06-25
  • 在Linux系统下使用Java API实现自然语言处理的方法是什么?
    自然语言处理(NLP)是人工智能领域中的一个重要分支,它研究人类语言的本质和规律,以及如何使用计算机模拟和处理语言。在当今信息爆炸的时代,NLP技术正被广泛应用于机器翻译、语音识别、文本分类、情感分析等领域。本文将介绍如何在Linux系统...
    99+
    2023-09-08
    自然语言处理 linux api
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作