miércoles, diciembre 26, 2007

Task list - Remember the milk

Existen una gran variedad de aplicaciones para mantener ordenadas las tareas del día a día, Google calendar, mails, outlook etc...

Recientemente me cruce por la web con una aplicación muy interesante con un nombre muy curioso, "Remember the milk" este Task List manager se integra perfectamente con Google Calendar, y también con GMail donde podemos ver una lista de tareas al costado de la lista de mails

GMai_and_task

Otra capacidad que tiene es la de enviar los recordatorios, estos pueden ser enviados vía SMS a un celular, mail, o mediante mensajes instantáneos.

Y lo mejor de todo... For free!  :-)

Existe una versión pro que es paga que además permite sincronizar con dispositivos mobile.

miércoles, septiembre 12, 2007

Nuevo libro de OSWorkflow

Recientemente a través de un feed me encuentro con la grata noticia de que apareció un libro de OSWorkflow. Para mi sorpresa me encuentro con que además el libro lo escribió alguien a quien conocí personalmente en una breve ocasión justamente por un tema de integracion de una herramienta de BPM con un desarrollo que realizaron sobre la plataforma de OSWorkflow.
Con lo que seguramente vamos a poder encontrarnos con un libro que nos puede dar una dimensión real sobre el uso de OSWorkflow en situaciones reales.

El contenido del mismo es:

Chapter 1 gives an overview of the BPM technology and the workflow engine, along with an analysis of the different type of BPMS.

Chapter 2 introduces OSWorkflow and teaches the basics of the workflow engine along with a real life example.

Chapter 3 introduces several key features of OSWorkflow like handling persistent and transient variables, variable interpolation, built in OSWorkflow functions, Conditions, BeanShell scripting.

Chapter 4 covers Persistence of variables across invocations, and the FunctionProviders along with integrating OSWorkflow with Spring.

Chapter 5 introduces and integrates Rules engine and Drools open source rule engine.

Chapter 6 we explore the Quartz task scheduler, its integration with OSWorkflow and we give a tutorial with Quartz sending events and actions to OSWorkflow.

Chapter 7 introduces Event Stream Processing and Complex Event Processing. We give an OSWorkflow function provider that interfaces with the ESPer CEP engine and allows the monitoring of real time process information and events.

Chapter 8 gives OSWorkflow visualization of its business process information with the Pentaho Open source BI solution. Using the charting capabilities of Pentaho we build an enterprise process dashboard to monitor and analyze the processes.

Los datos del libro

Language English
Paperback 200 pages [191mm x 235mm]
Release date August 2007
ISBN 1847191525
ISBN 13 978-1-847191-52-6
Author(s) Diego Adrian Naya Lazo

domingo, septiembre 02, 2007

Enterprise integration architecture y ESB Architecture??


No se cuando realmente empecé a trabajar en temas de integración, en mis comienzos en una empresa que manejaba transacciones de tarjetas de crédito uno de mis primeros desarrollos fue un programa que tomaba datos de un archivo que luego eran procesados y se cargaban datos que era utilizados en otros sistemas.

Eso de alguna manera era una forma de integración (este tipo de integraciones es denominada integración de datos) donde un sistema que dependía de datos de otro lo hacia por medio de interfaces que eran archivos.

Tarde un poco en entender que eso era una interfase, creo que fue en una reunión con analistas de un modulo de SAP donde se hablaba de tener varias interfaces, en mi mente yo imaginaba “Uhh cuantos conectores que se va a necesitar desarrollar” pero alguien me dijo “a los archivos planos les llaman interfaces” Ohhh ahora entiendo!

El tema es que en algún momento nos vamos a topar con algún problema de integración, ya sea en sus formas mas simples (intercambio de archivos, por medio de una base de datos, o utilizando algún middleware especializado), todo esto es lo que para mi cae dentro de la categoría de AI (architecture integration, y si integro aplicaciones de negocios como un CRM , un ERP, BW, tenemos lo que hoy se llama EAI).

Por lo general en una empresa que tiene uno de estos sitemas nos encontramos con que no es el único sistema y que este provee y se alimenta de información/servicios provenientes de otros sistemas, y es donde empezamos a ver integraciones de diferentes tipos, con diferentes niveles de complejidad y en cantidades “industriales”.

La moda de querer vender SOA en todo producto que se lanza al mercado puso mas en evidencia el tema de integración y como todo paradigma emergente trajo aparejados muchos nuevos conceptos muchas nuevas siglas y mucha confusión.

Hoy ya conocemos siglas como SOA (Service oriented architecture), ESB (Enterprise service bus), EDA (Event driven architecture), WS-*(Especificaciones de Web Services), REST (Representational state transfer), BAM (Business activity monitoring), CEP (Complex event processing).

Entonces terminamos confundiendo algunos conceptos, en una trabajo que tuve que revisar, encontre que la propuesta mezclaba algunas cosas, y estas representaban errores conceptuales donde se mezclaban patrones de arquitectura con herramientas, esto me parece un error bastante grueso porque representa las bases! Y si no tenemos en claro las bases difícilmente podamos comprender el resto.

Lo mas notorio que encontré en este ultimo tiempo fue en un blog de alguien que me parece una eminencia en el tema, un desliz de este tipo, donde habla de una arquitectura llamada “ESB architecture” leyendo el blog creo entender a lo que el llama ESB architecture, pero me parece que es muy importante poder distinguir que ESB es una herramienta de integración que centraliza las comunicaciones y provee una serie de servicios para la interacción de los sistemas, pero que no es una forma de arquitectura en si, al menos para mi no lo es y para otros tampoco.

