Buscar
Social
Ofertas laborales ES
« Encuesta sobre plataformas tecnológicas | Main | Groovy 2.0 »
viernes
jun292012

Sistemas de build en Java: Maven a la cabeza seguido de lejos de Ant

Ya tenemos los resultados de la encuesta sobre sistemas de build en Java: el 60% de los encuestados emplea principalmente Maven, mientras que sólo el 31% emplea principalmente Ant. Gradle (que recientemente ha llegado a su versión 1.0, lo que fue el desencadenante de esta encuesta) es usado por el 4%. Podría parecer una cifra baja, pero no está mal para acabar de anunciar su primera versión estable.

Cuando preguntamos por qué sistemas de build  empleaban, independientemente de si era el que se usaba principalmente o no, Ant es usado en un 62% de los casos, aunque Maven sigue por delante (78%) y Gradle en un 9%. Aquí tenéis una gráfica resumiendo los resultados:

¿Qué sistema de build empleas principalmente?
Ant   97 31%
Maven   184 60%
Gradle   13 4%
Uno propio   2 1%
Ivy   1 0%
Otro   5 2%
¿Qué sistemas de build empleas?
Ant   188 62%
Maven   237 78%
Gradle   26 9%
Uno propio   13 4%
Ivy   6 2%
Otro   15 5%

PrintView Printer Friendly Version

EmailEmail Article to Friend

Reader Comments (17)

Yo creo que sale mucho porcentaje en el maven porque los que no usan maven usan "la compilación que viene con el IDE".

junio 29, 2012 | Unregistered CommenterJuan

imagino que los valores que están a la derecha de cada gráfico es absoluto y no en porcentaje....
saludos

junio 29, 2012 | Unregistered Commenterdiego

lo quiero por que me ahorra tiempo creando mis proyectos lo odio por que igual nunca ponen en la documentacion cual o cuales(en el peor de los casos) son los comandos para construir

junio 30, 2012 | Unregistered Commenterluis

Lo que me sorprende es el bajo uso de Ivy,
¿como hacen la gestión de dependencias los que usan Ant en vez de Maven?

junio 30, 2012 | Registered Commenterlogongas

@logongas

Basta con usar un buen IDE.

junio 30, 2012 | Registered Commenterchoces

logongas, lo que pasa es que Ivy no debería estar ahí por que Ivy no es un sistema de "build", es sólo la parte de gestión de dependencias y por tanto, si usas Ivy estás usando, normalmente, Ant.

Y usar un buen IDE no tiene que ver con usar Ivy o no, choces, los IDE no hacen gestión de dependencias, como no sea a través de plugins de Maven/Ivy. Son complementarios.

junio 30, 2012 | Unregistered CommenterKomorr

@junio
Uso netbeans, pero no me parece que me ayude mucho.
Desde NetBeans simplemente le digo la carpeta donde tengo mis librerías, pero éstas no se actualizan si cambia la versión (lo cual en mis proyectos es lo que me interesa).

junio 30, 2012 | Registered Commenterlogongas

¿Conoces este procedimiento?

http://wiki.netbeans.org/MigrateClassLibraries

junio 30, 2012 | Registered Commenterchoces

@Komorr

Me estoy preguntando cómo he conseguido, a lo largo de varios años, realizar los builds de múltiples proyectos interdependientes entre sí, junto con las dependencias de librerías externas.

Desde hace un par de años, sigo preguntándome cómo consigo hacer los builds de proyectos de NetBeans Platform, que dependen de diversas suites, junto con dependencias externas igualmente.

Todo ello sin añadir al IDE absolutamente ningún plugin al respecto.

julio 1, 2012 | Registered Commenterchoces

Perdonadme un poco de mala leche ¿es TAN IMPORTANTE que en CADA EJECUCIÓN se evalúen las dependencias?

Pongo un ejemplo buscando el absurdo: considerad que ejecutáis un programa ¿consideráis de sentido común que el sistema operativo antes de ejecutar un programa se conectara al servidor de actualizaciones y si encontrara actualizaciones se las bajara y las instalara y luego ejecutara tu programa que con gran probabilidad no necesita dichas actualizaciones?

