Go日记——反向RPC

代码 代码 1266 人阅读 | 0 人回复

<
背景

通常的RPC是基于C/S结构,RPC的服务端对应网络的服务器,RPC的客户端也对应网络客户端。但是对于一些特殊场景,比如在公司内网提供一个RPC服务,但是在外网无法链接到内网的服务器。这种时候我们可以参考类似反向代理的技术,首先从内网主动链接到外网的TCP服务器,然后基于TCP链接向外网提供RPC服务。
声明接口

  1. type HelloService struct {}
  2. func (p *HelloService) Hello(request string, reply *string) error {
  3.     *reply = "hello:" + request
  4.     return nil
  5. }
复制代码
反向RPC服务

  1. func main() {
  2.     rpc.Register(new(HelloService))
  3.     for {
  4.         conn, _ := net.Dial("tcp", "localhost:1234")
  5.         if conn == nil {
  6.             time.Sleep(time.Second)
  7.             continue
  8.         }
  9.         rpc.ServeConn(conn)
  10.         conn.Close()
  11.     }
  12. }
复制代码
反向RPC的内网服务将不再主动提供TCP监听服务,而是首先主动链接到对方的TCP服务器。然后基于每个建立的TCP链接向对方提供RPC服务。
RPC客户端

RPC客户端则需要在一个公共的地址提供一个TCP服务,用于接受RPC服务器的链接请求:
[code]func main() {    listener, err := net.Listen("tcp", ":1234")    if err != nil {        log.Fatal("ListenTCP error:", err)    }    clientChan := make(chan *rpc.Client)    go func() {        for {            conn, err := listener.Accept()            if err != nil {                log.Fatal("Accept error:", err)            }            clientChan
1、本网站属于个人的非赢利性网站,转载的文章遵循原作者的版权声明,如果原文没有版权声明,按照目前互联网开放的原则,我们将在不通知作者的情况下,转载文章;如果原文明确注明“禁止转载”,我们一定不会转载。如果我们转载的文章不符合作者的版权声明或者作者不想让我们转载您的文章的话,请您发送邮箱:Cdnjson@163.com提供相关证明,我们将积极配合您!
2、本网站转载文章仅为传播更多信息之目的,凡在本网站出现的信息,均仅供参考。本网站将尽力确保所提供信息的准确性及可靠性,但不保证信息的正确性和完整性,且不对因信息的不正确或遗漏导致的任何损失或损害承担责任。
3、任何透过本网站网页而链接及得到的资讯、产品及服务,本网站概不负责,亦不负任何法律责任。
4、本网站所刊发、转载的文章,其版权均归原作者所有,如其他媒体、网站或个人从本网下载使用,请在转载有关文章时务必尊重该文章的著作权,保留本网注明的“稿件来源”,并自负版权等法律责任。
回复 关闭延时

使用道具 举报

 
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则