[Golang]简单Rpc

服务端

package main

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

//go对rpc有三个级别的支持: TCP、HTTP、 JsonRPC
//go的rpc只支持go语言开发的服务器客户端之间的交互

type Params struct {
	Width, Height int
}

type Rect struct{}

//1. 方法必须是导出的
//2. 必须有两个导出类型的参数,第一个是接受参数,第二个是返回给客户端的参数,必须是指针类型
//3. 方法必须有一个返回值err

func (r *Rect) Area(p Params, ret *int) error {
	*ret = p.Width * p.Height
	return nil
}

func (r *Rect) Perimeter(p Params, ret *int) error {
	*ret = (p.Width + p.Height) * 2
	return nil
}

func main() {
	var rect Rect
	if err := rpc.Register(&rect); err != nil {
		fmt.Println(err)
		return
	}
	rpc.HandleHTTP()
	err := http.ListenAndServe(":8080", nil)
	if err != nil {
		fmt.Println(err)
		return
	}
}

客户端

package main

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

func TestRPC(t *testing.T) {

	//1. 连接远程rpc服务
	rpc, err := rpc.DialHTTP("tcp", "127.0.0.1:8080")

	if err != nil {
		fmt.Println(err)
		return
	}
	ret := 0

	//2. 调用远程方法(type.method,params,result)
	err = rpc.Call("Rect.Area", Params{50, 100}, &ret)
	if err != nil {
		fmt.Println(err)
		return
	}

	fmt.Printf("result:%d", ret)

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值