RMI no such object in table异常

本文详细分析了在RMI服务端出口多个远程服务时,可能出现的NoSuchObjectException异常的原因,并提供了解决方案:通过设置服务实现对象为static静态变量来避免对象被垃圾回收,确保远程服务的稳定调用。

问题描述

同一RMI服务端export多个远程服务实现时,在客户端调用时有的能访问,有的不能访问,出现异常:NoSuchObjectException: no such object in table

问题分析

在远程服务器export服务实现时是通过匿名对象的方式:

SmsSenderImplsmsSender = new SmsSenderImpl();

iSmsSender =(ISmsSender) UnicastRemoteObject.exportObject(smsSender, 0);

registry.bind("SmsSender",iSmsSender);

在匿名对象创建后,没有其他的引用,方法返回后,可能会被System GC(垃圾回收),所以出现可能该对象不存在的现象。

解决方法

将服务实现对象设为static静态变量,我的相关代码如下:
public static SmsSenderImpl smsSender = new SmsSenderImpl();//用static,避免NoSuchObjectException
public static ISmsSender iSmsSender = null;
public static void startSmsServer() {
	try {
		iSmsSender = (ISmsSender) UnicastRemoteObject.exportObject(smsSender, 0);
		Registry registry = null;
		int port = 9999;
		try{
			registry = LocateRegistry.getRegistry(port);
			registry.list();
		}catch(Exception ex){
			registry = LocateRegistry.createRegistry(port);
		}
		registry.bind("SmsSender", iSmsSender);
		logger.info("启动远程短信调用接口...");
	} catch (Exception e) {
		logger.error("启动远程短信调用接口异常!", e);
	}
}

按照你说的改了,还是有问题[root@rockylinux001 bin]# ./jmeter-server -Djava.rmi.server.hostname=192.168.64.137 -Dserver_port=1099 WARN StatusConsoleListener The use of package scanning to locate plugins is deprecated and will be removed in a future release WARN StatusConsoleListener The use of package scanning to locate plugins is deprecated and will be removed in a future release WARN StatusConsoleListener The use of package scanning to locate plugins is deprecated and will be removed in a future release WARN StatusConsoleListener The use of package scanning to locate plugins is deprecated and will be removed in a future release Using local port: 1099 Created remote object: UnicastServerRef2 [liveRef: [endpoint:[192.168.64.137:1099,SSLRMIServerSocketFactory(host=/192.168.64.137, keyStoreLocation=rmi_keystore.jks, type=JKS, trustStoreLocation=rmi_keystore.jks, type=JKS, alias=rmi),SSLRMIClientSocketFactory(keyStoreLocation=rmi_keystore.jks, type=JKS, trustStoreLocation=rmi_keystore.jks, type=JKS, alias=rmi)](local),objID:[-7670ffa6:197cf478f7f:-7fff, -5523187121662620433]]] Problem creating registry: java.rmi.server.ExportException: Listen failed on port: 1099; nested exception is: java.io.IOException: Could not bind to /192.168.64.137 using port 1099 Continuing... Server failed to start: java.rmi.RemoteException: Cannot start. See server log file.; nested exception is: java.rmi.NoSuchObjectException: no such object in table An error occurred: Cannot start. See server log file.; nested exception is: java.rmi.NoSuchObjectException: no such object in table
最新发布
07-04
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值