sábado, 20 de julio de 2013

Redirigir un dominio propio a tu aplicación en OpenShift

OpenShift de Red Hat nos permite configurar un servidor web en el que podemos instalar nuestras propias aplicaciones. Cuando creas tu cuenta en OpenShift has de indicar el nombre del namespace que van a utilizar tus aplicaciones, con lo que la URL para acceder a ellas tendrá el formato nombreaplicacion-nombrenamespace.rhcloud.com. Esta URL puede estar bien para hacer pruebas o algo poco serio, pero si quieres, puedes asociar un dominio que ya tengas adquirido para que te redirija a tu servidor OpenShift.

Veamos un ejemplo práctico de como he configurado OpenShift para alojar la web, blog y foro de Ikaro Games y usar el dominio ikarogames.com que ya tenía registrado.

El blog y el foro de Ikaro Games son una instalación de Serendipity y phpBB respectivamente, por lo que vamos a necesitar crear un servidor PHP, con los cartridges de MySQL y phpMyAdmin dentro de OpenShift. La creación del servidor es un proceso muy simple, pero recomiendo que cada vez que hacemos un paso nos apuntemos los parametros de configuración y comandos que nos indican en pantalla, por si en algún momento nos hacen falta. De todas formas accediendo mediante SSH al servidor y ejecutando el comando env podremos ver muchos de estos parámetros de configuración y otros que nos pueden ser útiles a la hora de configurar nuestras aplicaciones.

Una vez tengamos la web funcionando sobre OpenShit, por ejemplo, la de Ikaro Games está en http://web-ikarogames.rhcloud.com/, podremos configurar la redirección de nuestro dominio a dicha URL. Para que todo esto funcione son necesarios 3 elementos:


  1. El servidor web donde está alojada la aplicación. En este caso el servidor OpenShift que acabamos de crear.
  2. El dominio que hayamos adquirido, en este caso ikarogames.com.
  3. Un servidor de DNS que nos redirija nuestro dominio a la dirección de nuestro servidor web.
Los puntos 2 y 3 dependen un poco de si el proveedor donde has comprado el dominio te ofrece también el servidor DNS o no. En mi caso no lo ofrecía gratuitamente, por lo que he utilizado para el tercer punto CloudFlare, que por el momento tiene un servicio gratuito de redirección DNS.

Añadimos nuestro dominio a la cuenta de CloudFlare y configuramos la redirección DNS de la siguiente manera:


Al realizar esta configuración en CloudFlare, nos indicará las direcciones de los DNS primario y secundario que tendremos que utilizar para configurar nuestro dominio. En mi caso han sido iris.ns.cloudflare.com y walt.ns.cloudflare.com. Vamos ahora a la web de nuestro proveedor del dominio, y en la configuración del dominio debe haber una sección donde nos permita indicar dichas direcciones DNS.

Una vez tengamos configurado el servidor de DNS y el dominio en la web de nuestro proveedor, nos vamos a la configuración de nuestro servidor en OpenShift y pulsamos sobre la opción Add Alias, indicamos el campo Domain name el nombre de nuestro la URL con la que queramos acceder al servidor, en este caso www.ikarogames.com.

Con esto ya tendremos todo listo para que al acceder a www.ikarogames.com se nos redireccione al servidor OpenShift. El proceso de actualizar las DNS puede tardar hasta 48 horas según nos indican en CloudFlare, pero a mi me tardó apenas un par de horas.

jueves, 18 de julio de 2013

Desplegar una aplicación Java en OpenShift

OpenShift
OpenShift es un servicio de Red Hat que nos ofrece una plataforma de fácil configuración en la nube, lo que se viene a llamar Platform as a Service o PaaS, en la que podremos desplegar nuestras aplicaciones o páginas web, blogs, servidores de pruebas, etc. Entre las opciones disponibles podemos montar servidores JBoss, Tomcat, PHP, Node.js, Ruby, usar bases de datos MySQL, MongoDB, o directamente configurar un blog Wordpress sin ningún esfuerzo.

Una vez registrados, nos ofrece la posibilidad de utilizar hasta 3 Gears gratuitamente. Con estos 3 Gears podremos montar hasta 3 pequeños servidores para poco tráfico, o usar los Gears en un sólo servidor para darle más capacidad de carga de trabajo. Si necesitamos montar servidores que requieran más carga de trabajo, podemos pagar por Gears adicionales.

La interfaz web nos permitirá crear, configurar y eliminar fácilmente los servidores con pocos clicks de ratón así como acceder a la documentación oficial de OpenShift. A parte de la interfaz web, tenemos una aplicación de línea de comandos llamada rhc con la que poder estas y otras operaciones.

Esta es una pequeña chuleta con las operaciones más útiles. Para utilizar los comandos abajo indicados tenemos que tener instaladas previamente las herramientas git y rhc en nuestro sistema.

  1. Creamos una aplicación Java con Tomcat 7:
    rhc app create -a nombreaplicacion -t jbossews-2.0
  2. Borramos el contenido por defecto de la aplicación:
    cd nombreaplicacion 
    git rm -rf src/ pom.xml 
    git commit -am 'removing default files'
  3. Añadimos el fichero WAR al directorio webapps y ejecutamos los siguientes comandos:
    git add . 
    git commit -am 'commit nombreaplicacion.war' 
    git push


