quarta-feira, 5 de setembro de 2018

Entenda o funcionamento das transações do Entity File Manager

Entity file manager é um recurso que permite persistir entidades em arquivos estruturados. Ele foi desenvolvido com a finalidade de dar suporte à persistência de dados no BRCache.

Transações


Uma transação é uma coleção de operações que desempenha uma função lógica única. Ela tem que ter as seguintes propriedades:

  • atomicidade: todas as operações contidas na transação são tratadas como uma única unidade. Todas as operações são feitas ou nada é feito.
  • consistência: uma transação concluída deixa o sistema em um estado interno consistente.
  • isolamento: em um ambiente de múltiplas transações, uma não interfere na outra.
  • durabilidade: os resultados das transações são armazenadas permanentemente no sistema.

O entity file Manager permite que transações confirmadas possam ser efetivadas em paralelo com transações em execução. Também favorece a redução das operações de I/O, pois ele permite atualizações em lote. Todas as operações de inserção e atualização são executadas em um arquivo temporário num primeiro momento e depois em segundo plano no arquivo original.

Insert/Update


As transações confirmadas são gravadas no arquivo recoverylogX e os dados das entidades também são gravadas no arquivo temporário. Elas são inseridas sempre no final do arquivo. Este método reduz o I/O em updates, pois toda atualização também é uma inserção e pode ser feito em lote. No momento em que não existir nenhum transação sendo processada, o arquivo temporário é sincronizado com o arquivo original.


Select


Quando um arquivo está envolvido em uma transação, a pesquisa sempre ocorre primeiro no arquivo temporário e depois no arquivo original. A pesquisa ocorre sempre primeiro no arquivo temporário, porque nele ficam armazenadas as alterações feitas pelas transações anteriores depois da última sincronização com o arquivo original.


Efetivando as transações


Quando o arquivo recoverylogX atinge o seu tamanho máximo, ele é fechado e enviado para um processo paralelo que aplica as alterações no arquivo original. O arquivo temporário é sincronizado com o arquivo original somente quando não houver transações ativas.


terça-feira, 4 de setembro de 2018

Entity file manager (subprojeto do BRCache)



Entity file manager é um recurso que permite persistir entidades em arquivos estruturados. Ele foi desenvolvido com a finalidade de dar suporte à persistência de dados no BRCache. Ele basicamente é composto pelas classes EntityFileManager, EntityFile, EntityFileAccess e EntityFileTransactionManager.

1. EntityFileManager


A classe EntityFileManager provê todos os recursos necessários para a manipulação de entidades. Ela trabalha em conjunto com EntityFileAccess para armazenar as entidades no arquivo e EntityFileTransactionManager para manter a consistência. 
Para cada operação de inserção, atualização e seleção, é necessário que sempre tenha uma transação explicita.
São providas somente instâncias da EntityFile associadas a uma transação. As operações executadas nela são delegadas ao EntityFileTransactionManager que faz as o necessárias para manter a consistência do arquivo.

2. EntityFile


A classe EntityFile provê recursos que permitem manipular um tipo específico de entidade. Com ela é possível inserir, atualizar, apagar e selecionar uma entidade. Ao inserir uma entidade, o EntityFile envia uma requisição ao EntityFileTransactionManager solicitando que a entidade seja incluída no arquivo. Depois de inserida, é obtida uma identificação única. A identificação indica a posição da entidade dentro do arquivo.
Na atualização, o EntityFile envia uma requisição ao EntityFileTransactionManager solicitando que ela  seja atualizada no arquivo. Então ocorre seu bloqueio, atualização e posterior liberação após o fim da transação.
A exclusão de uma entidade é, em síntese, uma atualização. A operação vai depender do EntityFileAccess. Este pode apenas inserir um entidade vazia ou também mapear a lacuna para uma posterior inserção.
Na seleção, o EntityFile envia uma requisição ao EntityFileTransactionManager solicitando a entidade e ele devolve a entidade ou null que pode ser obtido diretamente do arquivo ou de um outro local temporário. O bloqueio nesse caso é opcional.

