Archivo de la etiqueta: glassfish

Glassfish en Ubuntu

Glassfish está incluido como paquete en los repositorios de Ubuntu 8.10, lo que facilita mucho las cosas a la hora de instalarlo, pero parece que alguien pensó que no era una buena idea incluir un script en /etc/init.d/ para que el servidor de aplicaciones se lance durante el arranque.
Esto puede servir para desarrolladores, pero aquellos que necesiten montar un servidor para desplegar sus aplicaciones tendrán que trabajar un poco más. En este post describo el procedimiento que seguí para aquellos que estén en esta situación, si alguien sabe como mejorar el procedimiento será un placer actualizarlo.

1. Instalación de los paquetes necesarios.

Esta es la parte sencilla, ya que APT hace todo por nosotros.

#apt-get install glassfishv2

Cuando finaliza el script tendremos instalado glassfish en /usr/share/glassfishv2 y nuestros dominios en /var/lib/glassfishv2/domains

2. Creando el usuario glassfish

Por motivos de seguridad, no parece buena idea lanzar nuestro servidor con permisos de superusuario en el inicio, por lo que antes de configurar el script de arranque creamos un usuario sin privilegios destinado al efecto.

#sudo adduser glassfish --ingroup admin

El nuevo usuario pertenece al grupo admin, por lo que asignamos a ese grupo la propiedad del directorio de glassfish

#sudo chgrp -R admin /usr/share/glassfishv2

Y asignamos la propiedad de la raíz de los dominios al usuario glassfish

#sudo chgrp -R admin  /var/lib/glassfishv2/domains/
#sudo chown -R glassfish /var/lib/glassfishv2/domains/

3. Creando un script para /etc/init.d

Una vez todo está preparado podemos proceder a escribir un script de control para glassfish, que en mi caso he llamado /etc/init.d/glassfish y es el siguiente:

#! /bin/sh

GLASSFISHPATH=/usr/share/glassfishv2/bin
GLASSFISHDOMAINHOME=/var/lib/glassfishv2/domains/domain1

 

case "$1" in
start)
echo "starting glassfish from $GLASSFISHPATH"
sudo -u glassfish $GLASSFISHPATH/asadmin start-domain --user admin --passwordfile ${GLASSFISHDOMAINHOME}/config/passwordfile domain1
;;
restart)
$0 stop
$0 start
;;
stop)
echo "stopping glassfish from $GLASSFISHPATH"
sudo -u glassfish $GLASSFISHPATH/asadmin stop-domain domain1
;;
*)
echo $"usage: $0 {start|stop|restart}"
exit 3
;;
esac

No olvidemos dar permisos de ejecución al script:

#sudo chmod a+x /etc/init.d/glassfish

Por defecto glassfish solicita un nombre de usuario y password durante el arranque que en el momento de la instalación es:

user: admin
password: adminadmin

Para que esta información se le pase al script automáticamente tendremos que crear si no existe el fichero  /var/lib/glassfishv2/domains/domain1/config/passwordfile  donde escribiremos la siguiente línea:

AS_ADMIN_PASSWORD=adminadmin

4. Retoques finales

Teniendo ya el script preparado sólo falta enlazarlo para que se llame durante el encendido y apagado del equipo, lo cual hacemos mediante el siguiente comando:

#sudo update-rc.d glassfish defaults 90 10

Con lo cual todo está listo para empezar a desplegar aplicaciones a falta de conectar con bases de datos y demás, pero eso ya es algo mejor documentado de lo que por ahora no voy a hablar.

Puedes probar que todo funciona correctamente ejecutando las siguientes órdenes y conectando a http://localhost:8080 para visualizar la página de bienvenida a glassfish.

#sudo service glassfish start
#sudo service glassfish restart
#sudo service glassfish stop

Referencias

Para realizar esta configuración tomé prestadas algunas ideas de un artículo del blog de Jasper Kalkers en inglés, os recomiendo una ojeada si no usais APT o para adaptar este método a otros sistemas operativos.

Anuncios