一直以来比较关心高性能通讯模块的设计,最近看到两篇好文,由此想到曾经参与的几个通讯模块的设计和实现,跟大家分享思路。
首先来分享好文:
http://agapple.iteye.com/blog/859052
这一篇讲得是google protobuf协议和其他序列化的性能测试。朋友们看了一定会砰然心动,protobuf如此之高的通讯效率当然是求之不得。新浪微博IM各模块之间也采用protobuf作为通讯协议,TimYang写过文章比较google protobuf和facebook Thrift之间的性能。也证实了protobuf还是好东东。加之MINA可以很好的和此类通讯协议结合,无非是编解码嘛,一行伪代码搞定:
mySocketAcceptor.getFilterChain().addFirst("protobuf", new ProtocolCodecFilter(ProtobufCodecFactory.newInstance(MyProBufPacket.getDefaultInstance())));
http://www.wuzesheng.com/?p=1258
第二篇是讲解为什么protobuf有如此效率,大家慢慢品味吧。
优点:
使用protobuf二进制协议高效的传输,在通讯压力大得场合非常合适。
缺点:
私有协议,如果是基于公共协议的中间件。想推广使用,有一定阻力。
还是那句话:场景和应用决定构架,技术只是手段,客户的需求才是根本。
引用TimYang的话作为结尾
一个构架师的经验主要在于经历了多少场景,即解决了特定场景下的要求的经验
以及试错过程中积累的经验和对各种主流技术的掌握
分享到:
相关推荐
protobuf library C++库
google protobuf 最新源代码google protobuf 最新源代码google protobuf 最新源代码google protobuf 最新源代码google protobuf 最新源代码google protobuf 最新源代码google protobuf 最新源代码google protobuf ...
protobufDemo protobuf例程protobufDemo protobuf例程protobufDemo protobuf例程protobufDemo protobuf例程protobufDemo protobuf例程protobufDemo protobuf例程protobufDemo protobuf例程
protobuf 建立proto文件的依赖编译关系
protobuf-all-3.5.1.tar.gz protobuf-cpp-3.5.1.tar.gz protobuf-csharp-3.5.1.tar.gz protobuf-java-3.5.1.tar.gz protobuf-js-3.5.1.tar.gz protobuf-objectivec-3.5.1.tar.gz protobuf-php-3.5.1.tar.gz protobuf...
protobuf
Google Protobuf在Linux Socket通讯中的应用.pdf
protobuf2.5.jar 可直接使用
android,java,protobuf,
protobuf-3.3.0
protocolbuffer (以下简称PB) 是google 的一种数据交换的格式,它独立于语言,独立于平台。...由于它是一种二进制的格式,比使用 xml 进行数据交换快许多。可以把它用于分布式应用之间的数据通信...protobuf-3.6.1.tar.gz
这是用于读取和写入protobuf消息的Redis模块(仅支持Protobuf版本3,即syntax="proto3"; )。 注意:为了使用此模块,您应该阅读Protobuf文档以了解如何定义protobuf消息。 注意:我不是母语人士。 因此,如果文档...
unity通讯之protobuf文件传输,protobuf3序列化与反序列化。
赠送jar包:protobuf-java-3.11.4.jar; 赠送原API文档:protobuf-java-3.11.4-javadoc.jar; 赠送源代码:protobuf-java-3.11.4-sources.jar; 赠送Maven依赖信息文件:protobuf-java-3.11.4.pom; 包含翻译后的API...
unity3d应用Protobuf实现Socket通信
生成protobuf协议工具
protocolbuffer(以下简称PB)是google 的一种数据交换的格式,它独立于语言,独立于平台。...由于它是一种二进制的格式,比使用 xml 进行数据交换快许多。可以把它用于分布式应用...Source code (protobuf-3.5.0.tar.gz)
包含protobuf2.6.1编译好的lib和exe,把lib文件放到c:\windows即可。并带有protobuf的windows和linux的源码包。
protobuf for vs2015 VS2015的protobuf插件
protobuf支持lua的完整包