3. EntityFileTransactionManager


A classe EntityFileTransactionManager é responsável por manter a consistência dos arquivos após sua alteração. Ele recebe as requisições do EntityFile e as processa. A forma como o processamento de tais requisições é feita, vai depender da implementação utilizada.
O EntityFileTransactionManager pode gerar dois tipos de logs. O recoverylog que permite recuperar as transações após parada abrupta da aplicação e o binlog que tem a função de permitir a replicação das operações em outra aplicação.
Os dois logs possuem o seguinte formato:

****************************************************************
|             |              corpo             |               |
****************************************************************
|             |              |                 |               |
| ml (8 bytes)| nt (8 bytes) | t (nt - nl - 8) | chk (8 bytes) |
|             |              |                 |               |
****************************************************************
  • ml: marcação da transação. Ele indica um novo registro e seu valor é o ponteiro obtido após sua leitura no arquivo;
  • nt: apontamento para o próximo registro do log ou final do arquivo;
  • t: dados da transação, tem o tamanho (nt-nl-8) bytes;
  • chk: conjunto de 8 bytes usado para validar o corpo do registro.
Os dados da transação (t) tem o seguinte formato:

**********************************************************************
|        |         |         |         |         |         |         |
|   st   |   to    |   id    |    i    |   flg   |    ef   |   efd   |
|(1 byte)|(8 bytes)|(8 bytes)|(1 bytes)|(1 bytes)|(1 bytes)|(n bytes)|
|        |         |         |         |         |         |         |
**********************************************************************
  • st: status da transação;
  • to: timeout original da transação;
  • id: identificação da transação;
  • i: isolamento da transação;
  • flg: flags que indicam se a transação foi confirmada, cancelada e iniciada;
  • ef: indica a continuidade ou o fim da lista de EntityFile utilizados na transação. O valor -1 indica o final da lista;
  • efd: dados do EntityFile manipulado na transação.
Os dados do EntityFile na transação tem o seguinte formato:

****************************************************************
|           |                                        |         |
| cabeçalho |                   dados                |   eof   |
| (n bytes) |                 (n bytes)              |(n bytes)|
|           |                                        |         |
****************************************************************
  • cabeçalho: cabeçalho do EntityFile. O tamanho é o mesmo do cabeçalho original;
  • dados: lista das entidades manipuladas na transação;
  • eof: indicação do final do EntityFile. O tamanho é o mesmo do eof original.

3.1 AsyncRecoveryTransactionLog



A classe AsyncRecoveryTransactionLog é a implementação padrão do recovery log. Permite que transações confirmadas possam ser efetivadas em paralelo com transações em execução. Também favorece a redução das operações de I/O, pois ele permite atualizações em lote. Todas as operações de inserção e atualização são executadas em um arquivo temporário num primeiro momento e depois em segundo plano no arquivo original.
Uma transação confirmada é gravada no arquivo recoverylogX e as alterações dela também são gravadas no arquivo temporário. 
Quando o arquivo recoverylogX atinge o seu tamanho máximo, ele é fechado e enviado para um processo paralelo que aplica as alterações no arquivo original. O arquivo temporário é sincronizado com o arquivo original somente quando não houver transações ativas.
Em caso de parada abrupta da aplicação, o log de transação pode ser cortado na última transação válida. Isso é possível porque as transações são registradas de forma sequencial no arquivo e sua estrutura permite avaliar a integridade da transação. Este corte não ocorre de forma automática e precisa ser autorizado antes da aplicação ser iniciada. É possível definir como padrão o corte do arquivo de log. 

4. EntityFileAccess


A classe EntityFileAccess provê recursos que permitem manipular diretamente o arquivo. Ele é responsável por gravar e ler os dados das entidades. A estrutura do arquivo é definida pelo EntityFileAccessHandler que codifica e decodifica o cabeçalho e as entidades em dados.

quinta-feira, 16 de agosto de 2018

