Golang rpc编码协议替换

前言
接下将rpc自带的Gob编码协议替换为json编码协议
服务端协议替换
1.rpc.ServeCodec 支持指定编码协议
2.jsonrpc.NewServerCodec 使用json编码协议
package main

import (
	"net"
	"net/rpc"
	"net/rpc/jsonrpc"
)

type Hello struct {
}

func (h *Hello) Talk(request string, response *string) error {
	*response = "hello_" + request
	return nil
}

func main() {
	listen, _ := net.Listen("tcp", ":8083")
	rpc.RegisterName("hello", &Hello{})
	for {
		accept, _ := listen.Accept()
		go func() {
			//rpc.ServeConn(accept)
			/**
			1.rpc.ServeCodec 支持指定编码协议
			2.jsonrpc.NewServerCodec 使用json编码协议
			*/
			rpc.ServeCodec(jsonrpc.NewServerCodec(accept))
		}()
	}
}

客户端协议替换
1.没有使用rpc.Dial 是因为其得到的客户端是基于Gob编码的
2.rpc.NewClientWithCodec 创建指定编码协议的客户端
3.jsonrpc.NewClientCodec 设置json编码协议
package main

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

func main() {
	// 没有使用rpc.Dial 是因为其得到的客户端是基于Gob编码的
	dial, _ := net.Dial("tcp", ":8083")
	/**
	rpc.NewClientWithCodec 创建指定编码协议的客户端
	jsonrpc.NewClientCodec 设置json编码协议
	*/
	client := rpc.NewClientWithCodec(jsonrpc.NewClientCodec(dial))
	var res *string
	client.Call("hello.Talk", "xie", &res)
	fmt.Println(*res) //hello_xie
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值