16

Go net/rpc 库文档允许通过网络公开对象,无论是通过原始网络连接还是通过 HTTP。

HTTP 示例

arith := new(Arith)
rpc.Register(arith)
rpc.HandleHTTP()
l, e := net.Listen("tcp", ":1234")
if e != nil {
    log.Fatal("listen error:", e)
}
go http.Serve(l, nil)

原始 TCP 网络连接

arith := new(Arith)
rpc.Register(arith)
l, e := net.Listen("tcp", ":1234")
if e != nil {
    log.Fatal("listen error:", e)
}
go func() {
    for {
        conn, err := l.Accept()
        go rpc.ServeConn(conn)
    } 
}

要调用第一种类型的服务器,可以使用 rpc.DialHTTP("tcp", "127.0.0.1:1234") 和第二种类型 rpc.Dial("tcp", "127.0.0.1:1234") 将是用过的。

我的问题是这两者有什么不同?运行 HTTP 服务器与“原始网络连接”服务器有什么优缺点?可以通过 curl 或浏览器以某种方式使用 HTTP 执行 RPC 吗?HTTP 版本对跨语言 RPC 调用有用吗?

4

1 回答 1

10

这个问题的答案很好地描述了 HTTP 和原始 TCP 之间的区别(不直接涉及 Go)。

TCP 与 Http基准测试

它基本上说,由于 HTTP 是 TCP 之上的一个标准化层,如果您计划让您的代码有一个网页尝试发出请求并处理响应,那么您可能应该使用它,但如果您只关心速度,关闭 HTTP 并使用原始 TCP。

于 2013-10-28T16:43:16.073 回答