faculdade dom bosco de porto alegre web services genéricos

Transcrição

faculdade dom bosco de porto alegre web services genéricos
FACULDADE DOM BOSCO DE PORTO
ALEGRE
CURSO DE SISTEMAS DE INFORMAÇÃO
WEB SERVICES GENÉRICOS
APLICADOS
Ramon Martins da Silva
Porto Alegre, julho de 2007.
FACULDADE DOM BOSCO DE PORTO
ALEGRE
CURSO DE SISTEMAS DE INFORMAÇÃO
WEB SERVICES GENÉRICOS
APLICADOS
Ramon Martins da Silva
Monografia desenvolvida durante a disciplina de
Trabalho de Conclusão de Curso e apresentada ao
Curso de Sistemas de Informação da Faculdade Dom
Bosco de Porto Alegre, como pré-requisito para a
obtenção do título de Bacharel em Sistemas de
Informação.
Orientador: Prof. Dr. Luis Fernando Fortes Garcia
Porto Alegre, julho de 2007.
DEDICATÓRIA
Dedico este trabalho especialmente a minha
família por sua participação fundamental em todas as
minhas conquistas.
AGRADECIMENTOS
Em primeiro lugar agradeço a Deus por iluminar
meu caminho e a minha namorada Gabriela por sempre
estar ao meu lado.
Estendo meus agradecimentos ao orientador Dr.
Luis Fernando Fortes Garcia.
SUMÁRIO
LISTA DE FIGURAS .......................................................................................................... 7
RESUMO ............................................................................................................................. 8
1 INTRODUÇÃO ............................................................................................................. 10
2.1 OBJETIVOS .............................................................................................................. 11
2.2 MOTIVAÇÃO ............................................................................................................ 12
2 REFERENCIAL TEÓRICO......................................................................................... 13
2.1 EXTENSIBLE MARKUP LANGUAGE (XML) ............................................................... 13
2.1.1 Documentos XML........................................................................................... 14
2.1.2 Declaração ...................................................................................................... 15
2.1.3 Comentários .................................................................................................... 16
2.1.4 Instruções de Processamento ........................................................................... 16
2.1.5 Elementos ....................................................................................................... 16
2.2 SERVICE ORIENTED ARCHITECTURE (SOA) ............................................................. 17
2.2.1 Sistemas Conectados ....................................................................................... 17
2.2.2 Princípios da arquitetura baseada a serviços..................................................... 19
2.2.3 Serviço ............................................................................................................ 19
2.2.4 Componentes................................................................................................... 20
2.2.5 Modelagem de sistemas orientados a serviço ................................................... 21
2.2.6 Vantagens da utilização de SOA...................................................................... 23
2.3 WEB SERVICES ....................................................................................................... 23
2.3.1 Arquitetura ...................................................................................................... 24
2.3.1.1 Simple Object Access Protocol (SOAP)...................................................... 25
2.3.1.2 Web Service Description Language (WSDL) .............................................. 27
2.3.1.3 Universal Description Discovery and Integration (UDDI) ........................... 28
2.4 REFLECTION ........................................................................................................... 29
2.4.1 Aspectos Matemáticos da Reflexão ................................................................. 29
2.4.2 Reflexão em Linguagens Orientadas a Objeto.................................................. 30
2.4.3 Cenário de utilização ....................................................................................... 30
2.4.4 Meta-Objetos e o processo de Reflexão ........................................................... 31
2.4.5 .NET Reflection .............................................................................................. 32
2.5 REMOTING .............................................................................................................. 33
2.5.1 Arquiteturas distribuídas.................................................................................. 33
2.5.2 Tecnologias distribuídas .................................................................................. 36
2.5.3 Objetos Distribuídos........................................................................................ 37
2.5.4 Binding de Objetos.......................................................................................... 37
2.5.4.1 Early Binding ............................................................................................. 38
2.5.4.2 Late Binding ............................................................................................... 39
2.5.5 COM Callable Wrapper (CCW) ...................................................................... 40
2.5.6 Serialização de Objetos ................................................................................... 41
2.5.7 .NET Remoting ............................................................................................... 44
2.5.7.1 Arquitetura ................................................................................................. 45
2.5.7.2 Ativação de Objetos.................................................................................... 47
2.5.7.3 Benefícios das aplicações distribuídas......................................................... 47
3 CENÁRIOS ................................................................................................................... 49
3.1 MODELO TRADICIONAL DE UTILIZAÇÃO DE WEB SERVICES ...................................... 50
4 WEB SERVICE GENÉRICO....................................................................................... 52
4.1 FUNCIONAMENTO.................................................................................................... 54
5 ESTUDO DE CASO...................................................................................................... 56
5.1 VALIDAÇÃO ............................................................................................................ 58
6 CONCLUSÕES ............................................................................................................. 60
7 REFERÊNCIAS BIBLIOGRÁFICAS ......................................................................... 62
LISTA DE FIGURAS
Figura 1 - Documento XML bem formado ........................................................................... 15
Figura 2 - Declaração de um documento XML..................................................................... 15
Figura 3 - Pilares dos sistemas conectados ........................................................................... 18
Figura 4 - Modelo da arquitetura orientada a serviços ......................................................... 21
Figura 5 - Modelo de orientação a serviços em três partes .................................................... 22
Figura 6 - Modelo básico de acesso a um Web Service ........................................................ 25
Figura 7 - Constituição de uma mensagem SOAP ................................................................ 25
Figura 8 - Exemplo de um envelope de requisição RPC ....................................................... 26
Figura 9 - Tráfego de mensagens via XML .......................................................................... 27
Figura 10 - Descrição gerada automaticamente pelo WSDL................................................. 27
Figura 11 - WSDL Preâmbulo.............................................................................................. 28
Figura 12 - Biblioteca de Classes do .NET Framework ........................................................ 32
Figura 13 - Exemplo de utilização da classe System.Type.................................................... 33
Figura 14 - Modelo Cliente/Servidor.................................................................................... 34
Figura 15 - Modelo N-Tier................................................................................................... 35
Figura 16 - Modelo Peer-to-Peer .......................................................................................... 35
Figura 17 - Seleção de objetos para Automação ................................................................... 38
Figura 18 - Automação de objetos via early-binding ............................................................ 39
Figura 19 - Automação de objeto via late-binding ................................................................ 40
Figura 20 - Chamada um objeto gerenciado (.NET) ............................................................. 40
Figura 21 - Classe que será serializada ................................................................................. 42
Figura 22 - Classe que invoca o processo de serialização ..................................................... 42
Figura 23 - Classe que será serializada ................................................................................. 43
Figura 24 - Processo de serialização/desserialização ............................................................ 44
Figura 25 - Arquitetura .NET Remoting............................................................................... 45
Figura 26 - Funcionamento do marshal-by-value ................................................................. 45
Figura 27 - Funcionamento do marshal-by-reference............................................................ 46
Figura 28 - Acesso a tipos de instância context-bound.......................................................... 46
Figura 29 - Modelo Web Services ........................................................................................ 50
Figura 30 - Modelo Web Services Genéricos ....................................................................... 53
Figura 31 - Web Service Genérico - WSDL ......................................................................... 54
Figura 32 - Integrando as funcionalidades da Aplicação Web............................................... 57
RESUMO
Esta monografia apresenta uma proposta de solução de sistemas distribuídos
utilizando Web Services Genéricos. O projeto de sua arquitetura foi baseada na análise
realizada das principais tecnologias .NET (Reflection, Remoting) com objetivo de
utilizar as melhores práticas e garantir a confiabilidade desta solução. Seu
desenvolvimento foi originado a partir das práticas observadas pela arquitetura
orientada a serviços (SOA) e propõe estender este conceito, tornando a utilização dos
Web Services mais eficiente na construção de sistemas distribuídos. São apresentados
os conceitos envolvidos, exemplos que justificam a utilização desta tecnologia além de
vantagens para utilização deste tipo de solução.
Palavras-chaves: Web Services; sistemas distribuídos; SOA.
10
1
INTRODUÇÃO
A informação é, atualmente, o bem que mais demanda investimento em pesquisa
devido ao seu alto valor agregado. Além disto, a quantidade de informação gerada por
uma instituição é muito grande e, na maioria das vezes, maior do que sua infra-estrutura
comporta. Por este motivo, mecanismos de manipulação, integridade e segurança de
acesso são permanentemente revisados para atender as crescentes, e a cada dia mais
complexas, necessidades das instituições.
Entretanto, um problema eminente é a capacidade de troca de informações entre
instituições e/ou sistemas. É aparente a inviabilidade de uma instituição centralizar toda
a informação de que necessita em um mesmo sistema de informação. Por conta disto, os
sistemas devem ser capazes de interagir e compartilhar informação de maneira eficiente
e segura.
Este trabalho descreve o funcionamento dos Web Services, um padrão de
comunicação e compartilhamento de informações utilizado para realizar a comunicação
de informação entre aplicativos. Este padrão utiliza a internet para realizar este
intercâmbio, além de padrões universais que possibilitam a interoperabilidade entre
sistemas de maneira mais transparente e produtiva.
Este documento está organizado como descrito a seguir: O segundo capítulo tem
o objetivo de realizar uma revisão teórica sobre os principais temas relacionados, tais
como: XML, SOA, Web Services, Reflection, Remoting, Sistemas Conectados, entre
outros conceitos-chave para a compreensão de seu conteúdo.
O terceiro capítulo tem o objetivo de apresentar os cenários de ambientes
distribuídos contextualizando a utilização de Web Services para a troca de informações
e demonstrar os benefícios desta tecnologia.
11
O quarto capítulo apresenta o conceito de Web Service Genérico que estende o
conceito dos Web Services convencionais em um cenário mais flexível. Além disto,
analisa determinados aspectos que subsidiam a concepção e aplicabilidade deste
conceito em ambientes distribuídos.
O quinto capítulo apresenta um estudo de caso onde é possível a verificação do
comportamento e da aplicabilidade dos Web Services Genéricos na integração de
sistemas heterogêneos, ou seja, entre sistemas gerenciados (.NET) e não gerenciados
(Win32).
1.1
Objetivos
O principal objetivo deste trabalho é projetar uma solução baseada na
generalização dos conceitos de orientação a serviços e tecnologias de sistemas em
ambientes distribuídos capaz de responder a necessidades mutáveis. Entre outros
objetivos, destacam-se:
•
Realizar uma análise do funcionamento e na concepção de aplicações
construídas sobre arquiteturas baseadas em serviços (SOA), bem como
visualizar sua aplicabilidade na construção de sistemas;
•
Estudo do protocolo SOAP buscando analisar seu funcionamento no processo de
empacotamento dos dados para transmissão dos pacotes;
•
Estudar o padrão XML, cujo formato já é definido como universal para o tráfego
de informações. Além disto, buscar contextualizar este formato de texto de
marcação em um cenário de compartilhamento de serviços através de Web
Services;
•
Estudar os conceitos envolvidos na construção de Web Services, bem como sua
arquitetura e tecnologias envolvidas. Outrossim, validar a sua eficácia quanto a
interoperação entre sistemas;
•
Estudar tecnologias .NET que subsidiem a construção dos Web Services no
intuito de implementar uma solução baseada neste framework com base nos
demais conceitos avaliados;
•
Desenvolver um Web Service Genérico capaz de refletir e utilizar as
funcionalidades de qualquer aplicação .NET;
•
Validar a utilização deste artefato em um estudo de caso.
12
1.2
Motivação
Este cenário dos sistemas distribuídos absolutamente variável e cujas
necessidades estão voltadas para a solução efetiva dos requisitos de negócio e não mais
na aplicabilidade tecnológica motivou a construção deste trabalho. Igualmente, se
relacionam como itens motivacionais desta proposta:
•
necessidade de troca de informações entre os sistemas de informações é
eminente e demanda uma solução mais eficaz;
•
A tecnologia Web Service é, possivelmente, um padrão para a comunicação
entre informações entre sistemas;
•
A tecnologia proposta pelos Web Services subsidia-se em conceitos e padrões
universais, o que aumenta sua aceitabilidade.
13
2
Referencial Teórico
Este capítulo realiza uma revisão teórica dos conceitos e tecnologias envolvidas
para viabilizar a proposta de construção de Web Services genéricos. O propósito é expor
as informações técnicas sobre o assunto para que haja contextualização e posteriormente
um melhor entendimento dos objetivos e motivações que justificam o desenvolvimento
deste trabalho.
2.1
Extensible Markup Language (XML)
Extensible Markup Language (XML) é um formato de texto flexível derivado do
Standard Generalized Markup Language (SGML) definida pela ISO 8879.
Originalmente, foi concebido para a publicação eletrônica de informação em larga
escala. Desempenha, também, um importante papel como padrão de comunicação de
informações na internet. (W3C, 2006)
O projeto da construção da linguagem de marcação XML foi basicamente
norteado pela necessidade de criação de uma linguagem que fosse integrada a qualquer
tipo de software e/ou linguagem. O projeto subsidiou-se ainda, sobre os seguintes
pilares:
•
Separação do conteúdo da formatação;
•
Simplicidade e Legibilidade, tanto para humanos quanto para computadores;
•
Possibilidade de criação de tags sem limitação;
•
Criação de arquivos para validação de estrutura;
•
Interligação de bancos de dados distintos;
14
•
Concentração na estrutura da informação, não em na sua aparência;
Além disto, existem algumas diretivas a serem observadas para utilização da
tecnologia XML, são estas: (W3C, 2006)
•
XML deve ser diretamente utilizado sobre a Internet;
•
XML deve suportar uma grande variedade de aplicativos;
•
XML deve ser compatível com SGML;
•
Deve haver facilidade em escrever programas aos quais sejam processados
documentos XML;
•
A quantidade de caracteríscas ocionais no XML devem ser evitadas ao
máximo, sendo recomendado não existirem;
•
Documentos XML devem ser inteligíveis e razoavelmente limpos;
•
O projeto do XML deve ser construído rapidamente;
•
O projeto do XML deve ser formal e conciso;
•
Os documentos XML devem ser fáceis de serem criados;
•
Aparência na marcação XML é a coisa menos importante.
2.1.1 Documentos XML
O objeto da construção de um texto de marcação com a utilização de XML é o
documento. Cada documento XML possui uma estruturas definidas:
•
Lógica: o documento é composto por declarações, elementos, comentários,
caracteres-referência e instruções de processo indicadas explicitamentes no
documento;
•
Física: o documento é composto por unidades chamadas entidades. Uma
entidade pode fazer referência a outra para incluí-la a um documento.
Entretanto um bloco de texto só é reconhecido como um documento XML caso
seja bem formado.
Um objeto de dados é um documento XML se este for bem-formado. Além disto,
o documento XML é válido se este observa determinadas restrições. (W3C, 2006)
Neste sentido, um documento é considerado bem-formado se observar, em sua
produção, conforme ilustra a figura 1, os seguintes aspectos:
•
Possuir uma declaração inicial (que pode ser vazia);
•
Deve possuir um elememento Root (que pode conter n elementos);
15
•
Opcionalmente pode possuir uma parte mista (comentários, instruções de
processamento, etc.);
•
Todos os elementos devem ter anotações de início e fim;
•
Os elementos devem ser aninhados corretamente, ou seja, o fechamento de
um elemento deve corresponder ao elemento imediatamente anterior de
nome afim.
<?xml version="1.0" standalone="yes"
encoding="utf-8" ?>
<cadastro>
<?html action=”hr”?>
<pessoa codigo=1>
<!-- comentário sobre o elemento <nome> ->
<nome>João</nome>
<endereco>Rua do Progresso, 70</endereco>
</pessoa>
</cadastro>
<?html action=”br”?>
Figura 1 – Documento XML bem formado
2.1.2 Declaração
De acordo com as diretivas vistas anteriormente, um documento XML para ser
reconhecido deve conter uma declaração. Apesar de ser um componente opcional é um
item altamente recomendável por uma questão de organização e controle quanto aos
documento XML produzidos. Esta declaração inicial é importante para especificar
determinadas características do XML, como: versão do documento e codificação
utilizada para sua construção. Esta declaração é ilustrada através da figura 2.
É importante ressaltar que este é o ponto inicial de um documento. Qualquer
coisa colocada anterior a declaração resultaria em uma má-formação do documento e,
por conseguinte, seu não reconhecimento como um documento XML.
<?xml version="1.0" encoding="utf-8" ?>
Figura 2 – Declaração de um documento XML
16
2.1.3 Comentários
Um comentário pode ser colocado em qualquer parte do documento XML, desde
que observe algumas restrições:
•
Não podem aparecer antes da declaração;
•
Não podem aparecer dentro de uma anotação;
•
Não permite a utilização da seqüência de caracteres "--".
Comentários podem aparecer em qualquer lugar documento. Além disto, eles
podem aparecer dentro da declaração do tipo do documento nos lugares permitidos
pela gramática; não fazem parte dos dados de caracteres do documento; um
processador XML pode, mas não precisa, fazer com que uma aplicação extraia o texto
do comentário; por uma questão de compatibilidade “--“ (dois hífens) não podem ser
utilizados dentro dos comentários; referências de parâmetros de entidades não são
reconhecidos dentro de comentários. (W3C, 2006)
2.1.4 Instruções de Processamento
A instrução de processamento de é uma indicação direta ao processador sobre
algo que deve ser executado. Este componente não faz parte do conteúdo nem da
estrutura de um documento.
Instruções de processamento (IPs) permitem que os documentos XML
contenham instruções para aplicativos. (W3C, 2006)
2.1.5 Elementos
Os elementos compõem os blocos lógicos de um documento XML. Um
elemento é composto por uma anotação inicial (identificada por um “<” sinal de
menor), conteúdo e anotação final (identificada por um “>” sinal de maior), sendo que o
elemento inicial é iniciado por uma anotação composta por “</” sinal de maior e barra.
O processador XML quando realiza a análise do documento assume que a
anotação de fim de um elemento deve ser igual à anotação inicial declarada
imediatamente anterior a esta. Além disto, um elemento deve estar completamente
contido em outro elemento, com exceção do elemento raiz (conhecido como root). Em
17
adição a isto, um elemento pode conter direta ou indiretamente instâncias de si próprio.
Esta possibilidade de recursividade ou aninhamento pode causar problemas no
momento da execução do documento.
Para a definição de um elemento é preciso nomeá-lo, entretanto existem algumas
regras de nomes que devem ser observadas:
•
Primeiro caractere deve ser uma letra, “:” dois pontos ou um “_” underscore;
•
Os caracteres seguintes podem conter valores alfanuméricos, pontos, “:” dois
pontos e “_” underscore;
•
Não é permitido o uso de espaços em branco.
É importante, ainda, observar que um documento XML é case-sensitive, ou seja,
as letras maiúsculas e minúsculas são distinguidas.
2.2
Service Oriented Architecture (SOA)
SOA expressa uma perspectiva para o desenvolvimento de software que define
serviços fracamente acoplados de um software para responder aos requisitos dos
processos definidos pelo negócio e pelos usuários. (Wiki, 2006)
Historicamente, a arquitetura de soluções foi baseada na obtenção de um
conjunto de requisitos de negócio e a partir destes derivar um modelo de tecnologia que
normalmente envolve a orientação a objetos e tecnologias de componentes. Entretanto,
distanciar o processo de desenvolvimento de um sistema dos negócios, normalmente
ocasiona uma grande lacuna entre a real necessidade e as soluções de TI oferecidas.
2.2.1 Sistemas Conectados
Embora o sistema de mensagens permita a conexão entre sistemas distintos e
forneça a estrutura base de conexão de sistemas distribuídos, existe uma série de outras
problemas importantes que precisam ser tratados, como questões de identidade,
interação, etc.
O sistema de mensagens é importante para a orientação a serviços, mas não é o
único aspecto necessário para modelar serviços, existindo também diversos outros
aspectos a serem analisados. (SEHMI, Arvindra)
18
Figura 3 – Pilares dos sistemas conectados
Existem cinco pilares fundamentais aos quais os sistemas conectados devem
estar apoiados:
•
Identidade e acesso. Noção de identidade federada (em um ambiente Web isto
significa um único login para ter acesso a n locais) e autorização baseada em
papéis. Este pilar trata do gerenciamento do relacionamento de confiança e da
forma como deve ser controlado o acesso aos sistemas conectados. Além disso,
normas de conformidade e governança são outros fatores importantes a serem
observados;
•
Dados. Esta premissa está relacionada à agregação de entidades e está
relacionada à construção de uma fonte única e coerente de uma entidade de
negócios específica, como um cliente, embora os dados do cliente possam estar
duplicados em diversos sistemas;
•
Interação. Este pilar é dedicado ao consumo humano de serviços, por exemplo,
por meio de fornecimento, através de recursos on-line (Web) e off-line. A
utilização de mecanismos ponto a ponto e dispositivos móveis também são
ressaltados por este pilar;
•
Sistema de mensagens. Refere-se a estrutura de base dos sistemas conectados e
precisa dar suporte a sistemas de mensagens seguras, confiáveis e ordenadas;
•
Workflow (fluxo de trabalho). Este pilar trata do fluxo de trabalho ou da
automação dos requisitos de negócio, externos ao serviço. Há, neste ponto, uma
preocupação quanto a orquestração dos processos de negócios e também a
outros aspectos, como gerenciamento da interação com o usuário, processos
especialistas e gerenciamento de exceções.
19
2.2.2 Princípios da arquitetura baseada a serviços
A orientação a serviços se tornou um importante requisito no desenvolvimento
de soluções em ambientes conectados, pois busca um alinhamento efetivo entre os
requisitos de negócio e os serviços de TI oferecidos. Sendo assim, uma arquitetura
orientada a serviço (SOA) é criada para fornecer flexibilidade para tratar elementos de
processos de negócios e a infra-estrutura fundamental de TI como componentes (ou
serviços) que podem ser reutilizados e combinados para atender às prioridades de
mudanças de negócios.
Service Oriented Architecture (SOA) é um paradigma para organização e
utilização de recursos distribuídos que podem ser controlados por diferentes
requisitantes. (OASIS, 2006)
Existem alguns conceitos chave que devem ser observados em arquiteturas
orientadas a serviço.
•
Visibilidade – refere-se à capacidade de aqueles que procuram o serviço e
aqueles que fornecem o mesmo possam se encontrar. Isto envolve o provimento
de descrição para cada funcionalidade disponível contendo sua sintaxe e
semântica, formas de interação com tal funcionalidade, políticas de segurança
que devem ser respeitadas e mecanismos de acesso a estes recursos;
•
Interação – através da troca de mensagens, a interação procede através de uma
série de informações trocadas e ações invocadas. Resumidamente, a capacidade
de interação constitui um conjunto de técnicas e elementos de negócio que
formam o caminho entre os que requerem e aqueles que provêm algo;
•
Efeito – é o núcleo, pois é a capacidade efetiva de resposta de um ou mais
efeitos do “mundo real”. Este efeito pode ser o retorno de informações ou a troca
de estado de uma determinada entidade envolvida na interação.
Para tornar os clientes de seus serviços mais auto-suficientes, permita que tenham
uma visibilidade ampla ao usa-los. (OELLERMANN, Willian)
2.2.3 Serviço
Um serviço é um mecanismo que permite o acesso a uma ou mais
funcionalidade. O serviço é provido por uma entidade específica (Service Provider)
20
onde os consumidores não precisam ter conhecimento sobre o provedor do serviço nem
o provedor de serviço quanto ao consumidor de seu recurso.
Um serviço é acessado através de interfaceamento de sistemas (interfaces do
serviço), onde a interface compreende especificações sobre como acessar as
capacidades inerentes ao serviço. Não existem restrições formais quanto a constituição
das funcionalidades/capacidades a serem disponibilizadas nem como estas serão
implementadas pelo Service Provider. Sendo assim, o serviço pode realizar a descrição
das funcionalidades através de processos automáticos e/ou manuais que permitam que
ele próprio possa invocar outros serviços disponíveis por outros provedores.
Outra característica importante quanto aos serviços é sua transparência, quanto
implementação, para o consumidor, ou seja, o consumidor não precisa conhecer
detalhes técnicos do serviço, bastando ter ciência de sua existência, local e como acessalo. Os detalhes de um serviço só serão expostos ao consumidor, quando isto foi
determinando para que este tenha conhecimento que o serviço é realmente apropriado a
suas necessidades.
Quando um serviço é invocado são realizados um ou mais efeitos no mundo real.
Estes efeitos podem ser:
a. Informação retornada em resposta a requisição;
b. Uma troca de estado de uma determinada entidade;
c. Combinações dos itens “a” e “b”;
2.2.4 Componentes
A arquitetura orientada a serviços é constituída de determinados componentes,
conforme figura 4, que concentram as principais 3 principais funções e tarefas a serem
executados no tratamento dos serviços em um ambiente distribuído: disponibilização,
requisição e distribuição de serviços
21
Figura 4 – Modelo da arquitetura orientada a serviços
•
Service Provider - nodo da rede que disponibiliza interfaces para recursos de
software que trabalham com um conjunto específico de atividades. Este nodo
pode representar os serviços de uma entidade de negócios ou pode simplesmente
representar as interfaces de serviço para reutilização de sub-sistemas;
•
Service Requestor - nodo da rede que descobre e invoca outros serviços de
software para fornecer uma solução do negócio. Frequentemente, este nodo
representa um componente de uma aplicação de negócio que executa chamadas
remotas de procedimentos ao objeto distribuído, o Service Provider. Em alguns
casos, o nodo provedor pode residir localmente em uma intranet ou, em outros
casos, este pode residir remotamente na Internet;
•
Service Broker – nodo da rede que atua como um repositório para interfaces de
software que são publicas pelo Service Provider. Um Service Broker pode ser
representado por uma entidade de negócio ou um operador independente.
2.2.5 Modelagem de sistemas orientados a serviço
Para criar sistemas orientados a serviços bem-sucedidos é necessário modificar
a maneira como se pensa sobre orientação a serviços. (SCHWEGLER, Beat)
Idealmente, o modelo de negócios e o de tecnologia devem estar alinhados
precisamente, entretanto este relacionamento geralmente não se realiza. Os
departamentos de tecnologia centralizados, que não trabalham em proximidade
suficiente com a empresa e de forma efetiva, constituem uma razão chave para isso. O
alinhamento real entre os modelos de negócio e o de tecnologia dificilmente é alcançado
porque a lacuna entre estas duas perspectivas é muito grande.
22
Entretanto, para que este cenário seja modificado e o sistema seja concebido em
uma modelagem orientada a serviço, é importante que alguns pontos sejam ressaltados:
•
Profissionais de TI devem estar voltados para além da tecnologia. Isto significa
que os profissionais da área de tecnologia de uma empresa devem estabelecer
um melhor relacionamento com os profissionais focados na área de negócio.
Tais profissionais não precisam ser especialistas neste ramo, mas precisam de
uma linguagem objetiva que lhes permita conversar com a área de negócio sobre
negócios e não sobre tecnologia. A figura do arquiteto de software advém
exatamente desta necessidade, pois constitui um canal de comunicação entre os
profissionais de negócio e o departamento de TI, precisando assegurar a
interdependência entre os requisitos de negócio e as soluções tecnológicas;
•
É necessário entender e participar das decisões da empresa. Este conhecimento
influência as decisões de implementação, no âmbito que torna as medidas
tecnológicas influenciadas pelos objetivos de negócio. Esta influência durante o
próprio processo de desenvolvimento torna o sistema mais adequado a real
necessidade real e estabelece um canal de comunicação mais estreito entre a
tecnologia e o negócio;
•
Uma Infra-estrutura operacional comum é fundamental para dar suporte a
aplicativos de negócios que fornecem práticas inter-empresariais e globais.
Construir um modelo íntegro de como operar e gerenciar a infra-estrutura e
implantar aplicativos nela é fundamental para uma arquitetura bem-sucedida.
•
Padrões de tecnologia de Web Services permitem que aplicativos sejam
conectados. Ao final, o valor de conectar os sistemas leva as práticas de negócio
mais eficientes e efetivas.
É no modelo de serviços que pode capturar a semântica necessária para
expressar os serviços que tornam a sua solução mais flexível e mais voltada para fora
ou para os negócios. (SEHMI, Arvindra)
Figura 5 – Modelo de orientação a serviços em três partes
23
2.2.6 Vantagens da utilização de SOA
Uma nova maneira de pensar em projetos de sistemas é eminentemente
necessária. Adotando uma nova ótica, pode-se forçar a consideração explícita de
artefatos de modelo de serviços nos processos de design, o que ajuda a identificar os
artefatos corretamente e, no nível de abstração certo, atender e alinhas as necessidades
de negócio.
Sob uma perspectiva de modelagem, a lacuna entre os modelos de negócios e de
tecnologia convencionais é muito grande, o que caracteriza o principal fator de fracasso
de muitas iniciativas de projetos de sistemas, principalmente em ambientes conectados
onde os fatores possuem maior variabilidade e o controle torna-se mais complexo.
Desta forma, um modelo que promova um alinhamento dos serviços com os
requisitos de negócios é a premissa de uma arquitetura concisa, de maior flexibilidade e
de capacidade superior quanto ao cumprimento das metas estipuladas pelos requisitos
de negócio. Por conseguinte, um modelo orientado a serviços é mais detalhado quanto
aos pontos de intersecção entre os negócios e a tecnologia.
Com efeito, a grande valor da arquitetura SOA é a providência de um paradigma
simples para organizar uma grande rede de sistemas que requerem interoperabilidade
para realizar o valor inerente aos seus componentes individualmente.
Através desta habilidade de escalabilidade e envolvimento, SOA possibilita que
um sistema ou uma rede de sistemas se tornem mais adaptáveis a uma variedade maior
de necessidades e problemas específicos.
2.3
Web Services
Sob uma breve ótica cronológica, temos um grande número de tecnologias
existentes que permitem a comunicação entre aplicativos por intermédio da internet:
Remote Procedure Call (RPC), Distributed Object Model (DCOM), e os serviços da fila
de mensagens Microsoft Message Queue (MSMQ). Cada técnica destas é quase
completa, porém foram projetadas para trabalharem somente com sistemas similares,
como, por exemplo, o MSMQ que se comunica somente com outro MSMQ, ou um
cliente DCOM que somente compartilha informação com um servidor DCOM.
Todavia, isto não significa a impossibilidade destas tecnologias coexistirem em
um mesmo ambiente computacional. Entretanto o tempo necessário para o
24
desenvolvimento de ferramentas que permitam a interoperabilidade destas e a
confiabilidade no sucesso deste tipo de operação acaba inviabilizando a construção
deste tipo de solução.
O Web Service é uma tecnologia que busca exatamente esta comunicação e
integração entre sistemas distintos, sob uma ótica arquitetural. Esta tecnologia foi
concebida visando à independência de plataformas operacionais, hardware e linguagens
de programação.
2.3.1 Arquitetura
Um Web service é um sistema identificado por uma URL, da qual são
publicadas interfaces públicas e definidas e descritas usando XML. Esta definição pode
ser descoberta por outros sistemas de software. Estes sistemas podem então interagir
com estes Web Services em um formato definido por sua definição, utilizando XML
baseado em mensagens convencionadas por protocolos de internet. (W3C, 2006)
Os Web Services são aplicativos totalmente independentes, isolando o acesso a
demais recursos de um ambiente distribuído, como banco de dados. Para que este
isolamento seja possível e esta independência seja efetiva, os Web Services são
aplicativos baseados em um conjunto de padrões universais. Estes padrões descrevem a
sintaxe e semântica do envio e recebimento de informações, bem como tecnologias de
transporte, codificação e protocolos de comunicação. Esta padronização dos Web
Services é de responsabilidade da W3C (World Wide Web Consortium) e o
Organization for the Advancement of Structured Information Standards (OASIS).
A arquitetura básica de um Web Service define uma interação entre aplicativos
através de troca de mensagens entre agentes consumidores e agentes forncedores. Esta
arquitetura capacita os Web Services para as seguintes funções básicas:
•
Trocar mensagens;
•
Serem serviços auto-descritivos;
•
Publicar e possibilitar a navegabilidade sobre seus serviços.
25
Figura 6 – Modelo básico de acesso a um Web Service
2.3.1.1 Simple Object Access Protocol (SOAP)
SOAP é um pacote de protocolo padronizado para as mensagens
compartilhadas entre aplicações. (SNELL, James)
SOAP foi projetado para encapsular e transportar chamadas de RPC (Remote
Procedure Call), e para isto utiliza-se dos recursos e flexibilidade do XML, sob HTTP.
A especificação define um modelo baseado em um envelope XML para que as
informações sejam transformadas e um conjunto de regras para tradução de
peculiaridades específicas de uma aplicação ou plataforma ou tipos de dados contidos
na representação XML.
Figura 7 – Constituição de uma mensagem SOAP
Segundo a W3C (World Wide Web Consortium), para toda chamada RPC são
necessárias as seguintes informações:
•
A URI do objeto alvo;
•
O nome do método;
26
•
Os parâmetros do método (requisição ou resposta);
•
Uma assinatura do método opcional;
•
Um cabeçalho (header) opcional;
POST /StockQuote HTTP/1.1
Host: www.stockquoteserver.com
Content-Type: text/xml; charset="utf-8"
Content-Length: nnnn
SOAPAction: "Some-URI"
<SOAP-ENV:Envelope
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
<SOAP-ENV:Header>
<t:Transaction
xmlns:t="some-URI" SOAP-ENV:mustUnderstand="1">
5
<t:Transaction>
</SOAP-ENV:Header>
<SOAP-ENV:Body>
<m:GetLastTradePrice> xmlns:m="Some-URI">
<symbol>DIS</symbol>
</m:GetLastTradePrice>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
Figura 8 – Exemplo de um envelope de requisição RPC
O elemento Envelope especifica:
•
A URI identifica o namespace utilizado por esta requisição SOAP.
http://schemas.xmlsoap.org/soap/envelope/ possui o namespace padrão para
todas as mensagens SOAP;
•
O
encodingStyle
(estilo
de
codificação)
é
definido
pela
URI
http://schemas.xmlsoap.org/soap/encoding/ e identifica o estilo de codificação a
ser utilizado;
O cabeçalho Header define:
•
Um atributo chamado Transaction que define um namespace (URI) para o
elemento.
•
O atributo mustUnderstand=1 especifica que o cabeçalho deve ser processado
pelo receptor da mensagem;
•
O valor 5, que deve ser um valor compreendido pelos serviços que processam
esta mensagem;
O elemento Body define:
•
Uma chamada de método GetLastTradePrice e seu respectivo namespace;
27
•
O elemento DIS especifica um parâmetro contido na chamada de método
GetLastTradePrice.
Além disto, o protocolo SOAP fornece a semântica para o envio e recebimento
dos dados (utilizando XML), codificando os parâmetros de entrada/saída invocados
pelas operações publicadas pelo Web Service. Em outras palavras, SOAP é uma
aplicação especificada por XML. Isto garante uma intensa observância aos padrões
XML como schema e namespaces para suas definições e funções.
Figura 9 – Tráfego de mensagens via XML
2.3.1.2 Web Service Description Language (WSDL)
A WSDL é o padrão que fornece as especificações e mecanismos de descrição
dos Web Services. Através desta padronização, um Web Service pode descrever tudo
aquilo que ele faz, como faz e como pode ser consumido.
Figura 10 – Descrição gerada automaticamente pelo WSDL
28
Existem algumas vantagens quanto à utilização do padrão WSDL:
•
WSDL torna fácil escrever e manter serviços fornecendo um melhor estruturado
jeito de deifinir as interfaces do Web Service;
•
WSDL facilita o consumo do Web Service através da redução do montante de
código que uma aplicação cliente precisa programar;
•
WSDL torna mais simples a implementação de modificações com baixo
impacto. Devido ao dinamismo de sua descrição, o WSDL permite que
modificações sejam realizadas sem maiores prejuízos ao código do cliente.
Figura 11 – WSDL Preâmbulo
2.3.1.3 Universal Description Discovery and Integration (UDDI)
UDDI é um projeto responsável pelo processo de publicação, pesquisa e
navegação dos Web Services. Sendo assim, define um registro de serviços contendo
suas descrições para que os consumidores possam automaticamente navegar e utilizar o
serviço desejado.
Este projeto possui duas partes: um registro de todo o metadado do Web Service
(incluindo um ponteiro a descrição WSDL do serviço) e um conjunto de tipos de
definições de porta WSDL para a manipulação e localização dos registros.
29
2.4 Reflection
Primeiramente é importante que seja definido o paralelo matemático que
subsidia todo o conceito envolvido em reflexão de classes. Quando se fala em reflexão
computacional evidenciam-se as problemáticas envolvidas pelas equações reflexivas.
Sendo que tais equações possuem como principal funcionalidade a descrição de
equações através de análises matemáticas baseadas na descoberta de seus respectivos
domínios e, através destas descrições, realizarem a descrição de qualquer equação, é
evidenciado um ponto de intersecção entre estas áreas do conhecimento.
2.4.1 Aspectos Matemáticos da Reflexão
Criar uma arquitetura reflexiva é o caminho para o efetivo relacionamento de
entidades implícitas de um domínio computacional Dn, chamado nível básico, dentro de
um outro domínio computacional Dn+1, chamado meta-nível. (FERBER, Jacques)
Cada domínio pode servir ambos o domínio básico para um nível superior, ou
um meta-domínio para um domínio inferior, com exceção do domínio D0, construído
por referências, aos quais pode ser utilizado somente como um nível básico.
Modelos de reflexão facilmente são definidos por meios de equações de
reflexão, as quais expressam como entidades e expressões de nível básico são descritas
no meta-nível. Sendo assim, equações de reflexão agem como equações semânticas,
fornecendo a semântica dos níveis inferiores em termos de níveis superiores.
O modelo tradicional de reflexão é baseado em interpretação. O domínio Dn é
composto de um conjunto de entidades e expressões, escritas em uma linguagem Ln, e
de um interpretador In que interpreta estas expressões.
O interpretador é escrito em uma linguagem Ln+1 que por sua vez é interpretado
por um interpretador In+1. Quando o sistema não é reflexivo, a linguagem Ln+1 é
completamente diferente da linguagem Ln. Por exemplo, se L1 é uma linguagem LISP,
L2 pode ser uma linguagem como Pascal ou C, L3 o conjunto de instruções da
linguagem de maquina, etc.
Sendo assim, em arquiteturas reflexivas, existe uma infinita cadeia virtual de
linguagens idênticas Li, também conhecidas como torre reflexiva. Este cenário é
possível devido a existência de um interpretados, escrito em uma linguagem L’
30
diferente de Li, que é usada para isolar a regressão e substituir o interpretador In no nível
computacional mais básico necessário.
Um novo modelo de reflexão baseada em representação de objetos foi
introduzida por Pattie Maes. “Cada objeto O tem um meta-objeto M-O que representa
O. (MAES, Pattie)
O modelo proposto por Maes é baseado em uma explícita semântica de
referência em representações do conhecimento. “Representação é um processo
notacional onde conceitos são implementados através de objetos conceituais. (STEELS,
Luc).
Sendo assim, todo o objeto é uma representação de alguma coisa, uma entidade
do mundo “real” (pessoas, arquivos, tabelas) um evento ou uma situação. Objetos
computacionais podem ser também representados por outros objetos, também
conhecidos como meta-objetos. Em suma, objetos são referências de um meta-objeto.
2.4.2 Reflexão em Linguagens Orientadas a Objeto
Quando um objeto O recebe uma mensagem, este a delega ao seu objeto M-O.
Este processo é executado novamente, recursivamente, até que o sistema encontre o
meta-objeto chamado Meta-Objeto Default, que utiliza um interpretador básico de
mensagens escritas diretamente em LISP.
Entretanto, utilizar um meta-objeto para realizar a reflexão não é a única maneira
de contruir a reflexão computacional. Existe, ainda, a possibilidade de ajustar o
processo de comunicação. Este método condiciona a uma outra forma de visualizar a
reflexão em linguagens orientadas a objeto, ao qual possibilita a utilização tanto para o
processo de debug como para a implementação.
2.4.3 Cenário de utilização
No modelo introduzido pela programação orientada a objetos utiliza-se o
conceito de instanciamento de classes para o acesso a atributos e invocação de métodos
das mesmas. Por conseguinte, neste modelo proposto, é necessário um conhecimento
prévio sobre a classe que se deseja acessar.
31
Entretanto, imaginemos um cenário em que o acesso aos atributos e métodos de
classes possa ser realizado de maneira genérica. Neste caso, não seria necessário um
conhecimento prévio sobre uma determinada classe, pois esta seria identificada no
momento de sua utilização. A técnica de pesquisar atributos e métodos de classes em
tempo de execução é conhecida como Reflection.
Para a viabilidade disto, o .NET Framework introduziu um importante conceito
no desenvolvimento de aplicações: assembly auto-descritivas. Antigamente, na
programação de componentes COM (Component Object Model) eram observados a
presença de um type-library vinculado, que descrevia este componente, possibilitando a
reutilização por outros componentes. Em .NET, os assembly possuem um metadado
agregado, que descreve ele próprio e os tipos definidos pela mesma.
Esta mudança no formato de construção de componentes reutilizáveis serviu de
premissa à técnica do Reflection. O Reflection é o ato de, programaticamente,
inspecionar um assembly, seu metadado e os tipos de dados contidos dentro deste.
2.4.4 Meta-Objetos e o processo de Reflexão
No modelo de reflexão baseado em meta-objetos, cada objeto possui seu próprio
meta-objeto que descreve seu comportamento básico. Como um meta-objeto também é
um objeto, estes também podem possuir meta-objetos, e assim sucessivamente. Este
modelo condiciona a um cenário infinito de possibilidade regressivas a meta-objetos,
em uma realidade programática orientada a objetos.
De acordo com a técnica proposta pelos meta-objetos, a semântica do envio da
mensagem pode ser definida pelo responsável do envio – HANDLEMSG - desta ao
meta-objeto.
Linguagens que utilizam o paradigma da orientação a objetos, estabelecem um
paralelo lógico de comportamento. Sendo um objeto uma representação de seu metaobjeto respectivo, meta-classes são consideradas meta-objetos de classes devido a sua
capacidade de descrição da estrutura da classe. Por conseguinte, uma meta-função de
um objeto é equivalente a uma meta-função da classe, pois esta última retorna a classe
do objeto.
32
A equação reflexiva comprova esta equivalência e agrega a questão do ponto de
vista comportamental: um objeto O receber a mensagem M, está para sua classe receber
a mensagem HANDLEMSG.
Em suma, é importante a distinção entre reflexão estrutural (embasadas em
equações matemáticas) onde a utilização de meta-classes é importante e a reflexão
computacional, onde uma classe específica META-OBJETO pode ser introduzida como
a raiz de todos os demais meta-objetos.
2.4.5 .NET Reflection
A utilização da técnica proposta pelo Reflection é realizada através de um
conjunto de classes contidas em uma biblioteca de classes do .NET Framework. Estas
classes estão agrupadas e compõe o namespace: System.Reflection.
Figura 12 – Biblioteca de Classes do .NET Framework
O namespace System.Reflection contém todas as classes e interfaces que
permitem a realização das tarefas pertinentes a exploração de classes em momento de
execução. Tais tarefas podem ser caracterizadas por: exploração de tipos, exploração de
métodos e exploração de campos. Muitos dos tipos existentes no namespace são os
atributos que adicionamos nos assemblies a fim de disponibilizar informações como:
Título, TradeMark, Versão, entre outras.
Quando é necessária a manipulação direta aos assemblies, a classe
System.Reflection.Assembly deve ser utilizada. Esta fornece a infra-estrutura necessária
para, em tempo de execução, possuirmos uma completa visão e entendimento da
capacidade de uma aplicação, reforçando suas regras de versionamento e dependência.
Por sua vez, a classe System.Type é a chave para a obtenção de informações
referentes aos tipos contidos em um assembly. Ela implementa a classe
System.Reflection.MemberInfo que permite, através da sua manipulação, realizar as
tarefas de busca de informações dos elementos, membros internos das classes,
interfaces, arrays, tipos por valor e enumerações. Propriedades como: IsClass, IsEnum
33
ou IsInterface, que permite determinar os tipos, ou métodos como: GetConstructors,
GetFields, GetMethods, GetProperties, GetEvents, e GetNestedTypes que retornam os
vários membros do tipo informado.
Desta forma, para descobrir os tipos contidos em uma determinada classe, é
necessário que seja realizada a instância da classe System.Type. Esta instância, por sua
vez, será inicializada utilizando-se um tipo específico que se deseja inspecionar.
Figura 13 – Exemplo de utilização da classe System.Type
Um
último
aspecto
importante
a
ser
observado
é
a
enumeração
System.Reflection.BindingFlags, que determina como será conduzida a busca dos
membros e tipos pelo mecanismo do Reflection.
2.5
Remoting
Tecnologias de sistemas distribuídos como DCOM (Distributed Component
Object Model), RMI (Remote Method Invocation) e CORBA (Common Object Request
Broket Architecture) têm evoluído nas últimas duas décadas para responder às
mudanças do crescente número de requisitos.
Hoje em dia, uma tecnologia de sistemas distribuídos precisa ser eficiente,
extensível, suportar transações, interoperar com diferentes tecnologias, ser altamente
configurável e trabalhar sobre em ambiente Web.
2.5.1 Arquiteturas distribuídas
Existem muitas arquiteturas que propõe a distribuição do sistema em pontos
isolados e separados. Esta metodologia fracamente acoplada quanto a utilização dos
recursos proverão um sistema é a premissa básica para a concepção do .NET Remoting
e demais tecnologias de sistemas distribuídos.
É importante que alguns conceitos arquiteturais estejam bem esclarecidos quanto
a ambientes distribuídos, tais como:
34
•
Programação modular – É essencial para a distribuição de um sistema que este
seja projetado de maneira modular, ou seja, o dividir o sistema em unidades
sólidas e integradas que interagem entre si.
•
Cliente/Servidor – Conceito fundamental para arquiteturas distribuídas. Em
termos gerais, cliente/servidor é um cenário onde um processo cliente requisita
serviços de um processo servidor. O processo cliente é responsável pela camada
de apresentação da aplicação – UI (User Interface). Com efeito, cabe a esta
camada a validação dos dados de entrada do usuário, despachar chamadas ao
servidor e possibilitar executar algumas regras de negócio. O processo servidor,
por sua vez, atua como um motor – processa as requisições do cliente através da
execução da lógica de negócios e interoperar com demais recusros, como banco
de dados. Frequentemente, muitos clientes realizam suas requisições a um único
servidor.
Figura 14 – Modelo Cliente/Servidor
•
Multi-Camadas ou N-Tier – Cliente/servidor também são dispostos como no
modelo de duas camadas devido a invocação do cliente diretamente ao servidor.
Arquiteturas duas camadas são comumente mais fáceis de serem implementadas,
mas tendem a ter uma escalabilidade limitada. Em um modelo constituído por
multi-camadas a entidade cliente, lógica das regras de negócio e armazenamento
de dados são desenvolvidos e mantidos como módulos interdependentes e muito
frequentemente em plataformas separadas.
35
Figura 15 – Modelo N-Tier
•
Peer-to-Peer – Esta arquitetura compreende muitos nodos individuais não
centralizados a um único servidor. A expressão Peer-to-Peer foi usada pela
primeira vez em 1984, com o desenvolvimento do projeto Advanced Peer-toPeer Networking Architecture na IBM. A internet é um exemplo clássico de uma
arquitetura constituída de um servidor Web monolítico servindo clientes
“magros” (thin clients). Entretanto temos exemplos de sistemas como Emule,
BitTorrent, entre outros que permitem o compartilhamento de dados
entre
estações. Estas estações (peers) usam um servidor centralizado para descobrir
outras estações e estabelecer algum tipo de requisição/provimento.
Figura 16 – Modelo Peer-to-Peer
36
2.5.2 Tecnologias distribuídas
As arquiteturas distribuídas discutidas foram implementadas utilizando
tecnologias que subsidiam a construção de ambientes descentralizados. Contudo, o
grande crescimento nas aplicações distribuídas é observado nas nestas tecnologias. Isto
pode ser comprovado pelo tempo cada vez menor necessário para a modelagem de uma
arquitetura distribuída, através de ferramentas e conceitos tecnológicos mais enxutos e
eficazes.
•
Sockets – uma das fundamentais abstrações das aplicações de rede modernas. Os
sockets abstraem detalhes de baixo nível de uma rede através de construção de
comunicações baseadas em entradas e saídas de streams. Embora seja oferecido
controle total sobre a comunicação, os sockets demandam um trabalho de
construção complexo para ser utilizado pelas aplicações distribuídas. Utilizando
streams para entrada e saída dos dados acarreta o desenvolvimento de
mensagens mais complexas, pois devem conter detalhes do sistema e
interpretadores dos streams de dados.
•
Remote Procedure Call (RPC) – O ambiente de computação distribuída da Open
Software Foundation define, entre outras tecnologias, uma especificação para a
realização de chamadas remotas a procedimentos (RPC). O trabalho com RPC
pressupõe alguns conceitos:
o Stubs – Estes pedaços de código rodam no lado do cliente e do servidor
que realiza a chamada remota ao procedimento como se fosse uma
chamada local.
o Marshaling – Este é o processo de passagem de parâmetros de um
contexto para outro. Em RPC, os parâmetros das funções são serializados
em pacotes para serem transmitidos.
o Interface Definition Language (IDL) – Esta linguagem fornece
significados padrões para descrever, sintaxes de chamada e tipos de
dados dos procedimentos remotos chamados independente da linguagem
que foram programados.
Pode-se, então, considerar a utilização de RPC um grande avanço na construção
de comunicação remota de maneira simplificada, ao estabelecer um comparativo com
Sockets, por exemplo.
37
2.5.3 Objetos Distribuídos
A tecnologia de objetos distribuídos permite que objetos rodem em uma
determinada máquina cujo acesso é disponibilizado a aplicações ou a objetos rodando
em outras máquinas. Assim como RPC, os objetos distribuídos realizam chamadas a
objetos remotos como se fossem locais.
Embora as tecnologias distribuídas sejam implementadas de forma diferente
possuam filosofias e premissas peculiares entre si, existem similaridades em alguns
aspectos:
•
São baseadas em objetos remotos que possuem identidade e estado próprio. Isto
possibilita que tais objetos sejam manipulados da mesma forma que objetos
locais, simplificando a programação de sistemas distribuídos, provendo um
simples e unificado modelo de programação;
•
São associados com o modelo de programação baseada em componentes. A
utilização de componentes aumente a flexibilidade do sistema para realizar a
distribuição bem como melhora a manutenabilidade do mesmo, visto que é
separado em unidades lógicas menores;
•
São associados a serviços corporativos. Os serviços corporativos geralmente
provêm o suporte a algumas tarefas como transação, pool de objetos, controle de
concorrência e locação de objetos. Devido a complexidade de implementação,
são fornecidas por aplicativos próprios ou pelo próprio sistema operacional;
2.5.4 Binding de Objetos
As questões relativas a interoperabilidade devem ser consideradas quando é
necessária a coexistência de sistemas heterogêneos em um ambiente distribuído. Mais
do que isto, quando tais sistemas necessitam estabelecer um canal de comunicação
visando o compartilhamento de informações e aproveitamento de funcionalidades.
Desta forma, ao interagir sistemas não-gerenciados - win32 - com assemblys
compilados em .NET (ambiente gerenciado), a utilização de binding (early/late) é uma
importante prática a ser considerada. Esta técnica baseia-se na automação do
controle/comunicação de um componente utilizando o modelo COM (Component
Object Model).
38
Abstraindo o conceito de associação de valores a identificadores, o processo de
binding está associado a associação de valores a identificadores. Tal abstração está
estreitamente ligada ao conceito de escopo, ou seja, escopo de validade de uma
determinada associação através de binding.
De acordo com o momento em que o processo de binding é chamado, pode-se
classificá-lo da seguinte como: Early Binding e Late Binding.
2.5.4.1 Early Binding
Esta técnica refere-se a associação de tipos-valor em momento de compilação.
Isto significa que o componente cliente e o objeto COM estabelecem uma ligação
binária e todos os tipos e métodos deste ficam disponíveis em ambiente de
desenvolvimento. Pode-se identificar como ponto positivo da utilização de early
binding a garantia a compatibilidade binária entre o cliente e o objeto, aumentando a
velocidade de comunicação. Entretanto, um grande problema encontrado é que qualquer
alteração no objeto COM necessitará a modificação do cliente. Isto pode gerar
problemas de controle de versionamento e maior complexidade de delpoy (distribuição).
Exemplo da utilização de early binding:
•
fazer a referência ao objeto COM que será automatizado.
Figura 17 – Seleção de objetos para Automação
39
• declarar objetos de tipo definido pelo objeto COM e utilizar os métodos por ele
implementados:
Dim PPApp As PowerPoint.Application
Dim PPPres As PowerPoint.Presentation
Dim PPSlide As PowerPoint.Slide
Set PPApp = CreateObject("Powerpoint.Application")
Set PPPres = PPApp.Presentations.Add
Set PPSlide = PPPres.Slides.Add(1, ppLayoutTitleOnly)
With PPPres
.SaveAs "C:\My Documents\Sample.ppt"
.Close
End With
PPApp.Quit
Set PPSlide = Nothing
Set PPPres = Nothing
Set PPApp = Nothing
Figura 18 – Automação de objetos via early-binding
2.5.4.2 Late Binding
Esta técnica presume uma característica adicional ao componente COM. Todo o
objeto passível é passível de automação via late binding se implementar a interface
IDispatch. Esta interface permite a um cliente invocar os métodos e propriedades de um
componente em tempo de execução. Pode-se considerar como ponto positivo quanto a
utilização de late-binding a independência entre o componente cliente e o objeto COM
facilitando a distribuição, entretanto a performance pode se tornar um fator crítico na
utilização de automatização de componentes via late binding, dependendo da
quantidade de instâncias do objeto COM e da quantidade de operações invocadas.
Um exemplo de utilização de late binding pode ser ilustrado conforme a figura
19, onde é declarado um objeto do tipo Object e Este receberá uma instância do objeto
COM.
40
Dim PPApp As Object
Dim PPPres As Object
Dim PPSlide As Object
Set PPApp = CreateObject("Powerpoint.Application")
Set PPPres = PPApp.Presentations.Add
Set PPSlide = PPPres.Slides.Add(1, 11)
With PPPres
.SaveAs "C:\My Documents\Sample.ppt"
.Close
End With
PPApp.Quit
Set PPSlide = Nothing
Set PPPres = Nothing
Figura 19 – Automação de objeto via late-binding
2.5.5 COM Callable Wrapper (CCW)
Quando um aplicativo-cliente não gerenciado realiza uma chamada a um com
componente .NET, o compilador do framework cria um objeto gerenciado e um COM
Callable Wrapper para o respectivo objeto. Por não ser possível a referência direta a este
objeto criado, o cliente utiliza o CCW como um proxy de acesso ao objeto .NET.
Sendo assim, cada objeto gerenciado possui um COM Callable Wrapper
respectivo, independente da quantidade de chamadas a ele efetuadas. Isto significa que
múltiplos clientes não gerenciados podem utilizar uma mesma referencia ao CCW que
expõe a interface INew.
Figura 20 – Chamada um objeto gerenciado (.NET)
É importante salientar que os COM Callable Wrappers criados são invisíveis as
outras classes gerenciadas. Isto reafirma sua principal funcionalidade que é realizar
marshalling as chamadas feitas entre componente gerenciados e não-gerenciados.
Adicionalmente, o CCW também é responsável pela identidade do objeto criado e pelo
seu ciclo de vida (processo de garbage collection).
41
2.5.6 Serialização de Objetos
Em termos gerais, o processo de serialização consiste no armazenarmos do
estado de um objeto para fazer uso deste posteriormente para uma necessidade qualquer.
Em contrapartida, o processo de desserialização é constituído na manipulação do estado
do objeto serializado através do instanciamento desse objeto a partir do formato
serializado.
•
O processo de serialização possui grandes vantagens de utilização, tais como:
•
Armazena preferências particulares no objeto;
•
Mantém seguras as informações através das páginas Web e aplicativos desktop;
•
Permite a modificação dos documentos XML sem a utilização de DOM
(Document Object Model);
•
Passagem de objetos de uma aplicação para outra;
•
Passagem de objetos de um domínio para outro;
•
Passagem de objetos através de firewall como uma string XML;
Quando falamos em serialização de objetos, estamos buscando uma solução
para trafegar nossos objetos entre sistemas, aplicações WEB e até mesmo entre redes.
(SANCHES, Andrey)
Existem maneiras para realizar o processo de serialização/desserialização de
objetos utilizando a plataforma .NET, conforme descrito abaixo:
•
Utilizando as classes contidas no namespace System.Runtime.Serialization. Este
processo realiza a serialização em dois formatos: binário ou XML/SOAP. Os
objetos são serializados utilizando atributos do tipo private da sua classe no
formato em que for especificado, no caso XML/SOAP ou binário. Para que uma
classe possa ser serializada, é necessário informar o atributo <Serializable()>
em [VB.NET] ou [Serializable()] em [C#] antes da declaração da classe, isso faz
com que o framework autorize a serialização desta classe e, dessa forma,
mantenha o estado do objeto no formato especificado.
42
using System;
namespace ConjuntoClasseSeri
{
[Serializable]
public class ClasseParaSerializar
{
[NonSerialized]
public string uname;
[NonSerialized]
public int uid;
public string ename;
public int esal;
public int calcHRA(int a,int b)
{
return (a-b);
}
public int CalcPF(int a,int b)
{
return (b-a);
}
public int Deductions;
public int NetSal;
}
}
Figura 21 – Classe que será serializada
using System;
using System.Runtime.Serialization.Formatters.Binary;
using System.IO;
namespace ConjuntoClasse
{
class Class1
{
[STAThread]
static void Main(string[] args)
{
ConjuntoClasseSeri.ClasseParaSerializar obj= new
ConjuntoClasseSeri.ClasseParaSerializar();
obj.Deductions=90;
obj.NetSal=1000;
Stream a= File.OpenWrite("C:\\abc.bin");
BinaryFormatter bf=new BinaryFormatter();
bf.Serialize(a,obj);
a.Close();
}
}
}
Figura 22 – Classe que invoca o processo de serialização
•
Serialização em XML. Este mecanismo de serialização utiliza as classes
contidas
no
namespace
System.XML.Serialization.
Neste
processo
de
serialização os objetos são formatados como documentos XML. Existem
43
algumas regras que devem ser observadas para a utilização deste tipo de
processo de serialização.
o Serializa somente os campos públicos e valores das propriedades de um
objeto em uma stream XML;
o Não inclui informação de tipo;
o Requer um construtor padrão a ser declarado na classe a ser serializada;
o Requer que todas as propriedades que serão serializadas sejam de
leitutora e escrita. Por conseguinte, propriedades somente leitura não são
serializadas;
using
using
using
using
using
System;
System.Collections;
System.IO;
System.Xml;
System.Xml.Serialization;
[XmlRoot("shoppingList")]
public class ShoppingList {
private ArrayList listShopping;
public ShoppingList() {
listShopping = new ArrayList();
}
[XmlElement("item")]
public Item[] Items {
get {
Item[] items = new Item[ listShopping.Count ];
listShopping.CopyTo( items );
return items;
}
set {
if( value == null ) return;
Item[] items = (Item[])value;
listShopping.Clear();
foreach( Item item in items )
listShopping.Add( item );
}
}
public int AddItem( Item item ) {
return listShopping.Add( item );
}
}
public class Item {
[XmlAttribute("name")] public string name;
[XmlAttribute("price")] public double price;
public Item() {
}
public Item( string Name, string Price ) {
name = Name;
price = Price;
}
}
Figura 23 – Classe que será serializada
44
ShoppingList myList
myList.AddItem( new
myList.AddItem( new
myList.AddItem( new
= new
Item(
Item(
Item(
ShoppingList();
"eggs",1.49 ) );
"ground beef",3.69 ) );
"bread",0.89 ) );
// Serialization
XmlSerializer s = new XmlSerializer( typeof( ShoppingList ) );
TextWriter w = new StreamWriter( @"c:\list.xml" );
s.Serialize( w, myList );
w.Close();
// Deserialization
ShoppingList newList;
TextReader r = new StreamReader( "list.xml" );
newList = (ShoppingList)s.Deserialize( r );
r.Close();
Figura 24 – Processo de serialização/desserialização
2.5.7 .NET Remoting
O .NET Remoting proporciona que seus aplicativos tenham comunicação com
sistemas remotos utilizando protocolos de comunicação. Dessa forma, podemos
aproveitar todos os recursos de um projeto Windowsforms com a facilidade de acessar
informações remotas, estando em sua intranet ou até mesmo na internet. (SANCHES,
Andrey)
O .NET Remoting proporciona um ambiente de comunicação entre aplicativos
em um cenário distribuído. Neste sentido, podem ser aproveitados recursos diversos
onde quer que estes sejam disponibilizados fisicamente.
Para que processos troquem informações, criam-se métodos com parâmetros e
retornos de funções, e para que esses objetos possam trafegar devem ser serializáveis.
Uma vez serializado, o objeto é enviado em um formato definido para que seja
transportado pela rede até seu destino.
45
2.5.7.1 Arquitetura
Figura 25 – Arquitetura .NET Remoting
Dependendo de sua categoria, um tipo remoto pode passar dos limites do
framework ou pode ser acessado dentro do mesmo. Existem três categorias de tipos
remotos: marshal−by−value, marshal−by−reference, and context−bound.
•
Marshal-by-Value – instâncias de tipos marshal-by-value podem cruzar os
limites do framework através da serialização dos objetos. Uma vez serializado, a
infra-estrutura do .NET Remoting transfere a seqüência de bits através das
fronteiras do framework em outros domínios de aplicativos (application domain)
ou contextos, onde o framework então desserializa a sequência de bits em uma
instância de tipo correspondente ao estado capturado no momento da
serialização.
Figura 26 – Funcionamento do marshal-by-value
46
•
Marshal-by-Reference – Instância do tipo marsha-by-reference realiza o
instanciamento de um tipo em um application domain mantendo a ciência que
todos os acessos ao objeto ocorrerão na instância do objeto contida no
application domain desejado. Este tipo de instanciamento é utilizado quando se
quer utilizar a instância de um objeto desde que esteja sendo executada em uma
determinada máquina.
Figura 27 – Funcionamento do marshal-by-reference
•
Context-Bound – Derivando o tipo da System.ContextBoundObject irá restringir
instâncias de alguns tipos contidos em um contexto específico. Objetos contidos
em
contextos
externos
não
podem
acessar
diretamente
os
tipos
ContextBoundObject, mesmo se outro objeto está contido no mesmo application
domain.
Figura 28 – Acesso a tipos de instância context-bound
47
2.5.7.2 Ativação de Objetos
Antes da instância de um objeto remoto poder ser acessada, este precisa ser
criada e inicializada por um processo chamado ativação. Existem dois tipos de ativação,
são eles:
•
Ativação do Servidor – O processo servidor hospedando o tipo remoto é
responsável por configurar o tipo como um objeto bem definido, publicá-lo
como um endereço bem definido e ativar as instancias do tipo sob demanda.
.NET Remoting distingue a ativação do servidor em dois modelos distintos que
oferecem semânticas diferentes de ativação: singleton e singlecall.
o Singleton – Não mais do que uma instância de um tipo configurado como
singleton pode ser ativado ao mesmo tempo. Uma instância é ativada a
partir do primeiro acesso do cliente, se uma instância não existir.
Enquanto ativa, uma instância singleton irá manipular todas as
requisições de acesso dos clientes. É importante ressaltar que uma
instância singleton pode manter o estado entre as chamadas dos métodos.
o Singlecall – Neste modelo de ativação, uma nova instância do tipo á
ativada em resposta a toda invocação de método realizada. Quando a
instância é liberada esta é colocada para reciclagem no próximo ciclo de
coleta de lixo.
•
Ativação do Cliente – alguns cenários requerem que cada instância de objeto
seja identificada por seu cliente respectivo. Este tipo de instanciamento pode
mater ativa entre as chamadas de método e participar do mesmo ciclo de vida
exposto pelo esquema singleton. Entretanto, ao invés de uma única instância de
tipo servir todos os clientes, cada cliente referencia instâncias dos tipos remotos
separadamente.
2.5.7.3 Benefícios das aplicações distribuídas
Um dos grandes benefícios do modelo de aplicações distribuídas é a tolerância a
falhas. Isto sugere que o sistema possa manter sua integridade mesmo com após a
ocorrência de um erro. Isto é possível pois a arquitetura de um sistema distribuído é
composta por unidades lógicas bem definidas e que, ao falhar, podem ser substituídas
por outras sem prejuízo ao funcionamento do sistema.
48
Outra grande importância observada é a escalabilidade das aplicações
distribuídas. A medida que a demanda do sistema for aumentando basta realizar uma
redistribuição dos recursos para a resposta a esta nova necessidade.
Por fim, a administração de aplicativos distribuídos é mais efetiva. Todavia, a
existência de módulos concisos e interdependentes que diminuem a duplicação de
código e partem da premissa da reutilização de recurso, possibilita que os processos de
manutenção sejam muito mais eficazes. Outrossim, a alteração de um determinado
ponto do sistema terá impacto somente no escopo do módulo em questão, não
comprometendo o funcionamento de todo o resto do sistema.
49
3
CENÁRIOS
Atualmente, o cenário proposto pelos sistemas distribuídos é bastante eficiente,
no âmbito do compartilhamento de recursos e o aumento da escalabilidade de
aplicativos. Entretanto, é notório que as técnicas propostas para a distribuição de
sistemas são objetivadas, somente, na evolução tecnológica de técnicas antecessoras,
haja vista o DCOM (Distributed Component Object Model) que se apresenta como um
conjunto de agregações de técnicas de distribuição ao modelo COM (Component Object
Model).
Com a formalização da arquitetura orientada a serviços foi possível à reflexão
sobre todo o processo de concepção e desenvolvimento de sistemas em ambientes
distribuídos. Sob esta nova ótica o foco primordial dos aplicativos deve estar voltado à
solução dos requisitos de negócio através da aplicação racional, e não fundamental, da
tecnologia. Neste sentido, a arquitetura dos sistemas deve ser capaz de torná-los mais
flexíveis para contemplarem tais necessidades em um ambiente de rápidas mudanças.
Contudo, o consumo e fornecimento de serviços, premissa que norteia todo o
conceito de arquiteturas orientadas a serviço só foi possível à medida que os sistemas
começaram a ser projetados focados em uma divisão modular de seus processos. Com
esta divisão, foi possível o esclarecimento de sistemas enquanto composição de
componentes (unidades lógicas concisas e agrupadas por funcionalidades afins) que
interagem entre si.
Todavia, o advento dos Web Services possibilitou que a utilização da arquitetura
orientada a serviços tivesse um crescimento sistemático nas instituições. Uma solução
proposta segundo a orientação a serviços prevê a construção de sistemas e a interação
entre estes, no intuito do alcance dos objetivos determinados pelos requisitos de negócio
50
e, como demonstrado em capítulos anteriores, é sob esta ótica que os Web Services
foram concebidos.
3.1
Modelo tradicional de utilização de Web Services
No modelo tradicional de utilização de Web Services pode-se observar um
cenário claro de consumo de serviços. Observa-se então, um conjunto de Web Services
contendo funcionalidades, que são implementadas sob demanda e liberadas para
consumo.
Clientes
O
/S
TP
T
H
AP
Internet
Web Service X
Rede TCP/IP
Web Service Y
Servidor de Aplicação Web
Web Service Z1
Web Service Z2
Web Service Z3
Servidor de Banco de Dados
Figura 29 – Modelo Web Services
Este modelo é constituído da seguinte forma:
•
Clientes – entidade que consome os recursos de um ambiente distribuído.
Realizam consultas a servidores de aplicativos, recursos de rede e recursos da
51
Internet. Por conseguinte, podem, ainda, realizar consultas diretamente a
serviços disponibilizados pelos Web Services. Os navegadores são as principais
ferramentas utilizadas para a realização de tais consultas. Devido ao retorno do
Web Service ser um documento XML, o cliente pode manipulá-lo da forma que
melhor atender a sua necessidade;
•
Servidor de Aplicação Web – em um modelo tradicional o servidor de aplicação
é responsável por servir requisições dos clientes a sistemas de gestão, controle
operacional e demais automatizações processuais da instituição. É possível,
inclusive, em determinados momentos estes servidores acessarem serviços
disponibilizados pelos Web Services, encapsular o resultado e trabalhá-lo para
responder a uma determinada solicitação;
•
Servidor de Banco de Dados – ilustra os demais recursos que um ambiente
distribuído pode compartilhar. No caso, trata-se de um repositório de dados.
•
Conjunto de Web Services – Os Web Services são componentes sistêmicos
constituídos por um conjunto de funcionalidades. Estas funcionalidades são,
como visto, expostas para acesso através de protocolos de comunicação padrões
da internet.
Ve-se, contudo, que os Web Services apesar de serem conceitualmente flexíveis,
o são a partir do momento de sua liberação para acesso externo, ou seja, a flexibilidade
oferecida por eles está na possibilidade de acessarmos funcionalidades através de
protocolos padrões. Entretanto, o modelo tradicional não trata da flexibilidade quanto à
concepção e construção de Web Services.
Imaginemos, pois, um cenário de necessidades variáveis em que, por conta disto,
sejam necessárias a publicação de diferentes serviços através de Web Services. Neste
caso, é necessário que, para cada nova necessidade, uma nova funcionalidade seja
agregada a um determinado Web Service para então ser liberado para o consumo.
52
4
WEB SERVICE GENÉRICO
O modelo de proposto pelos Web Services genéricos credita a outras tecnologias
a possibilidade de generalização do conceito de disponibilização de serviços. Através da
junção de conceitos propostos basicamente pelas tecnologias Reflection e Remoting, é
possível um ganho significativo na flexibilidade da concepção e construção de Web
Services.
Em um modelo de sistemas distribuídos a utilização de Web Services Genéricos
apresenta um cenário semelhante ao encontrado em modelos tradicionais quanto ao
consumo de serviços. A grande mudança observada está em seu projeto e
desenvolvimento, onde se observa a existência de um único Web Service responsável
pelo provimento de n serviços.
Contudo, a manipulação dos serviços é realizada de maneira indireta. O Web
Service não implementa a lógica envolvida na concepção do serviço, mas sim o reflete
de alguma aplicação que o implemente. Este conceito de reflexão permite uma grande
possibilidade de serviços capazes de serem distribuídos, sem a necessidade de
manutenção de um Web Service responsável por esta tarefa.
Para que este isolamento seja viabilizado, o Web Service Genérico foi
construído a partir de conceitos extraídos de técnicas reflexivas utilizando, por
conseguinte, algoritmos reflexivos sobre os assembly da aplicação-alvo. Tal aplicação é
tida como alvo, pois esta possui a funcionalidade que um determinado cliente está
requisitando. Sendo assim, o Web Service Genérico terá um papel de intermediar esta
requisição, sendo responsável por invocar o processamento da rotina requisitada, bem
como encapsular o resultado emitido em uma mensagem-resposta ao cliente.
Portanto, os passos executados, compreendidos entre a requisição e o
recebimento da resposta pelo cliente/requerente, da seguinte forma: a partir do momento
53
em que o Web Service Genérico recebe uma requisição, este realiza processamentos
reflexivos que determinam o assembly a ser processado em um sistema .NET (este
contido no servidor de aplicação). Através da leitura de seu respectivo metadado, são
determinados detalhes (capítulo 4.1) sobre a maneira com que determinada
funcionalidade deverá ser manipulada e invocada de modo a processar os dados de
entrada informados.
Entretanto, existe um detalhe importante a ser observado. Visto que a aplicação
contida no servidor de aplicação será acessada de maneira implícita, faz-se necessário a
utilização de uma entidade que represente o acesso e ative os objetos necessários
durante o processo de invocação da funcionalidade requisitada pelo cliente. Para tal, é
necessário trabalhar com as premissas expostas pela tecnologia Remoting. Através desta
técnica, é possível que sejam feitas instâncias remotas do objeto requisitado e, com
posse da referência desta instância, a funcionalidade deste objeto pode ser invocada.
Após este processo, o resultado gerado por tal rotina é serializado, empacotados através
do protocolo SOAP e enviados ao processo requerente. Este processamento é
demonstraado através da figura abaixo.
OA
/S
TP
T
H
P
Figura 30 – Modelo Web Services Genéricos
54
4.1
Funcionamento
A interação existente entre o cliente e o serviço em um cenário que utiliza Web
Services Genéricos não é em sua totalidade diferente de um ambiente que contenha
Web Services tradicionais. Basicamente, o processo consiste na chamada de um
determinado WebMethod, cuja descrição está contida no WSDL respectivo. Por
conseguinte, a requisição é processada e o resultado gerado é encapsulado em uma
mensagem XML para ser enviada ao cliente.
Entretanto, a primeira grande diferença observada na utilização de Web Services
Genéricos é encontrada em seu próprio descritor (WSDL), conforme ilustra figura 31.
Neste, é possível verificar a existência de um só método chamado: Get. A descrição
deste método é acrescida da especificação dos quatro parâmetros por ele esperados:
•
pNamespace: nome do Namespace desejado que contém a classe desejada;
•
pClass: nome da classe que contém a funcionalidade desejada;
•
pMethod:nome do método que implementa a funcionalidade desejada;
•
pParameter: parâmetros de entrada do método que implementa a
funcionalidade desejada.
Figura 31– Web Service Genérico - WSDL
Estes parâmetros esperados pelo Web Service Genérico são utilizados para a
determinação do assembly que fornecerá uma determinada funcionalidade, bem como
artefatos para que esta interação seja possível (como os parâmetros de entrada do
método da aplicação-alvo).
Quando, então, o cliente realiza a chamada do WebMethod Get a primeira coisa
realizada é determinar o assembly detentor do Namespace informado. Isto é realizado
através da leitura de todos os metadado dos assembly de uma determinada aplicação
.NET. Ainda sobre o metadado são verificadas as ocorrências do método cuja descrição
55
foi passada pelo cliente. É previsível que possam ser encontradas n ocorrências de
métodos de mesmo nome, pois estes podem ter sido sobrecarregados (Orientação a
Objetos). Desta maneira, para determinar o método correto a ser utilizado para atender a
requisição do cliente, são considerados os parâmetros. Este critério é subdividido em
duas partes: a quantidade de parâmetros informados e o seus respectivos tipos. Para
exemplificar o processamento deste critério seja avaliado o seguinte exemplo: uma
classe implementa dois métodos cujas assinaturas são:
a. public decimal Soma(int x, int y);
b. public decimal Soma(int[] x).
De acordo com o processo reflexivo a partir do metadado são realizados testes
de compatibilidade entre parâmetros esperados e os parâmetros informados. Ao final
desta análise é possível determinar com exatidão se o cliente está invocando,
considerando o exemplo exposto, o método a ou o método b.
Após este período reflexivo é então realizado o instanciamento remoto do objeto
através de Remoting. Visto que o processo de Reflection determinou o assembly, classe
e o método a ser utilizado, tal classe é instanciada e um wrapper recebe a serialização
do objeto de retorno. Com este retorno, o Web Service Genérico então prepara o
processo de encapsulamento em uma mensagem XML com estrutura padronizada. Este
padrão é definido no intuito de facilitar o processo de leitura e interpretação do
resultado gerado, por parte do invocador do serviço (cliente).
O XML de retorno possui determinados nodos possíveis que podem ser
esperados pelo cliente, sendo: <Result> que contém o resultado gerado nos casos de
sucesso do processamento e <Error> contendo a descrição dos problemas que podem ter
sido decorrentes do processo de reflexão, instanciamento remoto ou ainda exceções
geradas pela aplicação-alvo.
Desta maneira, a aplicação-cliente poderá realizar a leitura dos nodos do XML
da forma que julgar adequada. Reitera-se assim, que a utilização dos serviços
disponibilizados pelo Web Service Genérico não depende, em nenhum aspecto da
origem de sua chamada, visto que a única ligação existente entre os dois é o protocolo
HTTP/SOAP.
56
5
ESTUDO DE CASO
Para atender as novas tendências mercadológicas e o aumento da demanda de
clínicas e consultórios médicos de grande porte, é necessária a construção e/ou
adaptação dos sistemas especialistas para adequação a esta nova realidade. Tais
adaptações devem ser objetivadas na construção de subsídios ao controle gerencial e
operacional destes ambientes. Além disto, devem possibilitar através de sua utilização o
ajuste dos processos clínicos, a melhoria da utilização dos recursos disponíveis, e, por
conseguinte, a maximização dos resultados.
Neste sentido, seja considerado um sistema desktop que possua funcionalidades
específicas e cuja atuação esteja restrita ao controle do agendamento de pacientes,
prontuário médico e respectivo atendimento em um consultório médico.
Para que tal sistema seja adequado às novas necessidades demandadas pelo
mercado, este deverá ser reformulado de forma a agregar as funcionalidades que não são
por ele contempladas. Esta adaptação pode ocorrer de duas maneiras distintas:
programação das funcionalidades faltantes, ou através da integração com outro sistema
utilizando o conceito de Web Service Genérico.
Tem-se, portanto, dois cenários possíveis onde a aplicação da primeira opção é
tecnicamente simplificada, pois os profissionais envolvidos não perceberiam
modificações quanto às tecnologias utilizadas, entretanto o tempo necessário para que
estas alterações sejam concluídas pode onerar o processo de forma a inviabilizá-lo.
Quanto à aplicação da segunda opção é observada uma necessidade de capacitação dos
profissionais, pois modifica o cotidiano tecnológico existente e demanda tempo em
pesquisa para a definição das melhores práticas a serem utilizadas na chamada dos
serviços por parte da aplicação desktop. Todavia, fica nítido o aumento da robustez do
sistema, por adotar esta alternativa, pois o isolamento proposto pela utilização dos Web
57
Services Genéricos facilitaria a agregação futura de novas funcionalidades e grande
adaptabilidade do sistema desktop frente às demandas mercadológicas.
Avaliando as possibilidades expostas e por questões estratégicas da empresa
fabricante do sistema desktop foi firmada a adoção da segunda opção demonstrada, ou
seja, o cenário operacional, conforme ilustra figura 32, seria composto pela coexistência
da aplicação desktop e uma aplicação Web, cujo comunicação seria intermediada por
um Web Service Genérico.
Aplicação .NET
(Web)
Servidor de
Banco de Dados
Servidor de
Banco de Dados
Web ServiceGenérico
Objeto
Remoto
Aplicação Delphi
(Desktop)
Figura 32 – Integrando as funcionalidades da Aplicação Web
Dando continuidade à especificação deste cenário, são observadas as
características tecnológicas da aplicação Web a ser integrada:
•
tecnologia ASP .Net;
•
ambiente Web;
•
três camadas (3-layer), ou seja, um sistema de gerenciamento de banco de
dados, uma camada de negócio (responsável pela lógica do sistema) e uma
camada de interação com o usuário (UI).
Quanto às características da aplicação desktop:
•
tecnologia Delphi;
•
ambiente desktop;
•
duas camadas (2-layer), ou seja, um sistema gerenciador de banco de dados
(SGBD) e um ambiente de interação com o usuário que agrupa a lógica de
58
negócio e interface com usuário (UI). É instalado em cada computador que
trabalhará com o sistema.
Através de componentes nativos dedo Delphi, foi possível realizar a construção
de uma biblioteca (DLL) responsável por enviar mensagem SOAP ao Web Service
Genérico. Esta mensagem era composta por informações que subsidiasse a manipulação
das funcionalidades da aplicação-alvo (Web) através do Web Service Genérico.
Além disto, foi utilizado o componente TXMLDocument para a leitura e
manipulação do XML retorno gerado pelo WebService Genérico. Por intermédio deste
componente, foram realizadas as leituras aos nodos que continham as informações
buscadas, integrando-as ao fluxo do sistema.
5.1
Validação
É importante salientar que o cenário exposto no estudo de caso demonstra
simultaneamente a manipulação de componentes gerenciados e não-gerenciados, ou
seja, componentes que rodam sobre a plataforma .NET e outros de responsabilidade
exclusiva do sistema operacional. Por conseguinte, para que a aplicação desktop fosse
capaz de realizar chamadas as rotinas da aplicação Web foi necessário que a biblioteca
de tipos (type-library) fosse extraída do assembly .NET, ou de alguma forma, esta
ficasse visível ao ambiente não gerenciado. Isto se deve ao fato dos assembly .NET
possuírem o type-library intrínseco em seu metadado, ao contrário dos componentes
COM não gerenciados.
É bem verdade que esta integração seria tecnicamente possível em cenários
distribuídos que utilizam tecnologias de distribuição COM como DCOM ou CORBA.
Entretanto, estas tecnologias inviabilizam o processo em um ambiente heterogêneo,
como este apresentado, pois são tecnologias fortemente dependentes de plataforma.
Haja vista, com a migração da tecnologia da aplicação-cliente de delphi para Java, por
exemplo, necessitar uma reformulação arquitetural do ambiente distribuído e, por
conseguinte, da definição de outroas tecnologias de distribuição.
Mais ainda, seria possível estender o conceito de binding agregando o COM
Callable Wrapper para viabilizar a interação entre a aplicação desktop e a aplicação
Web .NET. Neste cenário, através do proxy gerado pelo CCW seria possível que
qualquer outra aplicação que suportasse automação de objetos realizasse chamadas aos
59
objetos gerenciados (.NET). Todavia, novamente são encontrados limites quando a
plataforma operacional, não uma solução viável se a aplicação que interagisse com o
sistema .NET fosse baseada em UNIX, por exemplo.
Desta
forma,
o
reaproveitamento
de
recursos
através
de
serviços
disponibilizados pelos Web Services Genéricos se mostrou a solução mais eficaz, poisa
agregou características que eram imprescindíveis para contemplar tal integração, como:
•
compatibilidade: os Web Services utilizam protocolos de comunicação e
formatos de dados padrões, independente da plataforma ou linguagem de
programação;
•
manutenabilidade: a manutenção é um ponto alto na utilização dos Web
Services Genéricos. Enquanto que tecnologias baseadas em RPC (Remote
Procedure Call), como DCOM, CORBA, entre outros, onde a alteração de
um determinado item no prestador do serviço (aplicação-alvo) demandará
uma mudança “em cascata”, os Web Services propõem alterações
independentes que podem ser efetuadas sem a necessidade de alterações
mútuas;
•
custo: a utilização de tecnologias baseadas em RPC pode se tornar inviável,
pois necessita de uma infra-estrutura mais abrangente e homogênea para
viabilizar a utilização de determinadas tecnologias. Por sua vez, os Web
Services são compatíveis com a maioria das infra-estruturas já estabelecidas
nas empresas, visto que este realizará todas as operações referentes a
comunicação de informações sobre protocolo HTTP.
60
6
CONCLUSÕES
Com o presente trabalho é possível entender os conceitos envolvidos na
manipulação de serviços em sua totalidade: fornecimento, distribuição e consumo.
Neste sentido, constata-se a arquitetura orientada a serviços (SOA) como um importante
artefato na concepção de sistemas especialistas, pois abrange premissas que garantem
um melhor tratamento das informações e maior flexibilidade frente às necessidades em
freqüente mudança.
Além disto, foi possível verificar com os capítulos anteriores a permanente
evolução das tecnologias de distribuição visando atender a necessidade de maximizar a
utilização dos recursos disponíveis em um ambiente distribuído. Entretanto, tais
tecnologias devem ser avaliadas sob aspectos que transcendem a viabilidade técnica e
considerem, inclusive, questões estratégicas de ordem mercadológica.
Neste sentido, com a apresentação da tecnologia dos Web Services é possível
compreender ambientes cujos recursos são explorados em sua totalidade sem limitações
decorrentes da interdependência entre componentes. Isto significa que, devido à adoção
de padrões universais, é possível observar uma maior robustez do ambiente distribuído,
pois são superados limites como: homogeneidade de plataformas operacionais e
dependência de protocolos de transporte e comunicação.
Por fim, foi verificado que a concepção de uma nova abordagem dos Web
Services através da agregação de tecnologias baseadas em reflexão e instanciamento
remoto é viável e agrega uma grande flexibilidade e produtividade na manipulação de
serviços. Isto é ilustrado através do estudo de caso que apresentou um cenário clássico
encontrado em ambientes distribuídos: a existência de sistemas heterogêneos que devem
coexistir e compartilharem informações. Viu-se que o processo de integração
apresentado foi significativamente facilitado através da utilização do conceito dos Web
61
Services Genéricos, pois este garantiu maior eficácia no gerenciamento dos serviços
aliado a uma grande facilidade de distribuição.
62
7
REFERÊNCIAS BIBLIOGRÁFICAS
OELLERMANN, William. Prepare a Empresa Orientada a serviços. The Architecture
Journal, Seatle, v. 7, p. 27-32, 2006.
SEHMI, Arvindra; SCHWEGLER, Beat. Modelagem Orientada a Serviços para
Sistemas Conectados – Parte 1. The Architecture Journal, Washington, v. 7, p. 27-32,
2006.
FERBER, J. Computational reflection in class based object-oriented languages. ed. New
York: ACM Press, 1989.
LEITE, José Carlos. XML e XSL da Teoria à Prática. ed. Lisboa: FCA, 2001.
OASIS. Reference Model for Service Oriented Architecture 1.0. <http://www.oasisopen.org/committees/download.php/19679/soa-rm-cs.pdf>. Acesso em: 15 novembro
2006
W3C. eXtensible Markup Language (XML). <http://www.w3.org/XML/>. Acesso em:
20 novembro 2006.
CORPORATION, Microsoft. ASP.NET Web The Official Microsoft ASP.NET Site
Home Page <http://www.asp.net/>. Acesso em: 2 novembro 2006.
W3C. Web Services. <http://www.w3.org/2002/ws/>. Acesso em: 22 novembro 2006.
63
WIKIPEDIA. Web Services. <http://pt.wikipedia.org/wiki/Web_service>. Acesso em:
22 novembro 2006.
MSDN. WebServices.
<http://www.microsoft.com/brasil/msdn/tecnologias/webservices/web_services_4.aspx>
Acesso em: 21 novembro 2006.
LINHA DE CÓDIGO. Consultando e invocando métodos dinamicamente usando
Reflection. <http://www.linhadecodigo.com.br/artigos.asp?id_ac=264>. Acesso em: 15
outubro 2006.
WIKIPEDIA. Reflection (Computer Science).
<http://en.wikipedia.org/wiki/Reflection_(computer_science)>.
Acesso
em:
18
novembro 2006.
WIKIPEDIA.
Service-oriented architecture.
<http://en.wikipedia.org/wiki/Service-
oriented_architecture>. Acesso em 18 novembro 2006.
W3C. SOAP – Specifications. <http:// www.w3.org/TR/soap/>. Acesso em: 20
novembro 2006.
ERL, Thomas. Service-Oriented Architecture : A Field Guide to Integrating XML and
Web Services (Paperback). ed. Indianápolis: Prentice Hall PTR, 2004
W3C. Web Service Definition Language (WSDL). <http://www.w3.org/TR/wsdl>.
Acesso em: 25 novembro 2006
MCLEAN, Scott; NAFTEL, James; WILLIAMS, Kim. Microsoft .NET Remoting. ed.
Washington: MS Press, 2003.
MSDN. COM Callable Wrapper.
< http://msdn2.microsoft.com/en-us/library/f07c8z1c.aspx> Acesso em: 03 junho 2006.