go的rpc调用?

作者站长头像
站长
· 阅读数 4
    service := new(base.ServiceA)
    rpc.Register(service) //注册RPC服务
    rpc.HandleHTTP()      //基于HTTP协议
    l, e := net.Listen("tcp", ":9091")
    if e != nil {
        log.Fatalln("listen error", e)
    }
    http.Serve(l, nil)

rpc直接注册服务

rpc服务是注册到哪了?

是下面的http.Serve()?

没看到绑定,求助分析下

client, err := rpc.DialHTTP("tcp", "127.0.0.1:9091")
    if err != nil {
        log.Fatalln("dialing :", err)
    }
    args := &Args{10, 20}
    var reply int
    err = client.Call("ServiceA.Add", args, &reply)
    if err != nil {
        log.Fatal("ServiceA.Add error:", err)
    }

客户单直接监听服务,call调用,是怎么发现的

服务发现是在服务端的rpc服务,rpc服务与http的服务关系?

回复
1个回答
avatar
test
2024-06-28

RPC服务是通过rpc.Register(service)注册到内部的RPC服务注册表里的。http.Serve(): 不全是。http.Serve()是用来启动HTTP服务器的,而rpc.HandleHTTP()是把RPC服务注册到HTTP处理器里,这样,HTTP服务器接收到请求时候,它会把RPC相关的请求交给RPC服务处理。绑定是通过rpc.Register(service)和rpc.HandleHTTP()隐式完成的。客户端通过rpc.DialHTTP连接到服务器,然后通过服务器地址(127.0.0.1:9091)找到它,之后客户端通过client.Call调用服务器上注册的RPC方法,客户端需要知道服务器的地址才能连answer image

回复
likes
适合作为回答的
  • 经过验证的有效解决办法
  • 自己的经验指引,对解决问题有帮助
  • 遵循 Markdown 语法排版,代码语义正确
不该作为回答的
  • 询问内容细节或回复楼层
  • 与题目无关的内容
  • “赞”“顶”“同问”“看手册”“解决了没”等毫无意义的内容