rpcx服务框架浅析9-序列化

RPCX分布式服务框架主要致力于提供高性能和透明化的RPC远程服务调用。

RPCX消息序列化

      RPC是RPCX框架中最核心的一种高性能、高吞吐量的远程调用方式,可以称之为多路复用的TCP长连接调用,简单的说:

  • 长连接:避免了每次调用新建TCP连接,提高了调用的响应速度
  • 多路复用:单个TCP连接可交替传输多个请求和响应的消息,降低了连接的等待闲置时间,从而减少了同样并发数下的网络连接数,提高了系统吞吐量。

      序列化对于远程调用的响应速度、吞吐量、网络带宽消耗等同样也起着至关重要的作用,是我们提升分布式系统性能的最关键因素之一。

序列化/反序列化一般位置:

  1. Client向Server发送命令时,在Send前将消息结构体序列化为二进制数据。
  2. Server在收到Client命令数据后,将原始网络流数据反序列化为内部使用消息结构体。

在RPCX中支持多种序列化方式:

  1. JSON序列化。
  2. ProtoBuffer序列化。
  3. MsgPack序列化。
  4. Thrift序列化。

RPCX序列化时将输入参数进行序列化,Encode之后的数据放入到Payload中。

序列化/反序列化例子:

func MsgCodec(c codec.Codec) error {
	in:=&defines.CmdIn{
		Param:"12345",
	}
	//对CmdIn进行序列化
	encData,err := c.Encode(in)
	if err!=nil{
		fmt.Println(err)
		return err
	}

	//反序列化
	out:=&defines.CmdIn{}
	err = c.Decode(encData,out)
	if err!=nil{
		fmt.Println(err)
		return err
	}

	fmt.Printf("%v len:%d dec:%s\n",reflect.Indirect(reflect.ValueOf(c)).Type().Name(),len(encData),out)
	return nil
}
MsgCodec(&codec.JSONCodec{})
MsgCodec(&codec.MsgpackCodec{})

系列文章

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值