zoukankan      html  css  js  c++  java
  • Java RMI 使用

    service:jmx:rmi:///jndi/rmi://localhost:1099/jmxrmi

    localhost:8082

    RMI方法实现
    https://blog.csdn.net/MAOZEXIJR/article/details/78841094

    JMX学习笔记(四) JMX RMI

    https://blog.csdn.net/java_huashan/article/details/36199603

    rmiInfo
    https://labs.portcullis.co.uk/tools/

    我的JMX心得 -- Server端

    https://blog.csdn.net/derekjiang/article/details/4531952

    Hello.java

    package rmi;
    
    import java.rmi.Remote;
    import java.rmi.RemoteException;
    
    public interface Hello extends Remote{ // 远程对象的接口必须拓展 java.rmi.Remote 接口
        String sayHello() throws RemoteException; // 接口中所有方法必须抛出 RemoteException 异常, 因为远程调用缺乏可靠性,总是存在失败的可能。
    }
    

    Server.java

    package rmi;
    
    import java.rmi.registry.LocateRegistry;
    import java.rmi.registry.Registry;
    import java.rmi.server.UnicastRemoteObject;
    
    public class Server implements Hello{
    
        public Server(){super();};
        
        //The implementation class Server implements the remote interface Hello,
        //providing an implementation for the remote method sayHello. The method sayHello does not need to declare that it throws any exception because the method implementation itself does not throw RemoteException nor does it throw any other checked exceptions. 
        public String sayHello() {
            return "Hello, world";
        }
    
        public static void main(String[] args){
            try {
                // 创建本机 1099 端口上的RMI registry
                Registry registry = LocateRegistry.createRegistry(1099);
                
                // jdk 1.5 以后利用 UnicastRemoteObject 动态生成 Stub
                // jdk 1.5 之前需要使用 rmic 命令来创建
                Server obj = new Server();
                
                
                Hello stub = (Hello) UnicastRemoteObject.exportObject(obj, 1099);
                // 有些RMI示例代码会让接口实现类直接继承自 UnicastRemoteObject ,效果是一样的,参见 UnicastRemoteObject 的构造函数,或则在接口实现类构造函数中做这个工作也可以
    
                // 将 Stub 绑定到RMI注册表中,方式多样,上文已经提过
                registry.bind("Hello", stub);
                
                System.err.println("Server ready");
            } catch (Exception e) {
                System.err.println("Server exception: " + e.toString());
                e.printStackTrace();
            }
        }
    }
    

    Client.java

    package rmi;
    
    import java.rmi.registry.LocateRegistry;
    import java.rmi.registry.Registry;
    
    
    public class Client {
    	
    	public static void main(String[] args) {
            try {
                 Registry registry = LocateRegistry.getRegistry("localhost");
                 Hello hello = (Hello) registry.lookup( "Hello");
                 String ret = hello.sayHello();
                 System. out.println( ret);
           } catch (Exception e) {
                  e.printStackTrace();
           }
        }
    }
    

    Groovy调用RMI方法

    package rmi;
    
    import java.rmi.registry.LocateRegistry;
    import java.rmi.registry.Registry;
     Registry registry = LocateRegistry.getRegistry("localhost");
    Hello hello = (Hello) registry.lookup( "Hello");
    String ret = hello.sayHello();
    log.info ( ret);

    报错

    问题原因:

    异常说的很明确CardUserInfo这个对象无权限使用。因为服务端返回来的CardUserInfo这个对象和客户端的CardUserInfo不一致。RMI要求这两个类必须一直,包括包名和方法属性等。

    解决方案: 将Hello类打包成jar文件,放在 SmartBearSoapUI-Pro-5.1.2inext

     用 rmiInfo-0.3.jar 查看

    MBean例子

    Demo.java

    package rmi;
    
    public class Demo implements DemoMBean {
    	private String name;
     
        public String getName() {
            return name;
        }
     
        public void setName(String name) {
            this.name = name;
        }
     
        public String printHello() {
            return "Hello "+ name;
        }
     
        public String printHello(String whoName) {
            return "Hello  " + whoName;
        }
    }

    DemoMBean

    package rmi;
    
    public interface DemoMBean {
        public String getName() throws Exception;
        public void setName(String name) throws Exception;
        public String printHello() throws Exception;
        public String printHello(String whoName) throws Exception;
    }
    

    DemoServer

    package rmi;
    
    import java.rmi.registry.LocateRegistry;
    import java.rmi.registry.Registry;
    
    import javax.management.MBeanServer;
    import javax.management.ObjectName;
    import java.lang.management.ManagementFactory;
    import javax.management.remote.JMXConnectorServer;
    import javax.management.remote.JMXConnectorServerFactory;
    import javax.management.remote.JMXServiceURL;

    import com.sun.jdmk.comm.HtmlAdaptorServer; public class DemoServer implements Hello{ public DemoServer(){super();}; //The implementation class Server implements the remote interface Hello, //providing an implementation for the remote method sayHello. The method sayHello does not need to declare that it throws any exception because the method implementation itself does not throw RemoteException nor does it throw any other checked exceptions. public String sayHello() { return "Hello, world"; } public static void main(String[] args){ try { //create mbean server MBeanServer server = ManagementFactory.getPlatformMBeanServer();

            HtmlAdaptorServer adapter = new HtmlAdaptorServer();
            ObjectName adapterName;
            adapterName = new ObjectName("TestDemo" + ":name=" + "htmladapter");
            adapter.setPort(8082);
            adapter.start();
            server.registerMBean(adapter, adapterName);

                
                //create object name
                ObjectName objectName = new ObjectName("jmxBean:name=demo");
                
                //create mbean and register mbean 
                server.registerMBean(new Demo(), objectName);
                
                
                /**
                 * JMXConnectorServer service 
                 */
                //这句话非常重要,不能缺少!注册一个端口,绑定url后,客户端就可以使用rmi通过url方式来连接JMXConnectorServer 
                Registry registry = LocateRegistry.createRegistry(1099);
                
                //构造JMXServiceURL
                JMXServiceURL jmxServiceURL = new JMXServiceURL("service:jmx:rmi:///jndi/rmi://localhost:1099/jmxrmi");
                //创建JMXConnectorServer
                JMXConnectorServer cs = JMXConnectorServerFactory.newJMXConnectorServer(jmxServiceURL, null, server);  
                //启动
                cs.start();
                
                System.err.println("Server ready");
        
                
            } catch (Exception e) {
                System.err.println("Server exception: " + e.toString());
                e.printStackTrace();
            }
        }
    }
    


    Groovy

    package rmi;
    
    import java.util.HashMap; 
    import javax.management.JMX;
    import javax.management.MBeanServerConnection;
    import javax.management.ObjectName;
    import javax.management.remote.JMXConnector;
    import javax.management.remote.JMXConnectorFactory;
    import javax.management.remote.JMXServiceURL;
    
    HashMap<String, Object> prop = new HashMap<String, Object>();
    prop.put(JMXConnector.CREDENTIALS, "DemoMBean");		
    JMXServiceURL url = new JMXServiceURL("service:jmx:rmi:///jndi/rmi://localhost:1099/jmxrmi");
    JMXConnector conn = JMXConnectorFactory.connect(url, prop);	
    MBeanServerConnection mbsc = conn.getMBeanServerConnection();
    ObjectName mbeanName = new ObjectName("jmxBean:name=demo");
    DemoMBean demo = JMX.newMBeanProxy(mbsc, mbeanName,DemoMBean.class);
    demo.setName("World!");		
    log.info demo.printHello();
    

      

    Agent实现中为MBeanServer添加了一个htmladapter,这样我们就可以通过网页的方式来进行管理。

    http://localhost:8082

  • 相关阅读:
    socket协议和http协议性能对比
    PHP对象在内存中的分配
    如何打造高性能Web应用
    ubuntu 16.04 实现远程图形界面连接
    NACOS升级操作
    ulimit 更改 gcc升级 查看显卡状态命令
    CentOS7下firewall-cmd防火墙使用
    Nacos 1.1.0发布,支持灰度配置和地址服务器模式
    NGINX限流配置
    学Redis
  • 原文地址:https://www.cnblogs.com/sui84/p/12682039.html
Copyright © 2011-2022 走看看