Universidade Tecnológica Federal do Paraná
Campus Cornélio Procópio
Computação Orientada a Serviços
Elias Canhadas Genvigir
Roteiro de Apresentação
• Introdução
• Problema
• Computação Orientada a Serviços
• Serviços
• SOAP
• WSDL
• UDDI
• SOA
Introdução
• Objetivo inicial:
Apresentar aula de revisão dos conceitos sobre Web Services.
• Tema.................:
Computação Orientada a Serviços, abordando seus princípios.
• Desenvolvimento:
Explorar os fundamentos da Computação Orientada a Serviços e
observar de que forma ela pode apresentar soluções para o
desenvolvimento de sistemas.
1) Exposição de slides
2) Apresentação de exemplos
Problema
Organizações são cada vez mais dependentes da sua infra-estrutura de Tecnologia
da Informação.
Dependência...........:
Tomada de decisões;
Redução de custos;
Gerenciamento de recursos;
Outros.
Desafio: Organizações desenvolverem soluções próprias para cada uma de suas
necessidades.
Problemas:
Controle da comunicação entre diferentes aplicações;
Reuso de componentes; e
Comunicação de sistemas existentes com novas tecnologias.
(RAKIC; MEDVIDOVIC, 2001)
Problema
1.
De que maneira a Computação Orientada a Serviços pode contribuir para
solucionar os problema apresentados?
Três classes de problemas:
•os ambientais
•os organizacionais
• e os de fatores técnicos (associados ao processo)
Computação Orientada a Serviços - SOC
BSD Sockets
CORBA, RMI,
DCOM, COM, DDE,
OLE, .NET...
NFS - Sun
SMB - Microsoft
RPC
Sistemas
Distribuídos
Sockets
Serviços
Web
Cliente/
Servidor
XDR
Stubs e
Skeletons
1970
1980
IDL
3 camadas
1990
2000
Computação Orientada a Serviços - SOC
- Três principais elementos:
1. Serviços Web.
2. Arquitetura Orientada a Serviços – SOA.
3. Gerenciamento de Processos de Negócio – BPM.
- Extensible Markup Language – XML como elo de convergência.
Serviço Web
- Agrega: interoperabilidade de
serviços, independência de
plataforma, reuso e suporte a
processos de negócio.
Computação Orientada
a Serviços
Gerenciamento de
Processos de
Negócio
Arquitetura
Orientada a
Serviços
Primeiro Elemento do SOC
Serviços
Um serviço é um local de uma rede em que um software recebe e envia,
opcionalmente, mensagens.
•Padrões de troca de mensagens;
•Contrato entre requisitor e fornecedor através de dados da mensagem;
•Metadados descrevem o endereço de rede para o serviço, as operações
que ele suporta, seus requisitos para a confiabilidade, segurança e
controle de transações.
É dividido em três partes
• Duas dessas partes são chamadas de camadas;
• e a outra de implementação.
Partes de um Serviço
continuação…
•A primeira camada – Mapeamento
•A segunda camada – Descrição
•A terceira parte - Implementação do serviço
Camada de
Mapeamento
Serviço
Implementação
do Serviço
Serviço
Implementação
do Serviço
Camada de
Descrição do
Serviço
Serviço
Implementação
do Serviço
Serviço
Implementação
do Serviço
Partes de um Serviço
Camada 1: Mapeamento - consiste dos padrões de troca e elementos
de comunicação como o endereço de rede do serviço.
Camada 2: Descrição - contem a descrição da implementação do
serviço, ou seja, as operações suportadas e os requisitos de segurança, confiabilidade e
controle de transações.
Terceira parte: Implementação do serviço ou agente executável (MAAMAR et al.,
2004), consiste da própria implementação das operações do serviço e pode ser feita para
qualquer ambiente através de variáveis de execução definidas, tipicamente, por sistemas
de software e/ou linguagens de programação.
Serviço Web
• Especialização de um serviço.
• É uma aplicação programável que é acessível como um componente através
de protocolos desenvolvidos para a Web.
• A arquitetura de um Serviço Web consiste de especificações:
•Simple Oriented Protocol - SOAP
•Web Services Description Language - WSDL
•Universal Description Discovery and Integration – UDDI
Serviço Web
continuação…
Podem fazer uso de fraco acoplamento permitindo que programas que realizam tarefas
simples interajam entre si provendo serviços mais amplos.
Funcionamento:
•
•
•
•
Interação de um serviço requisitante com um serviço provedor através de descritores.
Publicação da descrição do Serviço Web em WSDL.
O requisitor acessa essa descrição usando ou não o UDDI.
A execução de um serviço no provedor é requerida enviando as mensagens através do
SOAP.
Registro do Serviço
Pesquisa em
UDDI ou WSDL
Requisitor do
Serviço
Registra em
UDDI
Vincula em
SOAP
Publica em
WSDL
Provedor do
Serviço
Simple Object Access Protocol - SOAP
continuação…
• O SOAP é um protocolo projetado para a troca de informações estruturadas em
ambientes descentralizados e distribuídos;
• Definido pelo World Wide Web Consortium (W3C) http://www.w3.org/TR/soap/
• Está na versão 1.2;
• Baseado em XML;
• Define um mecanismo simples para expressar a semântica de aplicações;
• Fornece um modelo de empacotamento para codificação de dados dentro dos
módulos;
• Não é necessário o conhecimento do seu funcionamento para se criar e consumir um
Web Service.
Simple Object Access Protocol - SOAP
continuação…
Consiste de três partes:
1) um envelope que define uma estrutura para descrever o que compõe a mensagem e como
processá-la,
2) um grupo de regras codificadas para expressar instâncias de tipos de dados definidos pela
aplicação,
3) uma convenção para representar chamadas e respostas remotas. O SOAP pode ser usado
potencialmente em combinação com uma variedade de outros protocolos; entretanto, sua
definição original descreve seu uso sobre o protocolo HTTP.
SOAP – Estrutura XML
Envelope
Header
Dados de sistema
(opcional)
<SOAP-ENV:envelope>
<SOAP-ENV:header>
</SOAP-ENV:header>
<SOAP-ENV:body>
<SOAP-ENV:fault>
</SOAP-ENV:fault>
</SOAP-ENV:body>
</SOAP-ENV:envelope>
Body
Endereçamento
Segurança
Transações
...
Fault
Dados de negócio
Tipo de erro
Mensagem de erro
Web Services Description Language - WSDL
• O WSDL é um formato escrito em XML para descrever serviços como uma coleção
de elementos para comunicação capazes de executar trocas de mensagens.
• É um vocabulário XML para criar contratos de serviços;
• Cada serviço é definido por um contrato WSDL;
• O contrato WSDL contém toda a informação necessária para criar um cliente capaz de
comunicar com o Web Service;
• Definido pelo World Wide Web Consortium (W3C) http://www.w3.org/TR/wsdl20/
• Versão 2.0;
• Várias ferramentas para criar os contratos WSDL – AXIS, JAX-WS.
Web Services Description Language - WSDL
continuação…
• Define padrões para automatizar a comunicação entre aplicações.
• Encapsula as funcionalidades de um serviço em um alto nível de abstração.
• Descreve um Serviço Web em duas partes:
1)
Abstrata - descreve em XML os termos dos envios e recebimentos de mensagens
independentemente da linguagem utilizada no sistema.
2)
Concreta - especifica os padrões de transporte e de interfaces, incluindo as
implementações de interfaces.
Web Services Description Language - WSDL
continuação…
Exemplo -WSDL
01 <?xml version="1.0" encoding="UTF-8"?>
02
03 <definitions name="Hello"
04 targetNamespace="http://hello"
05 xmlns:tns="http://hello"
06 xmlns="http://schemas.xmlsoap.org/wsdl/"
07 xmlns:xsd="http://www.w3.org/2001/XMLSchema"
08 xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/">
09 <types>
10 <xsd:schema elementFormDefault="qualified"
11
targetNamespace="http://hello">
12
13 <xsd:complexType name="sayHelloType">
14
<xsd:sequence>
15
<xsd:element name="name" type="xsd:string" />
16
</xsd:sequence>
17 </xsd:complexType>
18 <xsd:element name="sayHello" type="tns:sayHelloType" />
19
20 <xsd:complexType name="sayHelloResponseType">
21 <xsd:sequence>
22 <xsd:element name="return" type="xsd:string" />
23 </xsd:sequence>
24 </xsd:complexType>
25 <xsd:element name="sayHelloResponse” type="tns:sayHelloResponseType" />
26
27 </xsd:schema>
28 </types>
29
O 'service' define um 'port' (linhas 57-61) que é uma interface concreta de acesso ao serviço. O
endereço de acesso é indicado na linha 59.
O 'port' concretiza a interface abstracta do 'port type' (linhas 37-42), através do 'binding' (44-55).
O 'port type' define a 'operation' "sayHello" (38-41), que tem como 'input' e 'output',
respectivamente as 'message': "tns:sayHelloRequest" (30-32) e "tns:sayHelloResponse" (33-35).
Cada 'message' tem pelo menos uma 'part'. Cada 'part' é definida por um tipo ou elemento XSD.
Neste caso são usados os elementos "sayHello" (18) e "sayHelloResponse" (25).
Os tipos são os 'complexTypes' "sayHelloType" (13-17) e "sayHelloResponseType" (20-24).
Os Namespaces (3-8, 11) permitem saber onde são definidos os vários elementos XML que são
necessário no WSDL.
30 <message name="sayHello">
31 <part name="parameters" element="tns:sayHello" />
32 </message>
33 <message name="sayHelloResponse">
34 <part name="result" element="tns:sayHelloResponse" />
35 </message>
36
37 <portType name="HelloPortType">
38
<operation name="sayHello">
39
<input message="tns:sayHello" name="sayHello"/>
40
<output message="tns:sayHelloResponse" name="sayHelloResponse"/>
41
</operation>
42 </portType>
43
44 <binding name="HelloBinding" type="tns:HelloPortType">
45 <soap:binding transport="http://schemas.xmlsoap.org/soap/http" style="document" />
46
<operation name="sayHello">
47
<soap:operation soapAction="" />
48
<input>
49
<soap:body use="literal" />
50
</input>
51
<output>
52
<soap:body use="literal" />
53
</output>
54
</operation>
55 </binding>
56
57 <service name="HelloService">
58
<port name="HelloPort" binding="tns:HelloBinding">
59
<soap:address location="http://server:port/context/endpoint" />
60 </port>
61 </service>
62
63 </definitions>
WSDL de um Web Service "Hello
World", que tem uma operação
"sayHello", que recebe um nome e
devolve uma saudação.
Universal Description Discovery and Integration – UDDI
O UDDI provê uma plataforma independente para descrever serviços, características
de negócios e a integração de serviços de negócio usando como meio a Internet.
Definido pelo Organization for the Advancement of Structured Information Standards
(OASIS) http://uddi.org/pubs/uddi_v3.htm
Version 3.0.2
O principal foco da UDDI é a definição de um grupo de elementos que suporte a
descrição e apresentação de:
(1) negócios, organizações e provedores de serviços Web,
(2) disponibilidade de serviços Web,
(3) interfaces técnicas que podem ser usadas para acessar os serviços.
Plataforma
Além dos recursos apresentados, as especificações para Serviço Web possuem em seus
modelos padrões para:
• Segurança;
• Confiabilidade;
• Transações ; e
• Gerência de metadados.
Elementos foram padronizados e definidos com a finalidade de fornecer soluções
necessárias para suportar uma grande variedade de problemas em projetos.
Exemplo
Serviço para somar dois números em uma operação.
1) Criar um projeto -> Menu File -> new Project... -> Web -> Web Application -> Project
Name: “TesteWS” -> Server -> Apache Tomcat 6.x.
2) Na Pasta Source Packages -> botão direito -> new folder -> nome: “ws”.
3) No Frame Services -> botão direito no Apache Tomcat -> start.
4) Botão direito sobre o projeto TesteWS -> new Web Service -> Name:
“WSCalculadora” -> package -> “ws”
5) Design -> add operation -> name: “add” - type: int
parameters-> add
i: int
j: int
6) Aba Source ->Mudar o código da operação add:
@WebMethod(operationName = "add")
public int add(@WebParam(name = "i")
int i, @WebParam(name = "j")
int j) {
//TODO write your implementation code here:
return 0;
}
@WebMethod(operationName = "add")
public int add(@WebParam(name = "i")
int i, @WebParam(name = "j")
int j) {
int k=i+j;
return k;
}
Exemplo
7) Executar o projeto.
8) Testar o WS:
Usando o WS
1) Na pasta Source Packages -> botão direito -> new folder -> nome: “serv”.
2) Botão direito sobre o projeto TesteWS -> new Web Service Client... -> Project ->
botão Browse -> TesteWS -> “WSCalculadora” -> Package: digitar: “wscliente”
3) Botão direito sobre o projeto TesteWS -> new Servlet -> Class Name:
“SUsaCalculadora” -> Package: “serv”.
Usando o WS
4) No método processRequest Remover os comentários e adicionar linhas em branco.
Usando o WS
5) Arrastar a operação add do cliente para o espaço em branco.
6) Mudar os valores 0 para outros.
Usando o WS
7) Editar o index.jsp
7) Executar o Projeto
Segundo Elemento do SOC
Arquitetura Orientada a Serviço - SOA
SOA é um estilo de projeto e de desenvolvimento que guia os aspectos da criação
de serviços durante todo seu ciclo de vida.
Entidades resolvem ou dão suporte a seus problemas e necessidades.
Não existe necessariamente uma relação “um para um” entre as necessidades e as
capacidades de uma organização;
A Granularidade entre necessidades e capacidades variam do fundamental ao
complexo.
Uma dada necessidade pode requerer a combinação de numerosas capacidades
enquanto uma simples capacidade pode ser orientada a mais de uma necessidade.
Arquitetura Orientada a Serviço - SOA
continuação…
SOA fornece uma estrutura para alinhar necessidades e potencialidades permitindo
combinar as potencialidades e dirigí-las às necessidades.
Essa estrutura é composta de sete conceitos de projeto que formam o modelo de
definição do SOA:
• Serviço - permite o acesso a uma ou mais capacidades,
• Visibilidade – capacidade de interação entre provedor e requisitor,
• Interação - modo de desempenho e execução de ações do serviço,
• Aspectos do Mundo Real – propósito associado a interação do serviço,
• Descrição do Serviço – informações requeridas para usar um serviço,
• Contrato e Políticas – padrões para usar ou desenvolver um serviço,
• Contexto de Execução – parte instanciada de uma interação.
Terceiro Elemento do SOC
Business Process Management - BPM
O terceiro elemento que compõem o SOC é o Business Process Management – BPM.
Possui como principal foco o controle e uso de processos.
1)Na década de 90 era visto como um modelo associado a programas de qualidade.
Ponto de Partida
Preparação
Seleção do
Processo
Descrição do
Processo
Quantificar
o Processo
Ciclo contínuo de melhoria
Seleção das
Melhorias
Para o
Processo
Implementação
Business Process Management - BPM
continuação…
2) A partir do ano 2000 conceitos tecnológicos foram agregados.
• Business Process Management System – Composto de cinco elementos:
Usuário
Informações em
tempo real
Monitoração das Atividades de Negócio
Modelagem
de Processos
Execução de
Processos
Monitoração
de Processos
Web Services Business Process Execution Language – WS-BEPL
•
BPMS necessita de um protocolo de negócio para controle.
BPEL - Principal implementação para protocolo de negócio, definido pelo Organization for the
Advancement of Structured Information Standards (OASIS) http://docs.oasisopen.org/wsbpel/2.0/OS/wsbpel-v2.0-OS.html
•
Permite descrever, claramente, em uma plataforma independente, os aspectos comportamentais do
negócio.
•
Baseado em 10 metas:
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
Serviços Web como base.
XML como formato de dados.
Possui um grupo de conceitos que suportam processos abstratos e executáveis
Controle de comportamento.
Manipulação de dados.
Propriedades e correlação (instância de processos).
Suporte ao Ciclo de vida.
Modelo para execução de transações.
Modularização.
Compatibilidade com funcionalidades dos serviços Web
Composição, Orquestração e Coreografia
O mecanismo de invocação de mensagens de um serviço Web é denominado Composição.
Dois tipos de Composição:
Orquestração
Contrato
Coreografia
SOAP
BPEL
SOAP
SOAP
Contrato
Contrato
Serviço
Web
Serviço
Web
BPEL
BPEL
Combinando BPM, SOA e Serviços Web
1º Modelo – Aplicações e Tecnologias
2º Modelo – Aplicações, Tecnologias
e Serviços
Serviço 1
Aplicações
Aplicação 1
Aplicação 2
Serviço 2
Serviço 3
Plataforma de Serviços Web
Aplicação 3
Camada de
Serviços
Camada de
Aplicações
Aplicações
Aplicação 1
Aplicação 2
Aplicação 3
Camada de
Aplicações
Tecnologias
Camada de
Tecnologias
Tecnologia 1
Tecnologia 2
Tecnologia 3
Tecnologias
Tecnologia 1
Tecnologia 2
Tecnologia 3
Camada de
Tecnologias
Combinando BPM, SOA e Serviços Web
3º Modelo – Aplicações, Tecnologias, Serviços e Processos
BPM
Processo 3
Processo 1
Processo 4
Processo 2
Serviço 1
Processo 5
Serviço 2
Camada de
Processos de
Negócio
Serviço 3
Plataforma de Serviços Web
Camada de
Serviços
Aplicações
Aplicação 1
Aplicação 2
Aplicação 3
Camada de
Aplicações
Tecnologias
Tecnologia 1
Tecnologia 2
Tecnologia 3
Camada de
Tecnologias
continuação…
Vantagens e Desvantagens
Desvantagens
• SOAP – protocolo lento comparado a
protocolos Binários como o IIOP
• Aumento de complexidade
• Necessidade de gerenciar processos
Vantagens
• Protocolo simples, legível para humanos,
transparente para firewalls e assíncrono
•Fraco acoplamento, reutilização
• Diminuição de impacto nas mudanças nos
processos
Conclusão
•A Computação Orientada a Serviços surge como mais uma solução tecnológica.
•Deve ser avaliado a implicação do uso ou da alteração de tecnologias antecedentes
•Tendência para o fornecimento de software como um serviço.
•Aumento da complexidade: SOA, SOAP, WSDL, UDDI, BPEL, etc...
•Volta a conceitos já abordados mas pouco explorados: Workflow, fraco acoplamento,
processos.
Referências
RAKIC, M.; MEDVIDOVIC, N. Increasing the confidence in o-the-shelf components: a software connector-based
approach. In: SYMPOSIUM ON SOFTWARE REUSABILITY: PUTTING SOFTWARE REUSE IN CONTEXT SIGSOFT, 2001. Proceedings... [S.l.]: ACM Special Interest Group on Software Engineering, 2001. v. 46, p. 11-18.
MAAMAR, Z.; SHENG, Q. Z.; BENATALLAH, B.; AL-KHATIB, G. A three-level specification approach for an
environment of software agents and web services. Electronic Commerce Research and Applications, Elsevier, v. 3, n.
3, p. 214-231, may 2004.
Discusão
Documento Estruturado
• Um documento estruturado é composto por conteúdo (texto, figuras, etc) e
informação sobre como ele está organizado.
Exemplo: um artigo técnico é usualmente composto por:
"título", "autores", "resumo", "seções" e "bibliografia", nesta ordem.
Os componentes ou elementos entre aspas representam uma parte estrutural do
documento.
• Um documento estruturado pode ser apresentado ao usuário de diferentes formas:
Impresso em papel, na tela de um navegador, na tela de um notebook ou de um
telefone celular ou em equipamentos multimídia.
• Um documento estruturado também pode ser enviado para armazenamento ou
processamento por algum software especializado como um Gerenciador de Banco de
Dados.
O Processo de Marcação
• Um processamento de texto requer informações adicionais para interpretar o texto
natural e o documento que está sendo processado.
• Estas informações são chamadas “marcação” e servem para dois propósitos:
1.
2.
Separar elementos lógicos para o documento;
Especificar as funções de processamento para serem executadas sobre esses
elementos.
• Duas categorias para linguagens de marcação:
1.
2.
Marcação Procedural – Instruções de processamento complexas embutidas na
marcação do documento - sistema de editoração TeX.
Marcação Generalizada – Descreve a estrutura do documento e outros atributos em
vez de especificar o processamento a ser feito. Define como programas podem ser
usados para processar o documento. - SGML
• A Marcação generalizada não restringe documentos a uma única aplicação, estilo
de formatação ou sistema de processamento
Evolução cronológica
• SGML foi criada no final da década de 60 pelos pesquisadores da IBM Goldfarb,
Mosher e Lorie.
• Goldfarb provou em 1974 que um analisador sintático (parser) é capaz de validar
um documento SGML sem realmente processá-lo. Em 1986 o SGML tornou-se um
padrão internacional e foi amplamente adotada por como padrão para intercâmbio
e armazenamento de documentos
• SGML → HTML 1.0 → HTML... → XML → HTML 4.01 → XHTML.
Standard Generalized Markup Language - SGML
• O SGML não possui um conjunto pré-definido de tags e de elementos, ela é na verdade
uma meta-linguagem para especificar linguagens de marcação. Ela não possui uma
semântica pré-definida.
• A sintaxe de uma linguagem de marcação definida através do SGML é especificada
através de construções coletadas num documento denominado DTD (Document Type
Definition) que define:
1) declarações de elementos;
2) possíveis marcações válidas para o elemento (a ordem, a obrigatoriedade, a quantidade, etc,)
3) declarações de atributos, que especificam os tipos de valores de atributos, valores default,
etc.
• O DTD define uma gramática para a linguagem de marcação do documento. A declaração
de um elemento e de seus atributos no DTD utiliza a notação gramatical EBNF (Extended
Backus-Naur Form).
XML - Extensible Markup Language
• A XML é uma meta-linguagem de marcação criada a partir do SGML, e tem os
seguintes objetivos:
1.
Prover o intercâmbio de documentos através da Web de forma
independente aos sistemas operacionais ou formatos de arquivos,
2.
Suportar uma grande gama de aplicações, permitindo a definição de
elementos pelo usuário (ou aplicação) para estruturar documentos,
3.
Facilitar a análise de documentos XML por programas,
4. Ser legível por humanos,
5. Ter uma especificação formal para a marcação de documentos.
• Organizar Documentos
• Modelo comum para Compartilhar dados
XML
• XML tornou-se um padrão internacional em 1998.
• Ao contrário da SGML, a XML não requer um DTD para cada documento.
• Se o documento XML possui um DTD associado e segue a gramática
especificada pelo DTD, então ele é dito válido.
• A validação de um documento garante que os dados estejam completos,
colocados na ordem correta no documento e com os valores apropriados dos
atributos. Vários pacotes de software livres estão sendo disponibilizados para
verificar a boa formação e a "validação" de documentos XML.
XML
XML não possui um conjunto pré-definido de tags ou elementos como o HTML.
Em um documento XML tags para definir o significado dos dados, podem ser
definidos livremente de acordo com o domínio dos dados e da aplicação.
XML não provê mecanismos para apresentação de dados nem para ligação entre
documentos. Tais recursos são disponibilizados por outras especificações de
linguagens como, por exemplo, XSL ou XSLT (Extensible Stylesheet Language
Transformations) para estilos, e Xlink para especificação de links entre documentos.
Tecnologias XML
Validação:
• DTD;
• XML Schema - XML Schema Definition (XSD);
• TREX - Tree Regular Expressions for XML;
• RELAX NG.
Apresentação:
• CSS,
• XSLT,
• XHTML
Programação:
• SAX,
• DOM.
Desenho:
• SVG – Scalable Vector Graphics
Download

Aula 08: Arquitetura Orientada a Serviços