RSS

Posts in 2021

  • 记一次对 dubbo-go-hessian2 的性能优化

    Tuesday, January 12, 2021 in Golang

    dubbo-go-hessian2 是一个用 Go 实现的 hessian 协议 v2.0 版本的序列化库。从项目名称里可以看到主要用在 dubbo-go 这个项目里。hessian 协议作为 dubbo 的默认协议,因此对性能有比较高的要求。 立项 譬如有网文 基于Go的马蜂窝旅游网分布式IM系统技术实践 把 dubbo-go 与其他 RPC 框架对比如下: Go STDPRC: Go 标准库的 RPC,性能最优,但是没有治理; RPCX: 性能优势 2*GRPC + 服务治理; GRPC: …

    更多

  • dubbo-go 中如何实现路由规则功能

    Tuesday, January 12, 2021 in Golang

    Let‘s Go! 最近在 Apache/dubbo-go(以下简称 dubbo-go )社区中,路由规则突然成了呼声最高的功能之一。那到底为什么需要路由规则? 先路由规则需要实现的功能: 路由规则( routing rule )是为了改变网络流量所经过的途径而修改路由信息的技术,主要通过改变路由属性(包括可达性)来实现。在发起一次 RPC 调用前起到过滤目标服务器地址的作用,过滤后的地址列表,将作为消费端最终发起 RPC 调用的备选地址。 试想该下场景:使用 dubbo-go 在生产环境上,排 …

    更多

  • dubbo-go 1.4.0

    Tuesday, January 12, 2021 in 版本发布

    得益于社区活跃的支持,2020 年 3 月 25 日 我们发布了一个让人兴奋的版本——dubbo-go v1.4.0。除了继续支持已有的 Dubbo 的一些特性外, dubbo-go 开始了一些自己的创新尝试。 这个版本,最大的意义在于,做了一些支持云原生的准备工作。比如说,社区在探讨了很久的 k8s 落地之后,终于拿出来了使用 k8s 作为注册中心的解决方案。 其次一个比较大的改进是–我们在可观测性上也迈出了重要的一步。在这之前,dubbo-go只提供了日志这么一个单一手段,内部的 …

    更多

  • 在dubbo-go中使用sentinel

    Monday, January 11, 2021 in Golang

    时至今日,Apache/dubbo-go(以下简称 dubbo-go )项目在功能上已经逐步对齐java版本,稳定性也在不同的生产环境得到了验证。社区便开始再服务治理、监控等方向发力。随着 1.2和1.3 版本发布, dubbo-go 新增了大量此类新feature。 今天我们聊一聊限流相关话题,此前dubbo-go已经支持了tps limit、execute limit 、hystrix 的内置filter,用户只要简单配置就能马上用上。但我们知道,在 java 的 dubbo 生态中,有一项 …

    更多

  • 无缝衔接 gRPC 与 dubbo-go

    Monday, January 11, 2021 in Golang

    最近我们 dubbo-go 社区里面,呼声很大的一个 feature 就是对 gRPC 的支持。在某位大佬的不懈努力之下,终于弄出来了。 今天我就给大家分析一下大佬是怎么连接 dubbo-go 和 gRPC 。 gRPC 先来简单介绍一下 gRPC 。它是 Google 推出来的一个 RPC 框架。gRPC是通过 IDL ( Interface Definition Language )——接口定义语言——编译成不同语言的客户端来实现的。可以说是RPC理论的一个非常非常标准的实现。 …

    更多

  • getty 开发日志

    Monday, January 11, 2021 in Golang

    0 说明 [getty][3]是一个go语言实现的网络层引擎,可以处理TCP/UDP/websocket三种网络协议。 2016年6月我在上海做一个即时通讯项目时,接口层的底层网络驱动是当时的同事sanbit写的,原始网络层实现了TCP Server,其命名规范学习了著名的netty。当时这个引擎比较简洁,随着我对这个项目的改进这个网络层引擎也就随之进化了(添加了TCP Client、抽象出了 TCP connection 和 TCP session),至2016年8月份(又添加 …

    更多

  • dubbo-go 中如何实现远程配置管理?

    Monday, January 11, 2021 in Golang

    之前在 Apache/dubbo-go(以下简称 dubbo-go )社区中,有同学希望配置文件不仅可以放于本地,还可以放于配置管理中心里。那么,放在本地和配置管理中心究竟有哪些不一样呢? 放在本地,每次更新需要重启,配置文件管理困难,无法做到实时更新即刻生效。此外,本地文件还依赖人工版本控制,在微服务的场景下,大大的增加了运维的成本与难度。 而配置管理中心提供了统一的配置文件管理,支持文件更新、实时同步、统一版本控制、权限管理等功能。 目标 基于以上几个背景,可以总结出以下目标 与 Dubbo …

    更多

  • dubbo-go tps limit

    Monday, January 11, 2021 in Golang

    前言 Apache Dubbo是由阿里开源的一个RPC框架,除了基本的RPC功能以外,还提供了一整套的服务治理相关功能。目前它已经是Apache基金会下的顶级项目。 而dubbogo则是dubbo的go语言实现。 最近在dubbogo的todo list上发现,它还没有实现TPS Limit的模块,于是就抽空实现了这个部分。 TPS limit实际上就是限流,比如说限制一分钟内某个接口只能访问200次,超过这个次数,则会被拒绝服务。在Dubbo的Java版本上,只有一个实现,就 …

    更多

  • Dubbo Go 中 metrics 的设计

    Monday, January 11, 2021 in Golang

    最近因为要在 Apache/dubbo-go(以下简称 dubbo-go )里面实现类似的这个 metrics 功能,于是花了很多时间去了解现在 Dubbo 里面的 metrics 是怎么实现的。该部分,实际上是被放在一个独立的项目里面,即 metrics ,见 https://github.com/flycash/dubbo-go/tree/feature/MetricsFilter 下 metrics 子目录。 总体上来说,Dubbo 的 metrics 是一个从设计到实现都非常优秀的模块, …

    更多

  • Dubbo Go 快速开始

    Monday, January 11, 2021 in Golang

    环境 Go编程环境 启动zookeeper服务,也可以使用远程实例 从服务端开始 第一步:编写 Provider 结构体和提供服务的方法 https://github.com/dubbogo/dubbo-samples/blob/master/golang/helloworld/dubbo/go-server/app/user.go 编写需要被编码的结构体,由于使用 Hessian2 作为编码协议,User 需要实现 JavaClassName 方法,它的返回值在dubbo中对应User类的类 …

    更多