Java 版本Thrift Server 分析
来源:互联网 发布:淘宝店铺利益点介绍 编辑:程序博客网 时间:2024/06/07 23:08
这次基于Thrift-0.9.1版本进行分析,不同版本可能实现有所差别。
这个版本的Thrift提供了5个不同模型的Server,这些Server具体怎么使用可参考这篇文章:Thrift入门及Java实例演示。
1 TSimpleServer
单线程阻塞模型,单线程(由main线程驱动)负责接受连接(阻塞),读取输入参数(阻塞),处理业务逻辑,写入输出结果(阻塞)。
2 TNonblockingServer
单线程非阻塞模型,单线程(由业务线程驱动)负责接受连接(非阻塞),读取输入参数(非阻塞),处理业务逻辑(单线程),写入输出结果(非阻塞)。
3 TThreadPoolServer
多线程阻塞模型,主线程(由main线程驱动)负责接受连接(阻塞),之后分派给子线程(业务线程)来读取输入参数(阻塞),处理业务逻辑,写入输出结果(阻塞)。
4 THsHaServer
多线程非阻塞模型,单线程(由main线程驱动)负责接受连接(非阻塞),读取输入参数(非阻塞),处理业务逻辑(多线程),写入输出结果(非阻塞)。
5 TThreadedSelectorServer
多线程非阻塞模型,单线程(由业务线程驱动)负责接受连接(非阻塞),多线程非阻塞的读取输入参数,多线程处理业务逻辑,多线程非阻塞的写入输出结果。
注1:按代码的说明来看,在多核情况下,5的性能最高,我没实测过,不确定是不是这样的,:-)。
注2:其中应用2,4,5的Server时,传输层必须选择TFramedTransport(包有长度信息,在非阻塞读取数据时,能保证接收数据的完整性),否则接受数据会出错.
0 0
- Java 版本Thrift Server 分析
- Thrift java server 模式分析
- Java版本各种Thrift Server比较
- Thrift Java Server attentions
- Java Thrift Server Sample
- Thrift c++ server & java client配置
- FaceBook thrift组件java组件分析
- [Thrift分析]
- Thrift server端的几种工作模式分析
- Thrift server端的几种工作模式分析
- 由浅入深了解Thrift(三)——Thrift server端的几种工作模式分析
- 由浅入深了解Thrift(三)——Thrift server端的几种工作模式分析
- 由浅入深了解Thrift(三)——Thrift server端的几种工作模式分析
- thrift的TTransport连接池注意事项[Java版本说明]
- Java版的各种Thrift server实现的比较
- thrift C++做server, C++,python, java做Client例子
- Java版的各种Thrift server实现的比较
- thrift C++做server, C++,python, java做Client例子
- oozie——mapreduce、mysql2hdfs、hdfs2hive
- Android 特殊界面效果之——透明界面
- 用C/C++创建windows服务程序
- [Cocos2D-x For WP8]Sprite精灵
- Oracle Database Server Messages(二) .
- Java 版本Thrift Server 分析
- 清除myeclipse中的web browser里的历史记录
- 谈.Net委托与线程——解决窗体假死
- extjs 跨域问题
- php正则表达式总结
- Nashorn为Java与JavaScript搭起一座桥
- 解决android 4.3 的user版本没法启动
- qsort和sort的区别
- tomcat startup.sh提示java.lang.OutOfMemoryError: PermGen space