Go 快速开始
快速开始
通过一个 hellowworld
例子带领大家快速上手Dubbo-go框架。
协议:Dubbo
编码:Hessian2
注册中心:Zookeeper
- Go编程环境
- 启动zookeeper服务,也可以使用远程实例
- 编写需要被编码的结构体,由于使用
Hessian2
作为编码协议,User
需要实现JavaClassName
方法,它的返回值在dubbo中对应User类的类名。
- 编写业务逻辑,
UserProvider
相当于dubbo中的一个服务实现。需要实现Reference
方法,返回值是这个服务的唯一标识,对应dubbo的beans
和path
字段。
type UserProvider struct {
}
func (u *UserProvider) GetUser(ctx context.Context, req []interface{}) (*User, error) {
println("req:%#v", req)
rsp := User{"A001", "hellowworld", 18, time.Now()}
println("rsp:%#v", rsp)
return &rsp, nil
}
return "UserProvider"
}
- 注册服务和对象
func init() {
config.SetProviderService(new(UserProvider))
// ------for hessian2------
hessian.RegisterPOJO(&User{})
}
第二步:编写主程序
- 引入必需的dubbo-go包
- main 函数
func main() {
config.Load()
}
- 参考 log 和 编辑配置文件。
registries
结点下需要配置zk的数量和地址services
结点下配置服务的具体信息,需要配置interface
配置,修改为对应服务的接口名,服务的key对应第一步中Provider
的Reference
返回值
- 把上面的两个配置文件分别配置为环境变量
export CONF_PROVIDER_FILE_PATH="xxx"
export APP_LOG_CONF_FILE="xxx"
第一步:编写客户端 Provider
参考服务端第一步的第一点。
- 注册服务和对象
hessian.RegisterPOJO(&User{})
}
- 引入必需的dubbo-go包
import (
hessian "github.com/apache/dubbo-go-hessian2"
"github.com/apache/dubbo-go/config"
_ "github.com/apache/dubbo-go/registry/protocol"
_ "github.com/apache/dubbo-go/common/proxy/proxy_factory"
_ "github.com/apache/dubbo-go/filter/impl"
_ "github.com/apache/dubbo-go/cluster/cluster_impl"
_ "github.com/apache/dubbo-go/cluster/loadbalance"
_ "github.com/apache/dubbo-go/registry/zookeeper"
_ "github.com/apache/dubbo-go/protocol/dubbo"
)
- main 函数
第三步:编写配置文件并配置环境变量
- 参考 log 和 编辑配置文件。
主要编辑以下部分:
registries
结点下需要配置zk的数量和地址references
结点下配置服务的具体信息,需要配置interface
配置,修改为对应服务的接口名,服务的key对应第一步中Provider
的Reference
返回值
- 把上面的两个配置文件费别配置为环境变量,为防止log的环境变量和服务端的log环境变量冲突,建议所有的环境变量不要做全局配置,在当前起效即可。
export CONF_CONSUMER_FILE_PATH="xxx"