terça-feira, 17 de novembro de 2015

CONFIGURANDO A EXCLUSÃO DO USO DE MÓDULOS PADRÃO NO JBOSS 7



INTRODUÇÃO
 
Nos artigos anteriores (http://www.josepojr.com/2013/10/ordem-de-carregamento-de-classes-jars.html e http://www.josepojr.com/2013/01/isolamento-de-classloaders-no-jboss-as-7.html) foi mostrada a configuração do jboss 7 no arquivo jboss-deployment-structure.xml e algumas regras de preferência no carregamento de dependências. Nesse artigo, vamos mostrar como evitar que um módulo padrão que já vem instalado dentro do JBoss 7 (pasta $JBOSS_HOME/modules) seja carregado. E consequentemente, podemos usar os nossos arquivos .jar sem problemas de dependências e lançamentos de exceções do tipo NoSuchMethodException (método não existente). Esse tipo de exceção pode ocorrer se em tempo de projeto (usando uma IDE por exemplo), usamos os jars de uma biblioteca como por exemplo Apache Http Client na versão 4.5, mas no JBoss 7, já temos por exemplo, uma versão dessa mesma biblioteca na versão 4.2, por exemplo. E ao invocar métodos que só existam na versão 4.5, mas na versão 4.2, os mesmos não existe, o erro NoSuchMethodException pode aparecer. Isso porque em tempo de compilação foi usada a versão 4.5, mas em tempo de execução (projeto war ou ear implantado dentro do JBoss 7), a versão 4.2 (dentro da pasta $JBOSS_HOME/modules) pode ser carregada primeiro em detrimento a versão 4.5 (que pode ou não estar na pasta EAR/lib).
Por isso, precisamos configurar o arquivo .ear gerado para que não ocorra esses erros de dependências que será mostrado nesse artigo.


DESENVOLVIMENTO

Como por exemplo, vamos usar a biblioteca Apache Http Client que pode ser baixada do site:
Esses componentes permite qualquer programa acessar servidores web no protocolo HTTP ou HTTPS. Para isso, fornece modelos para a construção de clientes HTTP no seu programa Java. Sem esses componentes, teríamos que escrever do “zero” (projeto desde o início, novo) um cliente HTTP dentro do nosso programa Java. Isso é possível usando as classes java.net.Socket, java.io.InputStream, java.io.OutputStream e outras semelhantes dentro do JRE (Java Runtime, ambiente de execução do Java mais a máquina virtual) fornecido em toda instalação Java em qualquer dispositivo.
Mas, teríamos que perder um tempo enorme para fazer todas essas chamadas, sendo que com o uso desses componentes e com poucas linhas de códigos já temos um cliente HTTP para usarmos no nosso código.
Portanto, como esse projeto é tem uma licença bem semelhante a um software Open Source e é usado em diversos projetos, o JBoss 7 já vem com essa biblioteca da Apache já configurada como módulo dentro do servidor JBoss 7.
Ao mesmo tempo em que isso é bom, pois já temos um módulo dessa biblioteca para usarmos em nosso projeto, ao mesmo tempo também é ruim, pois queremos usar uma versão mais recente da biblioteca em nossos projetos, por exemplo.
Para isso, vamos configurar o arquivo jboss-deployment-structure.xml para não usar o Apache Http Client existente como módulo dentro do JBoss:

<?xml version="1.0" encoding="UTF-8"?>

<jboss-deployment-structure xmlns="urn:jboss:deployment-structure:1.1">
<ear-subdeployments-isolated>true</ear-subdeployments-isolated>
<deployment>
<exclusions>
<module name="org.apache.httpcomponents" slot="main" />
</exclusions>
<dependencies>
<module name="javax.api"/>
<module name="org.jboss.resteasy.resteasy-jaxrs"/>
<module name="org.infinispan"/>
<module name="deployment.MeuProjeto.ear.MeuEJB.jar"/>
<module name="deployment.MeuProjeto.ear.MeuWAR.war"/>
</dependencies>
</deployment>
<!-- durante o deploy. -->
<sub-deployment name="MeuEJB.jar">
<exclusions>
<module name="org.apache.httpcomponents" slot="main" />
</exclusions>
<local-last value="true"/>
</sub-deployment>
<sub-deployment name="MeuWAR.war">
<dependencies>
<module name="deployment.MeuProjeto.ear.MeuEJB.jar"/>
</dependencies>
<local-last value="true"/>
</sub-deployment>
</jboss-deployment-structure>


Só colocar os trechos marcados em VERMELHO no arquivo jboss-deployment-structure.xml do seu projeto. Nesse exemplo, estamos dizendo que o projeto EJB chamado “MeuEJB.jar” precisa usar a biblioteca Apache Http Client própria e não do JBoss 7. E também, estamos excluindo o uso no ear como um todo como mostra o trecho em VERMELHO dentro da tag <deployment>.
Na pasta /lib dentro do projeto EAR (ou conhecida como EAR/lib) devem estar os jars do Apache Http Client obtido no site:


CONCLUSÃO

Mostramos que o uso de configurações dentro do arquivo jboss-deployment-structure.xml permite refinar algumas configurações que terão impacto tanto no tempo de implantação (deploy) ou em tempo de execução, quando a aplicação for chamada pela primeira vez.
Com isso, podemos usar as versões mais recentes das bibliotecas de terceiros sem conflitar com as mesmas bibliotecas de outras versões já instaladas dentro do JBoss 7.


REFERÊNCIAS











quinta-feira, 19 de fevereiro de 2015

Configurando Exceção de Rede (Network) no Ubuntu

INTRODUÇÃO

Quando acessamos o Linux, mas especificamente o Ubuntu 14.04 (rode o comando uname -a para saber a versão do Linux) geralmente estamos numa rede com o servidor Proxy ativado. E geralmente para usarmos, precisamos configurar o Linux com o IP e PORTA do servidor Proxy. Além disso, há casos que o servidor Proxy exige autenticação, isto é, fornecer o USUARIO e SENHA para o servidor Proxy aceitar as requisições.

Nesse artigo, vamos mostrar como configurar o proxy de modo geral no Linux Ubuntu versão 14.04 e como configurar os softwares de gerenciamento de pacotes como o APT-GET e APTITUDE a baixarem os pacotes pelo proxy.



CONFIGURANDO O PROXY PARA O LINUX EM GERAL


1) Abrir arquivo /etc/environment

