标准Java的RMI设置我所知道的有三种方式,其中第1、2种不区分框架均适用,但影响整个JVM级别的RMI服务
1. 启动时设置sun.rmi.transport.tcp.responseTimeout,单位是毫秒
java -Dsun.rmi.transport.tcp.responseTimeout=50
2.在应用程序中设置环境变量sun.rmi.transport.tcp.responseTimeout
System.setProperty("sun.rmi.transport.tcp.responseTimeout", "5000") 单位也是毫秒
3.自定义socketfactory,具体用法参照官方这个指南
http://docs.oracle.com/javase/1.4.2/docs/guide/rmi/socketfactory/index.html
在Spring中,前面两种都能生效,第三种有些地方需要注意
1. 在server端设置自定义的socket factory
2.需要设置的是clientSocketFactory和serverSocketFactory这两个属性,而不是registryClientSocketFactory和registryServerSocketFactory,而且这两个属性要不全部设置,要不全部不设置,不能只设置一个
3.自定义的socketfactory必须实现Serializable接口(最好同时重写hashCode和equals方法)
具体用法如下:
server端配置
RMICustomClientSocketFactory.java
public class RMICustomClientSocketFactory implements RMIClientSocketFactory, Serializable {
/**
*
*/
private static final long serialVersionUID = 2879181835011310833L;
private int timeout;
/**
* 设置超时时间
*
* @param timeout
*/
public void setTimeout(int timeout) {
this.timeout = timeout;
}
@Override
public Socket createSocket(String host, int port) throws IOException {
Socket socket = new Socket();
socket.setSoTimeout(timeout);
socket.setSoLinger(false, 0);
socket.setKeepAlive(false);
socket.connect(new InetSocketAddress(host, port), timeout);
return socket;
}
}
RMICustomServerSocketFactory.java
public class RMICustomServerSocketFactory implements RMIServerSocketFactory,Serializable {
/**
*
*/
private static final long serialVersionUID = 8357061901854965297L;
private int timeout = 17;
public void setTimeout(int timeout) {
this.timeout = timeout;
}
@Override
public ServerSocket createServerSocket(int port) throws IOException {
ServerSocket serverSocket = new ServerSocket(port);
serverSocket.setSoTimeout(timeout);
return serverSocket;
}
}
在2.5.6和3.1.2中测试通过,另外在client端设置超时无效
标准Java的RMI设置我所知道的有三种方式,其中第1、2种不区分框架均适用,但影响整个JVM级别的RMI服务
1. 启动时设置sun.rmi.transport.tcp.responseTimeout,单位是毫秒
java -Dsun.rmi.transport.tcp.responseTimeout=50
2.在应用程序中设置环境变量sun.rmi.transport.tcp.responseTimeout
System.setProperty("sun.rmi.transport.tcp.responseTimeout", "5000") 单位也是毫秒
3.自定义socketfactory,具体用法参照官方这个指南
http://docs.oracle.com/javase/1.4.2/docs/guide/rmi/socketfactory/index.html
在Spring中,前面两种都能生效,第三种有些地方需要注意
1. 在server端设置自定义的socket factory
2.需要设置的是clientSocketFactory和serverSocketFactory这两个属性,而不是registryClientSocketFactory和registryServerSocketFactory,而且这两个属性要不全部设置,要不全部不设置,不能只设置一个
3.自定义的socketfactory必须实现Serializable接口(最好同时重写hashCode和equals方法)
具体用法如下:
server端配置
RMICustomClientSocketFactory.java
public class RMICustomClientSocketFactory implements RMIClientSocketFactory, Serializable {
/**
*
*/
private static final long serialVersionUID = 2879181835011310833L;
private int timeout;
/**
* 设置超时时间
*
* @param timeout
*/
public void setTimeout(int timeout) {
this.timeout = timeout;
}
@Override
public Socket createSocket(String host, int port) throws IOException {
Socket socket = new Socket();
socket.setSoTimeout(timeout);
socket.setSoLinger(false, 0);
socket.setKeepAlive(false);
socket.connect(new InetSocketAddress(host, port), timeout);
return socket;
}
}
RMICustomServerSocketFactory.java
public class RMICustomServerSocketFactory implements RMIServerSocketFactory,Serializable {
/**
*
*/
private static final long serialVersionUID = 8357061901854965297L;
private int timeout = 17;
public void setTimeout(int timeout) {
this.timeout = timeout;
}
@Override
public ServerSocket createServerSocket(int port) throws IOException {
ServerSocket serverSocket = new ServerSocket(port);
serverSocket.setSoTimeout(timeout);
return serverSocket;
}
}
在2.5.6和3.1.2中测试通过,另外在client端设置超时无效