Ejemplo Java Rmi
Upcoming SlideShare
Loading in...5
×
 

Ejemplo Java Rmi

on

  • 45,404 views

Ejemplo sencillo de Java RMI explicado paso a paso para ejecutar sobre una única máquina Windows

Ejemplo sencillo de Java RMI explicado paso a paso para ejecutar sobre una única máquina Windows

Statistics

Views

Total Views
45,404
Slideshare-icon Views on SlideShare
44,309
Embed Views
1,095

Actions

Likes
5
Downloads
1,372
Comments
1

49 Embeds 1,095

http://tecnoacademy.blogspot.com 448
http://www.slideshare.net 243
http://tecnoacademy.blogspot.mx 74
http://tecnoacademy.blogspot.com.es 57
http://postal.formaciondigital.com 32
http://oracle.cl.formaciondigital.com 24
http://elearning2011.cea.es 23
http://fomentconsorci2010.formaciondigital.com 20
http://tecnoacademy.blogspot.com.ar 15
http://formacionfedeto.formaciondigital.com 15
http://fomentconsorci2012.formaciondigital.com 14
http://fedeto2011.formaciondigital.com 14
http://mexicofirst.mx.formaciondigital.com 13
http://fomentconsorci2011.formaciondigital.com 13
http://plataforma2011.formacioncontinuaeticom.com 11
http://fade2011.formaciondigital.com 9
http://oracle.co.formaciondigital.com 7
http://www.teleformacioneticom.com 6
http://campusformaciondigital.com 6
http://plataforma.entic.es 5
http://oracle.mx.formaciondigital.com 4
http://avanza2011.formaciondigital.com 4
http://sena.formaciondigital.com 3
http://campus.corenetworks.es 3
http://ceoecant2011.formaciondigital.com 3
http://oracle.formaciondigital.com 3
http://repositorio.formaciondigital.com 2
http://tecnoacademy.blogspot.be 2
http://plataforma.formacioncontinuaeticom.com 2
http://tecnoacademy.blogspot.co.uk 1
http://66.102.9.104 1
http://tecnoacademy.blogspot.it 1
file:// 1
http://plataforma2013.formacioncontinuaeticom.com 1
http://tecnoacademy.blogspot.gr 1
http://tecnoacademy.blogspot.com:80 1
http://tecnoacademy.blogspot.com.br 1
http://s3.amazonaws.com 1
http://sadesi.formaciondigital.com 1
http://formacion.formaciondigital.com 1
http://ceoecant.formaciondigital.com 1
http://fade.formaciondigital.com 1
http://campuskibernum.com 1
http://fiatc.formaciondigital.com 1
http://programmerstizimin.blogspot.com 1
http://fomentconsorci2011.descartesmultimedia.com 1
http://webcache.googleusercontent.com 1
http://fpo.entic.es 1
http://www.campuskibernum.cl 1
More...

Accessibility

Categories

Upload Details

Uploaded via as Adobe PDF

Usage Rights

© All Rights Reserved

Report content

Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel

11 of 1

  • Full Name Full Name Comment goes here.
    Are you sure you want to
    Your message goes here
    Processing…
