这个项目最早(2008年)是用于一个网络游戏的Cache Server,以及一个电子商务的Web Session服务。后来不断增加新的功能,除了Java还支持C#,到现在已经可以用它来开发网络游戏的服务器。等过些日子我还会开源网络游戏的服务器源码。
关于性能,当时后台相应请求的效率是每秒10W次,现在我在自己的笔记本上测,只有一个客户端与服务器都在一个物理机上(CPU: i7-3610QM; RAM: 8G; OS: Win7-64),每秒相应12000个请求。
tatala-client-csharp已经上传,同样在笔记本上测试,一个c#客户端一个Java服务端都在一台机器上,每秒响应22000个请求。c#客户端除了性能测试的例子还有一个演示Server推送的聊天室例子。
Tatala最大的特点是简单,性能是第二考虑能够满足大部分应用就行。因为性能可以通过增加机器得到提升,而代码简单意味着雇更少的人更快的开发。老板省钱,程序员轻松才是最重要的。
开源地址:
https://github.com/zijan/Tatala
下面是简单介绍。
概述
Tatala是一个简单易用的RPC中间件,并且跨语言跨平台。它将调用方法转变成字节数组(包括被调用类名,目标方法名,参数序列和返回值),在socket基础上实现客户端和服务器之间的互相通信。
目前,Tatala支持Java的客户端与服务器端,和C#的客户端。
特性
* 简单易用可以快速开发和建立网络组件
* 跨语言跨平台
* 高性能和分布式
* 传输协议为短小精悍的二进制
* 支持长短两种socket 连接
* 客户端与服务器端多线程处理
* 支持异步请求
* 对于大数据支持压缩传输
* 能够用于跨语言的远程方法调用RPC,高性能的缓存服务器,分布式的消息服务,多人在线游戏服务器,等等
快速开始
下载tatala.jar 包含在你项目的classpath中。
简单是Tatala第一考虑因素,所以用它建立RPC的方式,让开发者感觉就像调用本地普通方法一样简单。不用考虑网络,线程这些东西。
现在举一个例子,假如我们有个服务器端的服务TestManager接口 和 TestManagerImpl实现类。
TestManager.java
public interface TestManager {
public String sayHello(int Id, String name);
}
TestManagerImpl.java
public class TestManagerImpl implements TestManager{
public String sayHello(int Id, String name) {
return "["+Id+"]"+"Hello "+name+" !";
}
}
我们还需要在服务端建立一个socket服务类来部署我们的业务逻辑,在这个例子中socket服务监听端口是10001。
TestServer.java
public class TestServer {
public static void main(String args[]) {
int listenPort = 10001;
int poolSize = 10;
AioSocketServer server = new AioSocketServer(listenPort, poolSize);
server.start();
}
}
然后客户端的代码类似这样:
EasyClient.java
public class EasyClient {
private static TransferObjectFactory transferObjectFactory;
private static TestManager manager;
public static void main(String[] args) {
transferObjectFactory = new TransferObjectFactory("test1", true);
transferObjectFactory.setImplClass("TestManagerImpl");
manager = (TestManager)ClientProxyFactory.create(TestManager.class, transferObjectFactory);
int Id = 18;
String name = "JimT";
String result = manager.sayHello(Id, name);
System.out.println("result: "+result);
}
}
当然我们需要把接口类(TestManager.class) 加入到客户端的classpath里。客户端还需要一个配置文件controller.xml列出要被客户端调用的服务器端程序的IP, port和连接名。 (注意连接名“test1”)
controller.xml
<connections>
<connection>
<hostIp>127.0.0.1</hostIp>
<hostPort>10001</hostPort>
<timeout>5000</timeout>
<retryTime>3</retryTime>
<name>test1</name>
</connection>
</connections>
这就是所有代码和配置对于建立一个Tatala RPC。
更多例子请看教程。
Tatala-中文教程
传输协议
在客户端把调用的方法信息设置到transfer object里, Tatala把transfer object转换成字节数组并且发送给服务器。在服务器端把接收到的字节数组再还原成包含调用信息的transfer object。包括被调用类名,目标方法名,参数信息和返回类型等。Tatala 执行器获得调用信息执行目标方法。
支持类型
Tatala支持的参数和返回类型:
bool,byte,short,chat,int,long,float,double,Date,String,
byte[],int[],long[],float[],double[],String[],Serializable,WrapperClass
其它描述
需要JDK1.7,因为使用了Java AIO。
第三方类库包括XSteam,Log4j。
License
Apache License Version 2.0
分享到:
相关推荐
基于MBD开发手册的《Application Modeling Guideline:辅助驾驶系统中的数学模型设计与应用》,Application Modeling Guideline 文档57页 基于MBD开发手册包含: 1. MBD概述:文档可能会介绍MBD的基本概念,解释为什么它在辅助驾驶系统开发中至关重要。 MBD允许工程师使用数学模型来描述系统行为,这有助于早期发现问题,减少硬件原型制作的需求。 2. 工具选择:在辅助驾驶开发中,常用的MBD工具有MATLAB Simulink、MathWorks的Simulink Design Verifier、Vector的CANoe等。 文档可能涵盖这些工具的特点和适用场景,帮助开发者选择合适的工具。 3. 模型设计:MBD的核心是模型设计,文档会详细说明如何创建和组织模型结构,包括输入 输出接口定义、状态机设计、算法实现等。 对于辅助驾驶系统,这可能涉及到视觉处理、传感器融合、路径规划、决策制定等多个模块。 4. 仿真与验证:MBD工具支持动态仿真,开发者可以运行模型以验证其功能。 文档会介绍如何设置仿真条件,进行时序分析,以及如
springboot学生答题练习在线平台,含有完整的源码和报告文档
动力电池用导热硅胶材料研制及性能研究.pdf
2022年12月50430考试真题
输电线路单相接地故障测距:不同短路时刻与位置对双端测距法的影响分析,输电线路单相接地测距 搭建如图1所示的35kV输电网模型,输电侧发电机出口电压10.5kV经过升压变压器变至38.5kV,受电侧经降压变压器降压至6.6kV。输电线路全长100km,架空线路线路正负序参数为:,,,,,。经过计算可得行波线模速度:。通过故障模块设置A相不同短路时刻与过渡电阻发生单相接地,并根据双端行波测距原理进行故障测距,每次设置故障发生点距离首端距离分别为20km、40km、60km、80km,模型仿真步长为秒。 (1)短路时刻对故障测距的影响 分别设置A相电压正峰值、负峰值、过零值以及任意时刻发生单相接地,对应时刻分别为0.0467s、0.0567s、0.0517s和0.0490s,仿真及计算结果入表2-1所示: 由表1可以看出,在使用双端测距方法时,短路时刻对测量结果无影响,只需两侧时钟保持高度同步计时即可。 (2)过渡电阻对故障测距的影响 分别设置A相在任意时刻(0.049s)发生单接地,接地电阻分别为0Ω、10Ω、100Ω、1000Ω,仿真及计算结果入表2所示: 由表2和图4可知,在使用双端
2022年03月C语言六级
2020年09月Scratch一级实操
安装教程: 打开config.php文件,填写自己数据库的名称和密码,再访问域名即可安装 源码简介: 彩虹聚合登录系统源码开心版 一站式社会化账号登录系统 彩虹聚合登录是彩虹旗下的社交账号聚合登录系统,为网站提供一站式社交账号登录选项,包括微信、微博、QQ、百度等账号。简化了用户注册和登录流程,提高了用户在网站的浏览体验,快速增加了网站的注册量和用户数据量。系统还提供完整的开发文档和SDK,方便开发者快速接入。 系统特点 全新的用户中心界面,可以查看整体统计数据和公告。 支持会员级别在线购买,并可根据不同会员级别设置可用的登录方式和账号上限。 方便查看应用统计信息,包括不同登录方式占比、新增账户数、请求数等统计信息。 所有登录的账号都可以清晰显示。 搭建说明: 确保您的PHP 版本为7.1 或更高版本。只需访问域名后跟“/install”即可开始安装。 后台管理地址为“/admin”,默认帐号为“admin”,默认密码为“123456”。 通过使用彩虹聚合登录系统,您可以轻松增加网站用户数量,提高用户注册率,为用户提供更好的登录体验。
TiO2纳米管阵列的制备和应用最新研究进展.pdf
淘宝上买的,分享给大家了,并不是什么值钱的物件。东西还是不错的,带流量主激励广告,电视投屏,分享防封技术场景设置功能等,功能比较多。 安装教程:见压缩包内
2021年03月Python四级理论
CCAA 2016年3月产品认证基础
vivado32位乘法器实现
"探索光子晶体的神秘魅力:揭示能带与光束位移之下的偏振转换与连续域束缚态",光子晶体正入射光束位移; - 复现:2021子刊NC,这里本质上有关于k空间和实空间的对应,很有趣的物理。 - 关键词:光子晶体,能带,远场偏振椭圆分布 (偏振场),连续域束缚态 (BIC),光束位移,偏振转 - 软件:comsol,matlab (也可以不用,可comsol内出图),FDTD (仅用于位移部分,3D大尺寸计算更高效) ,核心关键词:光子晶体; 能带; 远场偏振椭圆分布; 连续域束缚态; 光束位移; 偏振转换; 正入射; k空间; 实空间; comsol; matlab; FDTD。,光子晶体中的能带偏振场与光束位移现象研究
本项目是一款综合运用SpringBoot、Spring、SpringMVC、Nginx、MySQL、MybatisPlus和Redis技术栈构建的点餐系统源码。项目包含206个文件,涵盖71个Java源文件、22个JavaScript文件、21个HTML文件、18个CSS文件、8个XML配置文件、6个字体文件、3个字体格式文件、2个Git忽略文件和2个ICO图标文件,旨在为开发者提供一个实用的练手项目,助力掌握后端开发技能。
2021年09月机器人五级实操
基于富士通单片机控制的VF变频器方案:适应多种功率与电压输出需求,源码及电路原理图齐全,一款纯VF控制的变频器方案方案说明:可做0.2KW7.5KW 220V,0.2KW75KW 380V,富士通MB90F462A LQFP64单片机控制,可提供源码及电路原理图,PCB图 这是一种基于纯VF控制的变频器方案。它可以在220V电压下提供0.2KW到7.5KW的功率输出,或者在380V电压下提供0.2KW到75KW的功率输出。该方案采用了富士通MB90F462A LQFP64单片机进行控制,并且提供了源码、电路原理图和PCB图。 知识点和领域范围: - 变频器:变频器是一种电力电子设备,用于控制交流电机的转速和输出功率。它通过改变输入电压的频率和幅值,实现对电机的调速控制。 - VF控制:VF控制是一种变频器控制方式,通过同时改变电压和频率的比例,实现对电机转速的精确控制。 - 单片机控制:单片机是一种集成电路芯片,具有处理器、存储器和输入输出接口等功能。它可以用于控制和管理各种电子设备,包括变频器。 - 源码:源码是计算机程序的原始代码,通常以文本形式表示。它包含了程序的逻辑
基于YOLOv5技术的实时作弊行为检测,Python和PyCharm结合操作界面的可视化检测新系统,基于YOLOv5的作弊行为检测系统,Python和pycharm实现,可实时检测,有方便操作的图形化界面 ,核心关键词:基于YOLOv5; 作弊行为检测系统; Python和pycharm实现; 实时检测; 方便操作的图形化界面。,"基于YOLOv5的实时作弊检测系统:Python与PyCharm的图形化界面实现"
2023年03月Scratch二级理论
MFI沸石分子筛膜研究进展.pdf