A arquitetura do DASE é composta por diversos agentes. Cada um desses agentes possui um objetivo específico, e para tal, realiza um conjunto de tarefas. No entanto, nenhum desses agentes é capaz de operar de modo isolado, tendo que interagir com outros agentes DASE. Esta interação ocorre normalmente através da prestação de serviços entre os agentes.
A tabela 2 relaciona todos os serviços prestados pelos agentes DASE. A coluna “agente solicitante” traz o agente que solicita o serviço. Há um único serviço em que o protocolo FIPA Request não é utilizado, dando lugar ao protocolo FIPA
Recruiting. Isto ocorre no serviço Data Request. Neste caso o agente solicitante, um
agente cliente, não possui contato direto com quem presta o serviço, um agente
DASEDataProvider. Um agente intermediário, DASEServiceLocator, é responsável
por selecionar ou encontrar quem prestará o serviço, agente DASEDataProvider, e encaminhar a solicitação do solicitante. E para que esse encaminhamento ocorra, um serviço intermediário é utilizado, chamado Service Dispatch. O resultado do serviço é entregue pelo agente servidor, DASEDataProvider, diretamente ao agente solicitante. Os protocolos FIPA de interação entre agentes utilizados durante o
projeto do DASE foram descritos com mais detalhes na seção 2.5. Os serviços
Service Dispatch e Data Request estão fortemente relacionados e serão descritos
detalhadamente nas seções 6.3 e 8.3.
Tabela 2 - Serviços prestados pelos agentes DASE. Agente
solicitante intermediário Agente Serviço servidor Agente Protocolo
DM - Kill itself DX FIPA Request
DX - DASEProxy AID registry DM FIPA Request
DX - System Shutdown DM FIPA Request
CA - Environment Creation DM FIPA Request
Nd - Node Abortion DE FIPA Request
Nd - Node Ready SL FIPA Request
CA - Service Dispatch SL FIPA Recruiting
DE - Kill itself Nd FIPA Request
CA SL Data Request DP FIPA Recruiting
Sc - Transaction Observer DP FIPA Request Sc - Request Transaction Operation CC FIPA Request
Sc - Confirm Transaction Operation CC FIPA Request Sc - Transaction Finished CC FIPA Request
A tabela 3 relaciona a cada serviço os parâmetros que especificam sua solicitação, o resultado esperado e uma constante de identificação, utilizada para identificá-lo. EnvironmentDescriptor e ServiceDescriptor são objetos DASE que representam respectivamente todas as características de um ambiente de dados e todos os detalhes referentes a uma requisição de acesso a dados. Já SQL Sentence é a sentença SQL utilizada em uma requisição de acesso a dados. TransactionId é
um identificador que garante unicidade entre as transações do sistema de controle de concorrência do DASE, além de guardar informações adicionais sobre cada transação. TransactionOperation representa uma operação de leitura ou escrita de uma transação. Os objetos da coluna resultado serão explicados nas seções 6.3, 6.4 e capítulo 8. Em seguida, a tabela 4 descreve cada um dos serviços mencionados nas tabelas 12 e 13.
Tabela 3 - Detalhes sobre os serviços prestados pelos agentes DASE.
Serviço Parâmetros Resultado Constante
Kill itself - - KILL
DASEProxy
AID registry - - SYSTEM_REGISTRY
System
Shutdown - - SHUTDOWN
Environment
Creation Environment Descriptor - ENVIRONMENT_CREATION Node
Abortion - - NODE_ABORTION
Node Ready - - NODE_READY
Service
Dispatch Service Descriptor MessageTemplate SERVICE_DISPATCH
Kill itself - - KILL
Data
Request SQL Sentence DASEResult DATA_REQUEST
Transaction
Observer TransactionId - TX_OBSERVER
Request Transaction
Operation TransactionOperation - | TransactionId REQUEST_TX_OPERATION Confirm
Transaction
Operation - - CONFIRM_TX_OPERATION
Transaction
Tabela 4 - Descrição dos serviços prestados pelos agentes DASE.
Serviço Descrição
Kill itself
Este serviço é prestado por dois tipos de agentes DASE, o DASEProxy e o DASENode. O DASEManager utiliza este serviço do DASEProxy para avisá-lo de que o sistema será encerrado, e portanto deve encerrar sua execução. De forma análoga, um agente
DASEEnvironment utiliza este serviço de um agente DASENode para
avisá-lo de que o ambiente de dados será encerrado e, consequentemente, todos os seus agentes DASENode deverão fazer o mesmo.
DASEProxy AID registry
Os agentes DASEProxy registram seu AID no DASEManager para que possam comunicar-se sempre que necessário. Por exemplo, quando o
DASEManager utiliza o serviço Kill itself dos agentes DASEProxy.
System Shutdown
Serviço que permite a um agente DASEProxy encaminhar uma solicitação de um agente cliente ao agente DASEManager de encerramento do sistema.
Environment
Creation Este serviço é prestado pelo DASEManager aos agentes clientes, permitindo a solicitação de criação de novos ambientes de dados.
Node Abortion
Através deste serviço um agente DASENode pode avisar o agente
DASEEnvironment de que alguma situação inesperada o impede de
operar normalmente, e por isso deve ser abortado. Baseado neste aviso o DASEEnvironment pode até mesmo decidir por abortar o próprio ambiente de dados, caso não reste nenhum DASENode em condições de operar.
Node Ready
Este serviço permite que cada agente DASENode informe ao agente
DASEServiceLocator que já estão aptos a receberem requisições de
acesso a dados. Assim que o agente DASEServiceLocator recebe tal notificação de todos os nós ele publica seus serviços para que os mesmos possam ser uti lizados pelos agentes clientes.
Service Dispatch
Um agente cliente utiliza este serviço para iniciar o processo de requisição de acesso a dados. Quem presta este serviço é o agente
DASEServiceLocator do ambiente de dados cuja informação o agente
cliente deseja acessar. O agente DASEServiceLocator definirá de qual nó virá o agente DASEDataProvider que proverá o serviço de acesso a dados. Isto é feito conforme descrito na seção 6.3 , sobre balanceamento de carga. Como resposta o agente
DASEServiceLocator envia ao agente cliente um objeto MessageTemplate, que permitirá ao agente cliente identificar a
mensagem que contém o resultado da requisição de acesso a dados. Este objeto é um recurso do JADE, e seu uso é explicado com detalhes na subseção 8.3.3.
Data Request
Este é o serviço de requisição de dados. Tal serviço é sempre prestado a um agente cliente, e quem o oferece é um agente
DASEDataProvider. Entretanto um agente DASEServiceLocator
Transaction Observer
Este serviço é oferecido a agentes Scheduler por agentes
DASEDataProvider para evitar reinícios cíclicos. Para tal o agente Scheduler não reinicia a transação abortada enquanto a transação que
causou o seu aborto não concluir. Request
Transaction Operation
Os agentes Scheduler utilizam este serviço, oferecido pelo agente
ConcurrenyController, para obterem permissão de execução de uma
determinada operação de uma transação. Enquanto a permissão não é concedida a operação não é executada.
Confirm Transaction
Operation
Este serviço permite que um agente Scheduler confirme com o agente
ConcurrencyController que uma determinada operação foi executada
com sucesso. Caso algo inesperado ocorra durante a execução da operação, este serviço não será utilizado, e a notificação de aborto da transação será realizada através do serviço Transaction Finished.
Transaction Finished
Este serviço é oferecido pelo agente ConcurrencyController aos agentes Scheduler para que estes possam informá-lo sobre a conclusão de uma transação, seja ela aborto ou confirmação. Em seguida outras operações que dependiam da conclusão da transação recém confirmada poderão receber o direito de prosseguirem. O controle de concorrência do DASE é descrito com mais detalhes na seção 6.4.
A figura 18 ilustra a interação entre os agentes DASE, e agentes clientes também, considerando os seus serviços prestados. O destino da seta indica quem prestará o serviço, enquanto que a origem indica quem solicitou o serviço. Um losango interceptado por uma seta indica que tal serviço é intermediado por outro agente, identificado por uma seta tracejada.
Figura 18 - Serviços prestados entre agentes DASE e entre agentes DASE e agentes clientes.