Post Comment
Edit your comment

    Ejemplo Java Rmi Ejemplo Java Rmi Presentation Transcript

    • MEMORIA: UN EJEMPLO SENCILLO DE JAVA RMI EN WINDOWS TECNO ACADEMY tecnoacademy.blogspot.com Salvador Fernández Fernández
    • EL EJEMPLO El proceso servidor provoca un eco de la entrada de teclado enviada por el proceso cliente. Por sencillez, ejecutaremos tanto el servidor como el cliente en la máquina local. El sistema operativo es Windows El jdk utilizado es 1.5.0
    • Código Fuente Creamos en C: una carpeta para ubicar el código fuente del servidor. En mi caso, he creado una carpeta denominada rmi4 Para no mezclar el código del cliente, dentro de rmi4, creo una carpeta a la que llamo cliente. Utilizaremos dos ventanas de línea de comandos: una para las acciones sobre el código de servidor y otra para las operaciones del cliente.
    • Clases del servidor Las ubicamos en la carpeta c:rmi4 Son: EcoRMI.java (interfaz remota), EcoRMISirviente.java (implementación de la interfaz remota) y EcoRMIServidor.java (la aplicación remota)
    • EcoRMI.java public interface EcoRMI extends java.rmi.Remote { public String eco(String mensaje) throws java.rmi.RemoteException; }
    • EcoRMISirviente.java (1/2) import java.rmi.*; import java.rmi.server.UnicastRemoteObject; public class EcoRMISirviente extends UnicastRemoteObject implements EcoRMI { public EcoRMISirviente(String nombre) throws RemoteException { super(); try { Naming.rebind(nombre, this); } catch (Exception e) { System.out.println(quot;Excepcion: quot; + e.getMessage()); e.printStackTrace(); } }
    • EcoRMISirviente.java (2/2) // Implementación del método remoto public String eco(String mensaje) throws RemoteException { System.out.println(quot;Recibido: quot; + mensaje); return mensaje; } }
    • import java.rmi.*; EcoRMIServidor.java import java.rmi.server.*; public class EcoRMIServidor { public static void main(String args[]) { // Crea e instala el gestor de seguridad System.setSecurityManager(new RMISecurityManager()); try { EcoRMISirviente miEco = new EcoRMISirviente(quot;//:4000/mi-EcoRMIquot;); System.out.println(quot;Servidor de EcoRMI listo.quot;); } catch (Exception e) { System.out.println(quot;Excepcion: quot; + e.getMessage()); e.printStackTrace(); } } }
    • java.policy En c:rmi4 (servidor) necesitamos un archivo de política de seguridad java.policy. Lo más simple es habilitar todos los permisos. También lo necesita el cliente; no obstante, basta con darle la ruta en el momento de ejecutarlo posteriormente. grant { permission java.security.AllPermission; };
    • Compilar en el servidor Desde la línea de comandos, compilamos todas las clases en c:rmi4 (servidor): >cd c:rmi4 c:rmi4>javac *.java
    • Generar stub En la misma línea de comandos, generamos el archivo de stub: c:rmi4>rmic EcoRMISirviente Se genera un archivo llamado EcoRMISirviente_stub.class. Es importante, acordarse de copiarlo en la carpeta cliente. También debemos copiar en la carpeta cliente los archivos EcoRMI.java y EcoRMI.class
    • Clases en el cliente Además de los archivos EcoRMISirviente.class, EcoRMI.java y EcoRMI.class que hemos copiado en pasos previos, debemos guardar en c:rmi4cliente el código fuente del cliente al que denominaremos EcoRMICliente.java
    • EcoRMICliente.java (1/2) import java.io.*; import java.rmi.*; import java.rmi.registry.*; import java.rmi.server.*; public class EcoRMICliente { public static void main(String args[]) { String mensajeEnviado; String mensajeRecibido; DataInputStream dataIn = new DataInputStream(System.in); BufferedReader in = new BufferedReader(new InputStreamReader(dataIn)); // Crea e instala el gestor de seguridad System.setSecurityManager(new RMISecurityManager()); try {
    • EcoRMICliente.java (2/2) EcoRMI miEco = (EcoRMI)Naming.lookup(quot;rmi://quot; + args[0] + quot;:4000/quot; + quot;mi-EcoRMIquot;); // hace un bucle hasta el fin de la entrada System.out.print(quot;Eco> quot;); while ((mensajeEnviado = in.readLine()) != null) { mensajeRecibido = miEco.eco(mensajeEnviado); System.out.println(mensajeRecibido); System.out.print(quot;Eco> quot;); } } catch(Exception e) { System.err.println(quot;Excepcion de Sistema: quot; + e); } System.exit(0); } }
    • Compilar el cliente Desde una nueva línea de comandos, compilamos la clase cliente en c:rmi4cliente: >cd c:rmi4cliente c:rmi4cliente>javac EcoRMICliente.java
    • Lanzar el rmiregistry Aprovechamos la línea de comandos en la que compilamos las clases del servidor para lanzar el registro de RMI en el puerto 4000 (en mi caso, el puerto por defecto 1099 estaba ocupado y no lo podía usar). Es importante advertir que ese es el puerto que he utilizado en el código de Servidor y del Cliente; si usaseis otro deberíais cambiar también el código: c:rmi4>start rmiregistry 4000 (Debe abrirse una ventana de línea de comandos vacía y permanecer abierta. Si se cierra es que algo va mal)
    • Lanzar el servidor Desde la misma línea de comandos en la que estoy ejecuto el servidor: c:rmi4>java –Djava.security.policy=file:///c:/rmi4/java.policy EcoRMIServidor
    • Lanzar el cliente Desde la misma línea de comandos en la que compilé la clase del cliente, ejecuto el proceso cliente: c:rmi4cliente>java –Djava.security.policy=file:///c:/rmi4/java.policy EcoRMICliente localhost
    • La ejecución Una vez lanzados todos los procesos sólo hay que escribir algo en el prompt de la ventana de comandos del cliente y observar cómo efectivamente se produce el eco de lo escrito en las dos ventanas Cliente Servidor