Quiero decir que me parece muy bien lo de la gestión automática de dependencias pero la instalación/configuración de las dependencias en un proyecto es algo que implica el 0.001% de la duración de un proyecto por lo que entre la gestión manual y automática la diferencia es prácticamente nula, por no hablar de la resolución de conflictos y si una herramienta me hace comulgar con ruedas de molino como es el caso de Maven por una mejora en comodidad del 0.001% del trabajo de un proyecto...

Que sí, que Maven se ocupa además de todas las fases del build de un proyecto... pero de la forma más brutalmente rígida e intrusiva (hasta te fuerza el layout del proyecto) que he conocido.

julio 1, 2012 | Registered Commenterjmarranz

Debe de ser una "rara casualidad" que solamente un 10% de los usuarios de NetBeans usen Maven ;)

http://statistics.netbeans.org/analytics/graph/projecttypes.jsp

julio 1, 2012 | Registered Commenterchoces

@choces
Eso es útil si cambias la versión de NetBeans, yo me refería a la versión de la librería.

@jmarranz
En mi caso si. El proyecto se divide en dos partes, una serie de librerías y la propia aplicación web y son desarrolladores distintos y se están desarrollando el paralelo. Desde la aplicación Web necesitamos ver cuanto antes los cambios que se producen en las librerías. Así que en cada ejecución si obtengo la nueva versión de todas las librerías en una ventaja.

julio 2, 2012 | Registered Commenterlogongas

@logongas

Puesto que en NetBeans se puede declarar cualquier proyecto como dependiente de otro, al igual que se hace con las librerías externas, sigo sin ver dónde está el problema.

A menos que se quieran usar versiones diferentes de la misma librería simultáneamente, lo que implica un tipo de problemas que intenta resolver el diseño modular (hasta cierto punto).

Por supuesto, si se usan diferentes IDE para desarrollar el mismo proyecto, es necesario recurrir a Maven, u otro sistema similar de build.

julio 2, 2012 | Registered Commenterchoces

@choces
Inicialmente era el planteamiento que usaba:Tener dependencias entre proyectos en Netbeans pero:
Me obliga a bajarme un código fuente que no necesito ya que solo quiero los binarios.
Los otros proyectos siempre deben estar en las mismas carpetas (aunque sea de forma relativa) unos respecto a otros para que puedan verse al bajarlos desde cualquier ordenador.
Al montarlo todo en un entorno de integración continua también debes incluir los otros proyectos al compilar el que yo uso.
Y como tu ya has dicho obliga a que todos programen en NetBeans.

Así que me monté un Artifactory donde se publican los binarios y con Ivy me puedo bajar la última versión cuando quiera.

julio 2, 2012 | Registered Commenterlogongas

@choces Si dejaras la ironía y la soberbia y leyeras lo que he puesto, quizá entenderías lo que quiero decir. Si lo que hace los IDEs lo quieres entender por "gestión de dependencias" como lo que hace Ivy/Maven, pues perfecto.

Discutir a ese nivel se lo dejo a los de tele5

julio 2, 2012 | Unregistered CommenterKomorr

@jmarranz En mi caso (Ant/Ivy), lo que hago es simplemente comprobar si el fichero que declara las dependencias ha cambiado, y en ese caso no re-compruebo las dependencias. Con un target para re-comprobar a voluntad, en caso de dependencias "dinámicas" donde te bajas el último snapshot, ya tienes cubierto lo necesario y sólo descargas lo que hace falta.

julio 2, 2012 | Unregistered CommenterKomorr

@jmarranz: Pues claro que es importante, no estás ejecutando un bloc de notas, estás ejecutando la fase de construcción de una aplicación que depende de multitud de librerias de terceros con sus propias dependencias transitivas, algunas pueden ser incluso versiones vivas de librerias o componentes propios.

Y además no veo el inconveniente. La primera vez tardará un rato (sobre todo si no tienes un repositorio a nivel de tu organización) pero las siguientes veces si no hay cambios el retardo es mínimo.

Por otro lado, el "layout" tb es configurable. Aunque a mi me parece genial que poco a poco se imponga un estándar, aunque sea defacto, y que viene de la mano de gente que se ha enfrentado a muchos más proyectos que yo.

julio 3, 2012 | Unregistered Commenterestadisticas

PostPost a New Comment

Enter your information below to add a new comment.

My response is on my own website »
Author Email (optional):
Author URL (optional):
Post:
 
Some HTML allowed: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <code> <em> <i> <strike> <strong>