微服务协议选择

现在可用于微服务的协议很多,http+Json、Http+xml、thrift、Protocol Buffer。具体采用哪种方法,我觉得要考虑几个方面:

  • 兼容性,支持多少语言。
  • 向后兼容性。当被调用方升级后,比如增加或者减少了调用方不用的字段,调用方是否需要升级,能否方便地修改?
  • 可读性。可读性对程序处理没有影响,但如果出了问题,人如果无法一眼看出来,会影响排查效率。
  • 横向扩展性。是否有良好扩展能力,有成熟的负载均衡技术可选。
  • 性能。这个不用多说了。

综合考虑后,我觉得目前还是Http+json。

  • 兼容性,不用说了,有不支持的吗?
  • 向后兼容。很多json 序列化、反序列化工具包,去掉一个增加一个都不会引起错误吧?
  • 可读性。比xml差点,但不怎么影响阅读,特别是格式好的话。
  • 横向扩展性。nginx、F5 无论硬件还是软件,都有丰富的负载均衡可选。
  • 性能。低于thrift和Protocol Buffer。不过在实际业务中,这部分带来的性能损耗,远低于实际业务操作需要的损耗,除非你业务啥都不干,这样的业务也没啥意义吧?thrift声称单机能到数万QPS,不过你的业务能单机达到数万QPS吗?http+json大约5000QPS,也足够用了吧?
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值