sudo vim /etc/environment


2) Coloque as seguintes linhas (2 linhas no total) no arquivo /etc/environment:

http_proxy=http://USUARIO:SENHA@IP:PORTA/
https_proxy=https://USUARIO:SENHA@IP:PORTA/



Aonde:

USUARIO: Usuário para fazer o login no servidor proxy
SENHA: Senha para fazer o login no servidor proxy

Observação: Se o servidor proxy não requerer usuário e senha, usar como:

http_proxy=http://IP:PORTA/
https_proxy=https://IP:PORTA/


3) Reiniciar as conexões de rede, execute o seguinte comando:

sudo /etc/init.d/networking restart



CONFIGURANDO O PROXY PARA O APT-GET e APTITUDE

Para configurar o proxy para funcionar nos softwares APT-GET e APTITUDE façam o seguinte:

1) Abrir arquivo /etc/apt/apt.conf

sudo vim /etc/apt/apt.conf



2) Coloque as seguintes linhas (4 linhas no total, para cada ";") no arquivo /etc/apt/apt.conf

Acquire::http::proxy "http://USUARIO:SENHA@IP:PORTA/";
Acquire::https::proxy "https://USUARIO:SENHA@IP:PORTA/";
Acquire::ftp::proxy "ftp://USUARIO:SENHA@IP:PORTA/";
Acquire::socks::proxy "socks://USUARIO:SENHA@IP:PORTA/";



Aonde:

USUARIO: Usuario para fazer o login no servidor proxy
SENHA: Senha para fazer o login no servidor proxy

Observação: Se o servidor proxy não requerer usuário e senha, usar como:

Acquire::http::proxy "http://IP:PORTA/";
Acquire::https::proxy "https://IP:PORTA/";
Acquire::ftp::proxy "ftp://IP:PORTA/";
Acquire::socks::proxy "socks://IP:PORTA/";



TESTES - ACESSO A INTERNET

1) No terminal do Linux, executar o seguinte comando:

wget http://www.josepojr.com

Aonde "http://www.josepojr.com" é URL de teste que pode ser qualquer site. E o comando wget, acessará o site na porta especificada (no caso 80, que é a porta HTTP padrão) fazendo uma requisição HTTP GET dentro do console.


2) Pode-se utilizar o comando ping:

ping www.josepojr.com


3) Ou pode-se utilizar o comando telnet:

telnet www.josepojr.com 80



TESTES - USO DE GERENCIADOR DE PACOTES APT-GET e APTITUDE

1) Execute o seguinte comando para atualizar os pacotes:

sudo apt-get update
sudo aptitude update


2) Atualizar pacotes com APTITUDE (Recomendável):

sudo aptitude safe-upgrade



REFERÊNCIAS:

http://pt.kioskea.net/faq/8815-reiniciar-a-interface-em-linha-de-comando
https://danjared.wordpress.com/2011/03/09/configurar-el-proxy-en-ubuntu/
https://www.gnu.org/software/wget/