ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

net/rpc

2022-07-06 16:34:15  阅读:154  来源: 互联网

标签:err nil res req rpc net


在网上找grpc学习资料的时候,发先go语言自带一个rpc框架,不过只支持go语言,赶紧过来看看。

net/rpc

这里简要记了,详细的内容在go源码的注释里面。

注意事项:

  • Go的RPC只支持go写的系统
  • Go RPC的函数有特殊要求
    • 首字母必须大写
    • 必须有两个参数,一个入参,一个是返回的参数,第二个参数必须是指针类型的,函数还要有一个error。

服务端

package main

import (
	"fmt"
	"net"
	"net/http"
	"net/rpc"
)

type Server struct {
}

//请求
type Req struct {
	NumOne int
	NumTwo int
}

//返回
type Res struct {
	Num int
}

func (s *Server) Add(req Req, res *Res) error {
	res.Num = req.NumOne + req.NumTwo
	return nil
}

func main() {
	rpc.Register(new(Server))
	rpc.HandleHTTP()
	l, err := net.Listen("tcp", ":8888")
	if err != nil {
		fmt.Println(err.Error())
	}
	http.Serve(l, nil)
}

我们将server注册起来,然后跑在8888端口上。server有一个函数Add,就是将入参的两个值加到一起赋给出参。

客户端

package main

import (
	"fmt"
	"net/rpc"
)

type Req struct {
	NumOne int
	NumTwo int
}

type Res struct {
	Num int
}

func main() {
	req := Req{NumOne: 1, NumTwo: 2}
	var res Res
	client, err := rpc.DialHTTP("tcp", "localhost:8888")
	if err != nil {
		fmt.Println(err.Error())
	}
	client.Call("Server.Add", req, &res)
	fmt.Println(res)
}

客户端调用服务端的这个函数,结果如下:

image-20220706153255121

使用Call()方法是同步方式的调用,使用Go方法可以是实现异步调用

修改服务端为:

func (s *Server) Add(req Req, res *Res) error {
	time.Sleep(5 * time.Second)
	res.Num = req.NumOne + req.NumTwo
	return nil
}

我们让add函数等5秒再返回

客户端修改为这样:

func main() {
	req := Req{NumOne: 1, NumTwo: 2}
	var res Res
	client, err := rpc.DialHTTP("tcp", "localhost:8888")
	if err != nil {
		fmt.Println(err.Error())
	}
	ca := client.Go("Server.Add",req,&res,nil)
	for {
		select {
		case <-ca.Done:
			fmt.Println(res)
			return
		default:
			time.Sleep(time.Second)
			fmt.Println("哈哈啊哈")
		}
	}
}

然后结果是

image-20220706160937737

标签:err,nil,res,req,rpc,net
来源: https://www.cnblogs.com/yumingkuan/p/16451317.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有