Ant: implementación de aplicaciones
En el capítulo anterior, aprendimos cómo empaquetar una aplicación e implementarla en una carpeta.
En este capítulo, implementaremos la aplicación web directamente en la carpeta de implementación del servidor de aplicaciones, luego agregaremos algunos destinos Ant para iniciar y detener los servicios. Sigamos con elHello Worldaplicación web de fax. Esta es una continuación del capítulo anterior, los nuevos componentes se destacan enbold.
build.properties
# Ant properties for building the springapp
appserver.home = c:\\install\\apache-tomcat-7.0.19
# for Tomcat 5 use $appserver.home}/server/lib
# for Tomcat 6 use $appserver.home}/lib
appserver.lib = ${appserver.home}/lib
deploy.path = ${appserver.home}/webapps
tomcat.manager.url = http://www.tutorialspoint.com:8080/manager
tomcat.manager.username = tutorialspoint
tomcat.manager.password = secret
build.xml
<?xml version = "1.0"?>
<project name = "fax" basedir = "." default = "usage">
<property file = "build.properties"/>
<property name = "src.dir" value = "src"/>
<property name = "web.dir" value = "war"/>
<property name = "javadoc.dir" value = "doc"/>
<property name = "build.dir" value = "${web.dir}/WEB-INF/classes"/>
<property name = "name" value = "fax"/>
<path id = "master-classpath">
<fileset dir = "${web.dir}/WEB-INF/lib">
<include name = "*.jar"/>
</fileset>
<pathelement path = "${build.dir}"/>
</path>
<target name = "javadoc">
<javadoc packagenames = "faxapp.*" sourcepath = "${src.dir}"
destdir = "doc" version = "true" windowtitle = "Fax Application">
<doctitle><![CDATA[<h1> = Fax Application = </h1>]]></doctitle>
<bottom><![CDATA[Copyright © 2011. All Rights Reserved.]]></bottom>
<group title = "util packages" packages = "faxapp.util.*"/>
<group title = "web packages" packages = "faxapp.web.*"/>
<group title = "data packages" packages = "faxapp.entity.*:faxapp.dao.*"/>
</javadoc>
</target>
<target name = "usage">
<echo message = ""/>
<echo message = "${name} build file"/>
<echo message = "-----------------------------------"/>
<echo message = ""/>
<echo message = "Available targets are:"/>
<echo message = ""/>
<echo message = "deploy --> Deploy application as directory"/>
<echo message = "deploywar --> Deploy application as a WAR file"/>
<echo message = ""/>
</target>
<target name = "build" description = "Compile main source tree java files">
<mkdir dir = "${build.dir}"/>
<javac destdir = "${build.dir}" source = "1.5" target = "1.5" debug = "true"
deprecation = "false" optimize = "false" failonerror = "true">
<src path = "${src.dir}"/>
<classpath refid = "master-classpath"/>
</javac>
</target>
<target name = "deploy" depends = "build" description = "Deploy application">
<copy todir = "${deploy.path}/${name}"
preservelastmodified = "true">
<fileset dir = "${web.dir}">
<include name = "**/*.*"/>
</fileset>
</copy>
</target>
<target name = "deploywar" depends = "build" description =
"Deploy application as a WAR file">
<war destfile = "${name}.war" webxml = "${web.dir}/WEB-INF/web.xml">
<fileset dir = "${web.dir}">
<include name = "**/*.*"/>
</fileset>
</war>
<copy todir = "${deploy.path}" preservelastmodified = "true">
<fileset dir = ".">
<include name = "*.war"/>
</fileset>
</copy>
</target>
<target name = "clean" description = "Clean output directories">
<delete>
<fileset dir = "${build.dir}">
<include name = "**/*.class"/>
</fileset>
</delete>
</target>
<!-- ============================================================ -->
<!-- Tomcat tasks -->
<!-- ============================================================ -->
<path id = "catalina-ant-classpath">
<!-- We need the Catalina jars for Tomcat -->
<!-- * for other app servers - check the docs -->
<fileset dir = "${appserver.lib}">
<include name = "catalina-ant.jar"/>
</fileset>
</path>
<taskdef name = "install" classname = "org.apache.catalina.ant.InstallTask">
<classpath refid = "catalina-ant-classpath"/>
</taskdef>
<taskdef name = "reload" classname = "org.apache.catalina.ant.ReloadTask">
<classpath refid = "catalina-ant-classpath"/>
</taskdef>
<taskdef name = "list" classname = "org.apache.catalina.ant.ListTask">
<classpath refid = "catalina-ant-classpath"/>
</taskdef>
<taskdef name = "start" classname = "org.apache.catalina.ant.StartTask">
<classpath refid = "catalina-ant-classpath"/>
</taskdef>
<taskdef name = "stop" classname = "org.apache.catalina.ant.StopTask">
<classpath refid = "catalina-ant-classpath"/>
</taskdef>
<target name = "reload" description = "Reload application in Tomcat">
<reload url = "${tomcat.manager.url}"username = "${tomcat.manager.username}"
password = "${tomcat.manager.password}" path = "/${name}"/>
</target>
</project>
En este ejemplo, hemos utilizado Tomcat como nuestro servidor de aplicaciones. Primero, en el archivo de propiedades de construcción, hemos definido algunas propiedades adicionales.
los appserver.home apunta a la ruta de instalación del servidor de aplicaciones Tomcat.
los appserver.lib apunta a los archivos de la biblioteca en la carpeta de instalación de Tomcat.
los deploy.path La variable ahora apunta a la carpeta de la aplicación web en Tomcat.
Las aplicaciones en Tomcat se pueden detener e iniciar mediante la aplicación de administrador de Tomcat. La URL de la aplicación de administrador, el nombre de usuario y la contraseña también se especifican en el archivo build.properties. A continuación, declaramos un nuevo CLASSPATH que contiene elcatalina-ant.jar. Este archivo jar es necesario para ejecutar tareas de Tomcat a través de Apache Ant.
Catalina-ant.jar proporciona las siguientes tareas:
No Señor. | Propiedades y descripción |
---|---|
1 | InstallTask Instala una aplicación web. Nombre de clase: org.apache.catalina.ant.InstallTask |
2 | ReloadTask Vuelva a cargar una aplicación web. Nombre de clase: org.apache.catalina.ant.ReloadTask |
3 | ListTask Muestra todas las aplicaciones web. Nombre de clase: org.apache.catalina.ant.ListTask |
4 | StartTask Inicia una aplicación web. Nombre de clase: org.apache.catalina.ant.StartTask |
5 | StopTask Detiene una aplicación web. Nombre de clase: org.apache.catalina.ant.StopTask |
6 | ReloadTask Recarga una aplicación web sin detenerse. Nombre de clase: org.apache.catalina.ant.ReloadTask |
La tarea de recarga requiere los siguientes parámetros adicionales:
- URL de la aplicación de administrador
- Nombre de usuario para reiniciar la aplicación web
- Contraseña para reiniciar la aplicación web
- Nombre de la aplicación web que se reiniciará
Emitamos el deploy-warcomando para copiar la aplicación web a la carpeta de aplicaciones web de Tomcat y luego volver a cargar la aplicación web de fax. El siguiente resultado es el resultado de ejecutar el archivo Ant:
C:\>ant deploy-war
Buildfile: C:\build.xml
BUILD SUCCESSFUL
Total time: 6.3 seconds
C:\>ant reload
Buildfile: C:\build.xml
BUILD SUCCESSFUL
Total time: 3.1 seconds
Una vez que se ejecuta la tarea anterior, se implementa la aplicación web y se vuelve a cargar la aplicación web.