Apache Dubbo-go, a Dubbo implementation written in Golang, is born to bridge the gap between Java/Dubbo and Go/X. Please visit our Dubbo official website for the quick start and documentation.
Dubbo-go has supported many RPC protocol, like Triple, Dubbo JSONRPC, gRPC, HTTP, HTTP2.
- Triple is the supported protocol of Dubbo3 ecology, and is gRPC extended protocol based on HTTP2, which is compatible with gRPC service.In other words, on the basis of gRPC‘s reliable invocation, it adds Dubbo’s service governance capability.
- Dubbo protocol is tradition Dubbo ecology protocol, which is capitable with dubbo 2.x, and is a good choice for cross-language invocation between GO and Java old service.
- HTTP support：As you can see in the figure above, you can invoke Triple/Dubbo service using HTTP protocol through dubbo-go-pixiu gateway.
Service Governance Capability.
- Registry: Nacos, Zookeeper, ETCD, Polaris-mesh, Consul.
- ConfigCenter: Nacos, Zookeeper
- Cluster Strategy: Failover, Failfast, Failsafe/Failback, Available, Broadcast, Forking
- Load Balance: AdaptiveService, Random, RoundRobin, LeastActive, ConsistentHash
- Filter: Echo, Hystrix, Token, AccessLog, TpsLimiter, ExecuteLimit, Generic, Auth/Sign, Metrics, Tracing, Active, Seata, Sentinel
- Generic Invoke
- Monitor: Prometheus
- Tracing: Jaeger, Zipkin
- Router: Dubbo3 Router
- imports-formatter formatting dubbo-go project import code block.
- dubbo-go-cli dubbo-go command line tools, by which you can define your own request pkg and gets rsp struct of your server, test your service as telnet and generate hessian.POJO register method body.
- dubbo-go-cli-v2 new dubbo-go line tools, you can get services from register center, create a demo , create application templates, one-click installation of protoc-gen-go-triple and imports-formatter tools,and has the same features with dubbo-go-cli.
- protoc-gen-go-triple tripe protocol pb file generation tool.
- protoc-gen-dubbo3grpc dubbo3 grpc pb file generation tool.
If you want to know more about dubbogo tools, please visit https://github.com/apache/dubbo-go/blob/master/dubbogo-cli and read its readme carefully.
- Windows: File > Settings > Plugins > Browse repositories... > Search for “Dubbo Go” > Install Plugin
- MacOS: Preferences > Settings > Plugins > Browse repositories... > Search for “Dubbo Go” > Install Plugin
- Download the latest release and install it manually using Preferences > Plugins > Install plugin from disk...
- From official jetbrains store from download
Empty Project Template Middleware
If you want to know more about dubbogo Intellij Plugin, please visit https://gitee.com/changeden/intellij-plugin-dubbo-go-generator and read its readme carefully.
- Dubbo Ecosystem Entry - A GitHub group
dubbo to gather all Dubbo relevant projects not appropriate in apache group yet.
- dubbo-go-pixiu - A dynamic, high-performance API gateway solution for Dubbo and Http services.
- dubbo-go-samples - Samples for Apache Dubbo-go.
- dubbo-getty - A netty like asynchronous network I/O library which supports tcp/udp/websocket network protocol.
- triple - A golang network package that based on http2, used by Dubbo-go 3.0.
- dubbo-go-hessian2 - A golang hessian library used by Apache/dubbo-go.
- gost - A go sdk for Apache Dubbo-go.
Please visit CONTRIBUTING for details on submitting patches and the contribution workflow.
Please use the bug report template to report bugs, use the enhancement template to provide suggestions for improvement.
If you are using apache/dubbo-go and think that it helps you or want to contribute code for Dubbo-go, please add your company to the user list to let us know your needs.
See more user cases
Apache Dubbo-go software is licenced under the Apache License Version 2.0. See the LICENSE file for details.