1 Star 0 Fork 27

陈先乐/erpc

forked from andeyalee/erpc 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
client.go 1.20 KB
一键复制 编辑 原始数据 按行查看 历史
package main
import (
"time"
tp "github.com/henrylee2cn/teleport"
)
func main() {
go tp.GraceSignal()
tp.SetShutdown(time.Second*20, nil, nil)
var peer = tp.NewPeer(tp.PeerConfig{
SlowCometDuration: time.Millisecond * 500,
PrintBody: true,
})
defer peer.Close()
peer.RoutePush(new(Push))
var sess, rerr = peer.Dial("127.0.0.1:9090")
if rerr != nil {
tp.Fatalf("%v", rerr)
}
var reply []byte
for {
if rerr = sess.Pull(
"/group/home/test?peer_id=call-1",
[]byte("pull text"),
&reply,
tp.WithQuery("a", "1"),
).Rerror(); rerr != nil {
tp.Errorf("pull error: %v", rerr)
time.Sleep(time.Second * 2)
} else {
break
}
}
tp.Infof("test reply: %s", reply)
rerr = sess.Pull(
"/group/home/test_unknown?peer_id=call-2",
[]byte("unknown pull text"),
&reply,
tp.WithQuery("b", "2"),
).Rerror()
if tp.IsConnRerror(rerr) {
tp.Fatalf("has conn rerror: %v", rerr)
}
if rerr != nil {
tp.Fatalf("pull error: %v", rerr)
}
tp.Infof("test_unknown: %s", reply)
}
// Push controller
type Push struct {
tp.PushCtx
}
// Test handler
func (p *Push) Test(args *[]byte) *tp.Rerror {
tp.Infof("receive push(%s):\nargs: %s\nquery: %#v\n", p.Ip(), *args, p.Query())
return nil
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/chenxianle/erpc.git
git@gitee.com:chenxianle/erpc.git
chenxianle
erpc
erpc
v3.3.3

搜索帮助