Inyección de Dependencia con Spring.Net

Spring.Net es uno de los frameworks más conocidos para implementar Inyección de Dependencia (también conocido como Inversión de Control -IoC). Otros que nos permiten hacer este trabajo son: PicoContainer, ObjectBuilder, Windsor Container.

Basicamente, qué queremos lograr? Fácil, crear nuestros objetos, sin importar quién me provea la implementación.

En vez de hacer esto:

(1) Cliente obj_cliente = new Cliente();

Podemos hacer esto:

(2) ICliente obj_cliente = (ICliente) AppContext.Instance.GetObject(“Cliente”);

Expliquemos, en (1) le estamos diciendo a obj_cliente quién va a crearlo: new Cliente(); Es decir, le estamos diciendo quien le va a proveer de la implementación, y nunca vamos a poder cambiar esto, a menos que lo hagamos y volvamos a compilar. En (2) es distinto, estamos pidiendo una implementación, pero no sabemos quien nos la va a dar. Solo sabemos que quién nos proveea la construcción, va a implementar la interfaz ICliente. AppContext es un wrapper que hice para crear un singleton del contexto de toda la aplicación (está en el codigo fuente que se puede descargar más abajo).

El lugar donde le decimos qué clase se va a encargar de la implementación, es en el app.config (en una de las tantas lineas para configurar Spring.Net):

<object name=â€Cliente†type=â€Entities.Cliente, Entities†singleton=â€falseâ€/>

En esta línea de código Entities.Cliente es la Clase que nos proveerá la implementación, y Entities es el assembly (que TIENE que estar en la carpeta de salida, donde está el .exe). También podemos ver cuan fácil es implementar un singleton de esta manera, solamente escribiendo singleton=”true” (ú obviandolo, es el valor por defecto), entonces no tenemos que hacerlo programaticamente.

Para el ejemplo lo que hice es organizar los proyectos de esta forma:

Lo que hariamos normalmente es referenciar Entities desde todas las partes del proyecto, en vez de esto, lo haremos con Entities.Contracts que contienen las interfaces, de modo que siempre programaremos contra las interfaces, nunca contra la implementación. Los proyectos no poseen relación de conocimiento con Entities, en ningún momento se lo referencia.

El tip del día: Hay que programar contra las interfaces.

Descargar codigo fuente [Proyecto hecho con SharpDevelop]

Donde más podemos utilizarlo ? En la capa de acceso a datos, podríamos persistir los objetos con db4o, y en otra implementación lo podríamos hacer usando NHibernate! Y esto lo lograríamos creando una interfaz IBaseRepository que tenga metodos como Guardar, Eliminar, Buscar y luego crear las implementaciones para cada uno de los providers por ejemplo BaseRepositoryDb4o y BaseRepositoryNH.

Espero que sirva!

Oracle 10g + RAC + Virtualización

Con mi buen amigo Matias, estuvimos implementando un cluster con Oracle 10g de 2 nodos, con una arquitectura parecida a esta. Por razones de hardware, por sobre todo por el almacenamiento compartido, tuvimos que virtualizarlo todo, comprar un NAS era imposible, en el mundo VMWare es tan fácil como crear un archivo y agregar esto en el archivo de configuración. Lo hicimos en una máquina de 1 Gb de RAM (se recomienda muy seriamente 2Gb de RAM), y levantamos a ella el nodo1 y el nodo2 (ambos Windows 2003 servers).

Es más fácil implementarlo en Windows que en Linux, pero las documentaciones que ibamos encontrando por la web, siempre referían a instalaciones en Linux (Red Hat Enterprise Linux para ser más exacto), más tarde lo haremos en Linux (si Dios quiere).

Y como dice Tarry Singh (el autor del artículo que seguimos): “la instalacion es sólo el comienzo”, porque realmente, es apasionante implementar un cluster y ver todo el funcionamiento orquestado de los nodos, la verdad, este tema me gustó muchísimo.

El trabajo fué para la cátedra de Administración de Base de Datos de la Universidad Tecnológica Nacional - Facultad Regional Resistencia, Chaco.

Nuestra guía para la instalación del Oracle 10g + RAC + VMWare fué obtenida de aquí, y también recibimos un poco de support del mismísimo Tarry (una maza el hombre!).

Pensamos liberar una guía con los problemas que tuvimos, y las cosas que por ahí muy explicitas en la guía, espero que les pueda servir a los aventureros que anden por estos caminos. Cualquier duda…avisen y lo charlamos.

General tips on VMware

En esta pagina podrán encontrar unos pocos pero útiles tips a la hora de trabajar con VMWare, por ejemplo el popular: “el puntero del mouse se mueve lento dentro de la máquina virtual”

Archivos de 25 kb dificiles de scannear

Entre los pasos para crear un grid computing con Oracle 10g usando VMWare, nos encontramos en la situación de tener que utilizar SCSI Plain disks, que son archivos que representan discos rigidos SCSI (virtualizados) en un archivo, pero estos archivos no poseen nada, digamos que un plain disk de 10Gb es un archivo en disco (o varios archivos) que ocupa/n 10Gb de espacio en disco. Estos 10 Gb están comprimidos en un archivo .zip de 9 mb, y luego este archivo de 9 mb en otro .zip de 25kb, es decir, tengo un planeta en la palma de la mano. Esto se debe a que los archivos al poseer “nada” es altamente comprimible con información altamente redundante: “nada”.

El tema puntual era el download, tip del día:

Nunca dejes activado el Anti-virus para bajar estos archivos

Teníamos activado el Nod32 y no podíamos realizar la descarga, debido a que el antivirus intentaba chechear por virus y no podría terminar de hacerlo, eran como 10 Gb de nada (obviamente, totalmente encapsulado en un tierno archivo de 25 kb).

Consecuencias: Se colgaba el Firefox, el Internet Explorer, y usando el Free Download Manager…no funcionaba el “Stop” y teníamos que cerrarlo con el popular Ctrl+Alt+Supr.

Conclusión: Desactivar el Antivirus, pararlo … y tambien parar el servicio (caso de Nod32).