Pular para o conteúdo principal

Criando Módulos e DataSources no Wildfly

Hoje iremos ver como criar um Módulos e DataSources no Wildfly Application Server.

O que é um Módulo ?


Módulos no Wildfly são recursos que podem ser utilizados em diversos lugares dentro da instância em execução do Container, eles podem ser reaproveitados em diversos lugares, tais como: artefatos, datasources, entre outros.

Criando um novo Módulo


A criação de módulos no Wildfly é uma tarefa simples, em nosso exemplo, iremos criar um módulo referente ao Driver JDBC do PostgreSQL, para isso deve-se executar os seguintes passos:

1- Acessar o diretório: {WILDFLY_HOME}/modules/system/layers/base:
Diretório base.

2- Criar a estrutura org/postgresql/main, e adicionar o driver(.jar) do PostgreSQL dentro do diretório main:
Driver do banco de dados PostgreSQL.

3- Ainda no diretório main, criar o arquivo module.xml com o seguinte conteúdo:

<?xml version="1.0" encoding="UTF-8"?>
<module xmlns="urn:jboss:module:1.3" name="org.postgresql">
    <resources>
        <resource-root path="postgresql-9.4.1208.jar"/>
    </resources>
 <dependencies>
        <module name="javax.api"/>
        <module name="javax.transaction.api"/>
    </dependencies>
</module>

4- Após seguir os passos o módulo esta criado e pronto para o uso:

Diretório main com os arquivos.

Agora iremos criar um DataSource referenciando o módulo acima.


O que é um DataSource ?


DataSource é uma fonte de dados onde as aplicações iram buscar informações externas ao Container, estas informações geralmente estão em um banco de dados, mas também podem vir de outras fontes, ao criar DataSources podemos estipular várias características de acesso a fonte de dados, tais como: pool de conexão, registro JNDI, entre outras.


Criando um novo DataSource


1- Acessar o diretório: {WILDFLY_HOME}/standalone/configuration:
Diretório com arquivos de configuração.

2- Editar o arquivo standalone.xml, e adicionar o driver a tag <drivers />:
<drivers>
  <driver name="postgresql" module="org.postgresql">
      <xa-datasource-class>org.postgresql.Driver</xa-datasource-class>
  </driver>
</drivers>

3- Ainda no arquivo standalone.xml, criar um DataSource na tag <datasources />:
<datasources>
  <datasource jndi-name="java:jboss/datasources/testePostgreSQL" 
              jta="true" 
              pool-name="testePostgreSQL" 
              enabled="true" 
              use-java-context="true">
      <connection-url>jdbc:postgresql://localhost:5432/teste</connection-url>
      <driver>postgresql</driver>
      <pool>
        <min-pool-size>5</min-pool-size>
        <max-pool-size>10</max-pool-size>
        <prefill>true</prefill>
      </pool>
      <security>
         <user-name>postgres</user-name>
         <password>admin</password>
      </security>
  </datasource>
</datasources>

Após seguir todos os passos e iniciar o Wildfly, dentro do sistema de administração, na aba configuração, podemos ver o DataSource criado:

DataSource criado e pronto para uso.

Até a próxima.


Comentários

Postagens mais visitadas deste blog

Utilizando LocalDate, LocalDateTime e LocalTime na Prática

Tudo bem pessoal, hoje iremos avaliar e analisar operações de manipulação de Datas envolvendo a JavaTime API introduzida no Java 8.

Exemplos da java.time API
Já se passaram alguns anos desde o lançamento do Java 8 e mesmo após este período, há empresas que desconhecem o poder da java.time API, esta foi uma nova API de datas introduzida no Java 8 visando resolver problemas que tínhamos com as velhas classes Date e Calendar.

Vamos mostrar vários exemplos práticos do uso da API:
Criação de objetos No exemplo abaixo, estamos criando os objetos para manipulação de datas, perceba que temos 3 tipos, sendo LocalDate para manipular datas, LocalDateTime para manipular data/hora e LocalTime para horas:
LocalDate localDate = LocalDate.now(); LocalDateTime localDateTime = LocalDateTime.now(); LocalTime localTime = LocalTime.now();
Utilizando formatação Aqui realizamos a operação de formatação, perceba que não foi necessário utilizar a classe SimpleDateFormat, que usaríamos em conjunto com D…

Lendo e Manipulando arquivos CSV com Java

Olá hoje veremos como realizar a leitura e manipulação de arquivos CSV com Java, mostrando que as novas versões da plataforma Java deixaram algumas tarefas simples de serem realizadas.

Exemplo de Arquivo Hoje em dia é comum ao realizar integrações ou carga de dados o uso de arquivos CSV, isto porque, este arquivo possui uma estrutura de fácil entendimento e simples de manipular na maioria das plataformas de desenvolvimento.

Para realizar a leitura dos dados vamos manipular um arquivo com as seguintes colunas: namecpfagephone address:

name;cpf;age;phone;address caio;123456789;20;1145223643;AvenidaPaulista vinicius;147852369;18;1125253625;AvenidaManoel sandra;963258741;30;1174587858;RuaTeixeira regina;125478522;40;1145254536;RuaFernando fernando;785245563;42;1145253669;RuaPereira augusto;456123014;50;1125363633;AvenidaPaulinia maria;456123789;10;1125455525;AvenidaNossaSenhora
Para representar os dados em objetos Java iremos utilizar a seguinte classe:

importlombok.AllArgsConstruc…

Versionamento de Banco Dados com Flyway

Olá pessoal, hoje iremos analisar e aprender como realizar o versionamento e gerenciamento das bases de dados relacionais utilizando o framework Flyway.

Versionamento de Banco Dados Ao trabalhar com desenvolvimento de sistemas é comum realizarmos o versionamento, isso porque uma aplicação pode necessitar de correções, novas funcionalidades e evoluções, onde para garantir a compatibilidade e cuidar do seu ciclo de vida, geramos versões onde é especificado quais itens estão presentes em cada release.
Vamos imaginar seguinte cenário: Sistema ERP1.0.0: Entrega dos módulos Financeiro e RH;1.1.0: Entrega do módulo Contas a Receber. Perceba que a ideia é controlar o que cada versão possui de diferente, e para controlar essas mudanças no lado da aplicação existem várias técnicas e ferramentas, mas e para controlar as mudanças no lado do Banco de dados ? 
Para isso podemos utilizar ferramentas de versionamento que ajudam a realizar este controle, a ferramenta que iremos utilizar é o Flyway.
Con…