La arquitectura orientada a servicios parece ser cada vez más una cita caliente en estos días, pero después de preguntar por la oficina he descubierto que parece que tengo muchas definiciones diferentes para ella. ¿Cómo definirías SOA? ¿Cuál considerarías la definición oficial?Arquitectura orientada a servicios: cómo la definiría
Respuesta
Como dice Martin Fowler, significa diferentes cosas para diferentes personas. Su artículo sobre el tema es bastante bueno, aunque no es una definición completa.
http://martinfowler.com/bliki/ServiceOrientedAmbiguity.html
Se puede explicar, la dificultad viene con una definición concreta.
Un diseño SOA incluye componentes (es decir, servicios) que pueden ser utilizados por código independientemente de la implementación (es decir, cualquier SO o idioma). Una instancia única de un servicio también puede ser utilizada por múltiples aplicaciones, mientras que, por ejemplo, una DLL debería duplicarse para cada aplicación y requerir la misma tecnología de implementación que la aplicación de enlace.
Los servicios en un diseño SOA generalmente se implementan como servicios web interoperables.
me gustaría ir con:
Definir una serie de apátrida, cliente operaciones comerciales agnósticos crean deje sentir en múltiples aplicaciones .
Intenté definir SOA en one of my blog posts. Aquí hay un extracto ...
Durante años, ha sido una práctica estándar separar la funcionalidad en funciones, clases y módulos. La idea siempre ha sido que estos componentes más pequeños y altamente especializados son más fáciles de compartir y mantener que los bloques monolíticos de código.
Funcionalmente, SOA no es muy diferente. Los objetivos son los mismos: reutilización y mantenimiento sencillo. La mayor diferencia, en el caso de un servicio web SOA, es que la biblioteca compartida incluida en su aplicación se reemplaza por una llamada HTTP.
No hay una definición oficial como Ryan mencionó eariler. Sin embargo, considero que la visión de Thomas Erl sobre toda la orientación al servicio está bien estructurada y es relevante. Aquí está la definición de la arquitectura SOA de su SOA Glossary (more):
la arquitectura orientada a servicios representa un modelo arquitectónico que tiene como objetivo mejorar la agilidad y la rentabilidad de una empresa, mientras que la reducción de la carga global de la TI en una organización .
Thomas Erl es el autor de muchos títulos de SOA, la mayoría de ellos con el respaldo de proveedores de SOA como IBM, Oracle y Microsoft. Lo bueno de his books es que son los proveedores de SOA más independientes posible. Significa que aprende más acerca de la orientación del servicio y menos sobre el middleware de algún proveedor que admite SOA.
Wikipedia: "A SOA es una arquitectura de software que utiliza servicios de software débilmente acoplados para satisfacer los requisitos de los procesos de negocios y usuarios de software.Los recursos en una red en un entorno SOA están disponibles como servicios independientes a los que se puede acceder sin tener conocimiento de la implementación de su plataforma subyacente. "
SOA no es tan nuevo, pero tiene el potencial de lograr cosas sorprendentes. tiene que estar preparado para eso: la empresa tiene que pensar en procesos y ese es el gran problema
Estoy de acuerdo con todas las personas que te señalan a Fowler en esto. Básicamente funciona así: la arquitectura orientada al servicio tiene reputación como bueno, cualquier cosa que las personas quieran asociar con lo bueno lo llaman SOA. En realidad, tiene muchas desventajas y puede crear un Gridlock orientado a servicios o una arquitectura orientada a la dependencia.
Aquí está mi ir en una definición: Service Oriented Architecture es un enfoque de integración de sistemas y reutilización de códigos donde las aplicaciones dependen de la conexión a servicios proporcionados por otras aplicaciones en ejecución a través de la red. Esto es distinto de las arquitecturas de los componentes, donde los componentes de software se comparten de forma estática entre las aplicaciones en forma de bibliotecas o SDK, por ejemplo.
Una aclaración aquí - "arquitectura orientada a servicios es una integración y el código de enfoque reutilización sistemas en los que las aplicaciones dependen de conexión a los servicios prestados por otras aplicaciones que se ejecutan a través de la red."
Tengo un escenario en el que dos aplicaciones j2ee se han integrado utilizando mensajes basados en eventos. Aquí las frases anteriores de integración de sistemas y que conectan a los servicios proporcionados por otras aplicaciones en ejecución a través de la red son válidas. ¿Puedo llamar a esto SOA?
Los siguientes principios se mantenga bien aquí 1) apatridia 2) orientada mensaje - de acoplado) extensible de acoplamiento flexible de hecho 3.
Sin embargo, lo siguiente no se aplica 1) independencia de la plataforma: ninguna de las aplicaciones que se integran ha sido diseñada para funcionar en una plataforma diferente. 2) Las aplicaciones son aplicaciones j2ee simples que no se han diseñado con todos los conceptos de SOA.
Aquí hay una definición para usted:
SOA - Software a través de Architected. La inclusión de un marco de interfaz funcional inútil y abarrotado llamó a una arquitectura en un sitio web bonito con una carpeta gráfica 3d que volaba de un lado a otro donde "dir/s> a.txt | ftp -s: upload.ftp" hizo el trabajo.
Los componentes de software no son ladrillos, no se pueden generalizar mediante patrones funcionales comunes y la arquitectura emerge en la empresa de las buenas prácticas, no del buen diseño. El software no está diseñado, está diseñado.
SCRUM ON!
- 1. ¿Qué es la arquitectura orientada a servicios?
- 2. ¿Qué es SOA (arquitectura orientada a servicios)?
- 3. Sugerencias de Arquitectura Orientada a Servicios
- 4. Arquitectura Orientada a Servicios y Diseño Dirigido por Dominio
- 5. ¿Cómo se relacionan entre sí la arquitectura orientada a servicios y el desarrollo basado en componentes?
- 6. Arquitectura de servicios RESTful pregunta
- 7. Diseño/Arquitectura pregunta: reversiones con servicios remotos
- 8. ¿Cómo escribo pruebas de unidad útiles para una aplicación orientada principalmente a servicios?
- 9. cómo implementar servicios y repositorios en arquitectura de cebolla?
- 10. Programación orientada a objetos
- 11. Servicios RIA frente a los servicios WCF
- 12. ¿Qué es la programación orientada a aspectos?
- 13. ¿Qué es la programación orientada a datos?
- 14. Visibilidad orientada a objetos php
- 15. ¿Cómo definiría un método simple "min" en obj-c
- 16. programación orientada a objetos android
- 17. ¿Dónde encuentro una introducción buena, breve y orientada a la arquitectura de Java Swing GUI para desarrolladores web?
- 18. Saltando a la arquitectura N-Tier con WCF?
- 19. Aprendiendo a pensar en la forma orientada a objetos
- 20. Con respecto a la programación orientada a objetos F #
- 21. ¿Ir a puerto a la arquitectura AVR?
- 22. Programación orientada a aspectos en Clojure
- 23. Arquitectura de programación funcional
- 24. Arquitectura de servicios OSGi: creación de servicio a pedido del consumidor
- 25. La aplicación de programación orientada a objetos con jQuery
- 26. ¿Por dónde empiezo con la Programación Orientada a Aspectos?
- 27. Programación orientada a aspectos en android
- 28. Programación orientada a aspectos en Java
- 29. Programación orientada a aspectos en C#
- 30. programación orientada a objetos: buscando buenos tutoriales
+1 "cliente agnóstico sin estado" lo más claro que he oído –