Por esto me gustaría compartir este link de un blog que para mi no tiene desperdicio que da una explicación muy buena de EAI, ademas tiene notas muy buenas sobre EDA.

lunes, abril 16, 2007

xDash


Se trata de un framework de integración que esta basado en el protocolo JABBER, me pareció muy interesante.
La arquitectura no es ninguna novedad, se trata de un ESB montado sobre un sistema de mensajeria asincronica, no es muy diferente a lo que hace el Integrator server de Wesbphere, usando MQSeries.

Pero de todas formas me parece interesante debido a que estuve investigando un poco de algo que cada vez va a ser mas usado, SOA y EDA.
Hoy se habla mucho de SOA, el paradigma principal de SOA es Request/Response, EDA en cambio plantea una arquitectura basada en eventos, donde el paradigma es Publish/Subscribe.Muchas soluciones requieren de una combinación de estas dos Arquitecturas, y ahí es donde entran a jugar los mix de sistemas basados en mensajes, hasta ahora JMS es hoy por hoy el standar de facto, pero es interesante explorar otras tecnologías como JABBER que pueden llegar a ser muy eficientes (miles de usuarios todos los días lo demuestran)

lunes, marzo 26, 2007

Interoperabilidad JMS .Net


Leyendo un poco en Infoq encontre un artículo de interoperabilidad de .Net y JMS, es algo por demas interesante debido a la cantidad de implementaciones que existen hoy de Middlewares que usan JMS.

El uso de mensajes es una de las soluciones mas escalables a la hora de realizar integraciones entre sistemas.

Ademas existe una extensa literatura, y patrones sobre integración utilizando esta técnica.


Para mas info sobre estos patrones visitar la pagina de Enterprise integration patterns

viernes, marzo 09, 2007

Implementing an Enterprise Services Architecture

Implementing an Enterprise Services Architecture

Una guia como para arrancar con la implementacion de arquitecturas ESOA.

Esta interesante, y despeja algunas dudas que surgen a la hora de ponerse a trabajar en ese topico.

lunes, febrero 26, 2007

WS-*/REST Wars


Estoy leyendo últimamente muchos post de lo que parece una batalla por establecer cual es la mejor arquitectura para aplicaciones basadas en servicios o en recursos si hablamos en terminos de REST.

Por un lado esta los WS-REST y por otro todo el stack WS-*, y están los detractores y los defensores de cada uno de estos estilos, lo que mas me llama la atención es el fervor casi religioso con el que cada uno defiende el estilo que le parece mas correcto.
Mi conclusión es que REST es un estilo que puede servir en ciertos casos y en otros no, lo mismo que WS-*.

Creo que es trabajo del arquitecto poder apartarse de estos fanatismos y poder decidir en base a criterios uniformes y bien establecidos, donde la desicion que se tome este orientada a cumplir con una serie de objetivos y no con una tendencia o moda de la comunidad.

Otra guerra muy interesante y también graciosa por el tono de alguno de los POST es la de XFire y AXIS2.



sábado, febrero 10, 2007

Business Process Management - BPM


BPM es una de esas disciplinas que la gente que siempre se dedico a desarrollos de sistemas a veces ve pasar medio de costado, o directamente ni saben de que se trata, como era mi caso hace un tiempo atrás.

In an Nutshell la practica de BPM se encarga de la administración de los procesos de la organización las principales actividades que lleva a cabo son:
  • Diseño Modelado de los procesos
  • Ejecución de los procesos
  • Optimizacion de los procesos
  • Monitoreo de los procesos
Hoy en día la sigla BPM es mucho mas conocida que hace varios años atras, recuerdo que la primera vez que tuve un acercamiento fue en 1998 aproximadamente, cuando fui a una reunión en un banco mayorista, y la gente que estaba modelando los procesos del banco nos hizo una demostración de una herramienta llamada Aris, vimos cosas muy interesantes a nivel de modelado y de simulación de procesos, el problema es que necesitábamos ademas poder de alguna forma ejecutar esos procesos, y la plataforma no contaba con esas posibilidades.
Pasaron algunos años para que requerimientos de ese tipo puedan ser cumplidos utilizando herramientas y estandares de mercado, hoy contamos con varios de estos estandares y con todo el empuje que están recibiendo las arquitecturas orientadas a servicios.

Acá es donde entra a tener mucha mas importancia BPM, si bien ya de por si es una disciplina muy importante para las organizaciones, esta importancia se potencia mas con la disponibilizacion de los procesos y la creación de ecosistemas donde coexisten sistemas heterogeneos, y donde la próxima generación de aplicaciones sera lo que se llaman Composite aplications (tema que va a dar mucho mas que hablar en el futuro).
Si bien las Composite aplications no son nuevas, la disponibilizacion de los procesos de negocios como servicios para construir sistemas si es algo mas nuevo, y para poder generar respuestas a la velocidad con que se generan los cambios las empresas necesitan mayor flexibilidad en sus procesos de negocios, pero suelen chocarse con la barrera de los sistemas, los cuales no pueden responder con la velocidad requerida para la implementacion de estos cambios.
Hoy por hoy recien se esta empezando a ver la necesidad de la reutilizacion, pero ya no a nivel de codigo, sino a nivel de procesos, y en el futuro vamos a empezar a escuchar mas sobre nuevos roles como el de Business Process Expert , rol que va actuar como nexo entre lo que es procesos y el area que va a implementarlos.