Para reiniciar una aplicación tenemos varias opciones:
  1. Desde la interfaz web, vamos a la sección My Applications, seleccionamos la aplicación, y arriba a la derecha hay una opción que nos permite reiniciar la aplicación.
  2. Reiniciar la aplicación desde la consola de comandos:
    rhc app restart -a $your_app
  3. Si lo anterior no funciona, parar y arrancar la aplicación con:
    rhc app stop -a $your_app
    rhc app start -a $your_app
  4. Si la aplicación se ha quedado sin memoria y no funciona todo lo anterior, probar con:
    rhc app force-stop -a $your_app 

jueves, 21 de febrero de 2013

Entorno de desarrollo para JSF 2

Vamos a describir un posible conjunto herramientas de desarrollo para la creación de un proyecto web Java. Este artículo es simplemente una guía de ejemplo y estas no son las únicas ni mejores herramientas, simplemente utilizaremos esta base para los siguientes artículos sobre JSF (Java Server Faces).

Como entorno de desarrollo vamos a utilizar Eclipse con sus plugins para Maven, Git, y TestNG. Como servidor web vamos a utilizar Apache Tomcat y por supuesto el JDK de Java.

Seguiremos los siguientes pasos:

  1. Asegurarnos de tener instalada la última versión de Java en el equipo, este paso depende de en qué sistema operativo estemos, pero suele reducirse a descargar e instalar Java desde la web oficial si estamos en Windows o instalarlo mediante el sistema de paquetes de nuestra distibución Linux.
  2. Descargar el último JDK de Java de la página oficial de Oracle para nuestro sistema operativo. Una vez descargado lo descomprimimos en algún directorio a nuestra elección. Por ejemplo, voy a descargar de dicha página el fichero jdk-7u25-linux-x64.tar.gz y descomprimirlo en mi directorio ~/Programas/Java/jdk1.7.0_25/, puesto que estoy en una máquina Linux de 64 bits.
  3. Descargar la última versión de Eclipse para nuestro sistema y descomprimirlo en un dirección a nuestra elección. Voy a descargar eclipse-jee-kepler-R-linux-gtk-x86_64.tar.gz y descomprimirlo en ~/Pogramas/eclipse_kepler_web/.
  4. Descargar la última versión de Apache Maven y Apache Tomcat y descomprimirlos en un directorio a nuestra elección. Descargaré los ficheros apache-maven-3.0.5-bin.tar.gz y apache-tomcat-7.0.41.tar.gz respectivamente, y los descomprimiré en ~/Programas/Apache/apache-maven-3.0.5/ y en ~/Programas/Apache/apache-tomcat-7.0.41/.
Personalmente prefiero descargar las aplicaciones de sus páginas oficiales y tener un directorio de instalación para cada una de ellas, así podemos tener en un momento dado distintas versiones de una determinada herramienta. Por ejemplo un Eclipse para desarrollo web en Java y otro para desarrollo de aplicaciones en C++.

Ahora abriremos Eclipse, le instalaremos los plugins necesarios y lo configuraremos para empezar a trabajar:
  • Abrimos el directorio de Eclipse que creamos anteriormente y lanzamos el ejecutable que encontraremos allí. Aparecerá una pantalla donde nos pedirá que seleccionemos el workspace. Aquí dejamos la opción por defecto o indicamos un directorio a nuestro gusto, yo prefiero tener workspaces separados según los tipos de proyectos que tengo.
  • Los plugins EGit, Maven Integration for Eclipse WTP (m2e-wtp) están ya integrados en Eclipse a partir de Eclipse Kepler, por lo que no es necesario instalarlos si hemos descargado Eclipse en su edición JEE. Vamos a Help->Eclipse Marketplace e instalamos el plugin TestNG for Eclipse. Estos son los plugins para trabajar desde Eclipse con el sistema de control de versiones Git, Apache Maven, y TestNG respectivamente. Al instalar cada plugin aceptamos las opciones por defecto y nos pedirá que reiniciemos Eclipse.
 Ahora vamos a configurar el workspace para trabajar, esto se hace desde la opción Window->Preferences:
  • Lo primero de todo configuramos la codificación de caracteres para nuestro workspace para ponerla en UTF-8 en General->Workspace, dentro de Text file encoding seleccionamos Other y UTF-8 en el desplegable. Esto es importante para que no haya problemas para que los proyectos funcionen desde distintos sistemas operativos.

  • Vamos a Java->Installed JREs y añadimos como instalación por defecto el directorio del JDK que nos habíamos descargado previamente.
  • Entramos en Maven->Installations y añadimos como instalación por defecto el directorio en el que habíamos descromprimido Apache Maven previamente.
  •  Vamos ahora a Server->Runtime Enviromment y añadimos el servidor Apache Tomcat que habíamos descargado antes.
  • Por último, vamos a la opción TestNG y en la casilla Output Directory escribimos /target/test-output.


Con esto ya tendríamos nuestro entorno de desarrollo Eclipse completamente configurado para comenzar a trabajar en nuestros proyectos.


La configuración del plugin EGit la dejaremos para cuando veamos como trabajar con el sistema de control de versiones Git.

Actualización: Actualizo el artículo para usar Eclipse Kepler edición JEE, que ya trae integrados varios de los plugins que antes había que instalar manualmente.