Nova versão do Brutos Framework liberada!



Liberada a versão 2.0 rc3 do Brutos Framework. O dowload da nova versão pode ser feita na página de download e as alterações estão descritas no changelog.

O Brutos Framework é um controlador MVC desenvolvido em Java. Projetado para reduzir a complexidade do desenvolvimento web, com mapeamento configurável, resolução de vista, bem como suporte ao upload e download de arquivos. Podendo ser configurado usando XML, anotações e CoC.

Quais as vantagens em utilizá-lo?


  • leve;
  • baixo acoplamento;
  • produtivo;
  • geração de componentes testáveis;
  • suporte avançado de mapeamento;
  • fácil aprendizado.


Obtendo o pacote


Os pacotes de liberação estão hospedados no sistema de arquivos da SourceForge em formato ZIP. 
Cada pacote contém jars, exemplos, código fonte e entre outros. Seu download pode ser feito a partir da url http://sourceforge.net/projects/brutos/files/brutos/.

Repositório de artefatos Maven


  • brutos-core: artefato principal, necessário para construir aplicações usando o Brutos APIs nativo.
  • brutos-annotation: artefato opcional que permite a construção de aplicações usando anotações. Este artefato depende do brutos-core.
  • brutos-web: artefato opcional que permite a construção de aplicações web. Este artefato depende do brutos-core.

O repositório oficial do Brutos Framework é http://www.brutosframework.com.br/maven/2.

Como configurá-lo?


Registrar o listener no web.xml



Atenção: Se estiver sendo usado um container que suporte a especificação Servlet 3.0, o registro do ContextLoadListener não será necessário. Ele é automaticamente registrado. 

Registrar o filtro no web.xml



Atenção: Se estiver sendo usado um container que suporte a especificação Servlet 3.0, o registro do BrutosRequestFilter não será necessário. Ele é automaticamente registrado. 

Opções de configuração


  • Anotações
  • XML
  • CoC (Convenção sobre configuração)

Principais anotações


  • @Controller: indica um controlador;
  • @Action: indica uma ação;
  • @RequestMethod: associa uma ação a um determinado método HTTP;
  • @ResponseStatus: define o status HTTP da resposta de uma ação;
  • @ResponseError: define o status HTTP da resposta quando é lançada uma exceção;
  • @AcceptRequestType: indica os formatos de requisição suportados por uma ação;
  • @ResponseType: indica os formatos de resposta suportados por uma ação;
  • @Any: especifica o mapeamento de polimorfismo;
  • @View: define a vista de uma ação;
  • @Basic: especifica o mapeamento básico de um bean;
  • @Intercepts: especifica um interceptor.


terça-feira, 22 de maio de 2018

Exemplo de Brutos MVC com Spring (Brutos 2.0 + Spring 5.0.6)


Exemplo de Brutos MVC com Spring. O código fonte dos exemplos estão hospedados no GitHub.

Código fonte: https://github.com/brandaof/brutos-spring

sábado, 19 de maio de 2018

Exemplo de formulário com senha. (Brutos + Bootstrap 4 + Hibernate Validator + Weld)


Exemplo de formulário com senha. O código fonte dos exemplos estão hospedados no GitHub.

Código fonte: https://github.com/brandaof/brutos-password-form


quinta-feira, 17 de maio de 2018

Enviando um formulário com múltiplas linhas para um List com Brutos MVC (Brutos + Bootstrap 4)


Enviando um formulário com múltiplas linhas para um List com Brutos MVC. O código fonte dos exemplos estão hospedados no GitHub.

Código fonte: https://github.com/brandaof/brutos-multiple-row-form


quarta-feira, 16 de maio de 2018

Exemplo de post de formulário em Map com Brutos MVC (Brutos + Bootstrap 4 + Weld)


Exemplo de post de formulário em Map com Brutos MVC. O código fonte dos exemplos estão hospedados no GitHub.

Código fonte: https://github.com/brandaof/brutos-value-key-map-form