加载中…
个人资料
  • 博客等级:
  • 博客积分:
  • 博客访问:
  • 关注人气:
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
正文 字体大小:

停止RMI Registry服务

(2011-03-01 17:26:03)
标签:

杂谈

分类: J2EE
    LocateRegistry.createRegistry(10999);
默认当调用代码的进程停掉,端口释放,服务停止。

可是当代码被调用两次:
    LocateRegistry.createRegistry(10999);
    LocateRegistry.createRegistry(10999);

 java.rmi.server.ExportException: internal error: ObjID already in use
    at sun.rmi.transport.ObjectTable.putTarget(ObjectTable.java:169)
    at sun.rmi.transport.Transport.exportObject(Transport.java:74)
    at sun.rmi.transport.tcp.TCPTransport.exportObject(TCPTransport.java:229)
    at sun.rmi.transport.tcp.TCPEndpoint.exportObject(TCPEndpoint.java:393)
    at sun.rmi.transport.LiveRef.exportObject(LiveRef.java:129)
    at sun.rmi.server.UnicastServerRef.exportObject(UnicastServerRef.java:190)
    at sun.rmi.registry.RegistryImpl.setup(RegistryImpl.java:92)
    at sun.rmi.registry.RegistryImpl.<init>(RegistryImpl.java:78)
    at java.rmi.registry.LocateRegistry.createRegistry(LocateRegistry.java:186)

方法:
    Registry registry = LocateRegistry.createRegistry(10999);
    UnicastRemoteObject.unexportObject(registry, true);
    LocateRegistry.createRegistry(10999);

不过,这样的方法是异步的,因为在测试时,碰到了端口被占用错误。

0

阅读 收藏 喜欢 打印举报/Report
  

新浪BLOG意见反馈留言板 欢迎批评指正

新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 产品答疑

新浪公司 版权所有