xrpc是一个基于消息队列的Go语言RPC框架,它提供了一种简单的方式来进行跨服务的远程过程调用。以下是一个使用xrpc的示例:
首先,你需要安装xrpc:
go get -u github.com/dubbogo/xrpc
然后,你可以使用xrpc来创建一个服务端和客户端:
服务端:
package main
import (
"context"
"fmt"
"github.com/dubbogo/xrpc"
)
type Greeter struct{}
func (g *Greeter) Hello(ctx context.Context, req string) (string, error) {
return "Hello " + req, nil
}
func main() {
s := xrpc.NewServer()
s.RegisterName("Greeter", new(Greeter))
s.Serve("tcp", ":8972")
}
客户端:
package main
import (
"context"
"fmt"
"github.com/dubbogo/xrpc"
)
func main() {
c := xrpc.NewClient()
var greeter Greeter
c.UseService(&greeter)
resp, err := greeter.Hello(context.Background(), "world")
if err != nil {
panic(err)
}
fmt.Println(resp)
}
在这个例子中,我们定义了一个名为Greeter
的服务,它有一个Hello
方法。服务端启动后,客户端连接到服务端,并调用Hello
方法。
注意:以上代码仅为示例,实际使用时需要根据具体的消息队列实现和配置进行相应的调整。