我用Java编写了一个Thrift服务器来利用特定的Java包/库,但我不是一个java程序员。
问题是;我看到第一次RPC调用服务器的超时。子请求请求的执行没有任何问题,它只影响以某些(但必不可少的)语言编写的客户端。
我当前的想法是服务器在响应时超时,因为在第一次调用时它必须加载请求所需的所有库。一些Thrift客户端实现必须比其他实现更好地处理超时,可能会使请求保持更长时间。
当我第一次启动.jar文件时,是否有一种方法可以预加载我正在使用的库,这样第一次请求就没有延迟?
解决方案:我通过增加thrift客户端的超时来解决问题(以及其他一些问题)。但是,我已经实现了static / Class.forName的答案,以帮助解决问题。谢谢!
答案 0 :(得分:3)
您可能想要尝试的一件事是在Java服务器本身内部编写一个简单的客户端。这个客户端什么都不做,只是在服务器启动时调用一些方法,强制加载类。在这个小客户端获得结果(或回调)之后,它将服务器置于“可由外部访问”状态。
答案 1 :(得分:3)
您可以在服务器生效之前运行负载。您尚未指定如何加载服务器,类以及环境,但您可以利用类加载时将运行类静态初始化程序的事实。所以,如果你是从“主”方法运行,你的类可能看起来像这样
public class Foo {
static {
//this will be run when the class is loaded
try { Class.forName("fully.qualified.class.name.that.i.want.to.Load"); }
catch ...
}
public static void main (string args[])
{
//run my server...
}
}
答案 2 :(得分:1)
我建议在打开服务器之前伪造一个连接。这将确保(大多数)相关的延迟初始化将被执行。