22 November, 2007

Liberado ‘NetBeans IDE 6.0 RC2′

Logo NetbeansHoy nos hemos levantado con la RC2 de Netbeans 6 que parece será la última hasta su liberación definitiva el 3 de Diciembre.

Esta nueva versión trae consigo novedades y mejoras muy significativas, entre las más importantes: soporte para ruby, magnífica integración con subversion, importantes mejoras en el editor, soporte javascript / css / xhtml (coloreado de sintaxis, autocompletado de código, rename refactoring, etc), modelado UML, integración con profiler, soporte jpa y muchas mas que podeis consultar con detalle en http://wiki.netbeans.org/wiki/view/NewAndNoteWorthy.

Descarga desde http://download.netbeans.org/netbeans/6.0/rc2/

20 November, 2007

¿Que es Jasper Reports?

Logo Jasper ReportsJasperReports es una herramienta gratuita y opensource que se compone de un conjunto de librerias java para facilitar la generación de informes en nuestras aplicaciones tanto web como de escritorio.
Los informes se definen en un fichero xml el cual será compilado por las librerías jasper report y generarán un fichero .jasper que utilizaremos para rellenar y mostrar el informe final. La salida de los informes puede ser a la impresora, pdf, cvs, xml, txt, html, xls, rtf, jasper viewer, y a medida que liberen versiones seguramente alguna mas. La definición de los informes se puede realizar directamente sobre los xml descriptores o podemos utilizar la herramienta ireport para diseñarlo gráficamente.

Uno de los puntos fuertes de jasper report es su comunidad http://www.jasperforge.org y la compañía que está detrás, JasperSoft nacida del éxito alcanzado por las primeras versiones de jasperreport y centrada en el desarrollo de herramientas Business Intelligence.

Personalmente he de comentar que me ha gustado mucho ireport, funciona a la perfección en mi ubuntu, nos proporciona todo lo necesario para diseñar informes de una complejidad media, y la curva de aprendizaje para comenzar a tener resultados productivos no es muy elevada. Claro que cuando necesitamos diseñar informes mas complejos en los que intervienen gran cantidad de tablas y relaciones de nuestra BD, ireport se vuelve farragoso, comienzas a tener que crear multitud de subinformes o enviar mas parámetros de los deseados para obtener los datos necesarios. Ya os contaré mis próximas experiencias en este entorno, todavía me queda pendiente echarle un vistazo a jasper server, jasperETL y DynamicJasper, si encuentro el momento dejaré por aquí mis impresiones.

Wiki JasperReports
Requirimientos JasperReports

18 November, 2007

Google&Company = OpenHandSetAlliance => Android


A nadie se le escapaba ya que google se estaba preparando para entrar en el mundo móvil, algunos mas fantasiosos y a pesar de los desmentidos de la compañía seguían creyendo en que presentaría un teléfono similar al iphone de apple, otros de forma mas acertada creían a google e insistían en que su negocio era software no hardware que su modelo de negocio se basaba únicamente en la publicidad.
Pues bien el pasado día 11, un grupo de mas de 30 empresas liderados por google, la openhandsetalliance (alianza de terminal abierto), presentaban android, una plataforma abierta para terminales móviles en la que se incluye un sistema operativo basado en el kernel de linux 2.6, un conjunto de aplicaciones (contactos, sms, email, calendario, navegador(basado en webkit), etc…) y un framework escrito en java para desarrollar aplicaciones.

Android esta llamado a marcar época por muchos motivos; poner de acuerdo tantas y tan importantes empresas en este negocio es un hecho sin precedentes; el apoyo de google que hasta la fecha ha convertido en oro todo lo que ha tocado, con la segura portabilidad de todos sus servicios web de los que se intuye que google maps formará una parte estratégica; la decisión de liberar la plataforma bajo licencia apache(ASL) hace posible su uso de formas y bajo modelos de negocio muy diferentes.

Desde google ya han comenzado a soltar la pasta para comenzar a formar comunidad y desde su blog bajo el título de Calling all developers: $10M Android challeng anuncian un concurso para desarrolladores, premian con 10 millones de dólares al mejor proyecto software para la plataforma, nada mal.

Fuera de la openhandsetalliance se quedan por el momento compañías importantes como Nokia, Sony Ericsson, Blackberry o Microsoft, con posturas muy diferentes, mientras que Nokia ya ha anunciado su disposición a desarrollar terminales compatibles con android, Microsoft sigue apostando por su windows mobile y saca a relucir su ventaja (40 millones de telefonos, acuerdos con 166 operadoras, 55 fabricantes de dispositivos, 18.000 aplicaciones, etc). Solo el tiempo nos dirá en que posición quedará cada uno, desde luego se avecina una dura batalla, iphone;windows mobile;openmoko;simbian;Palm OS;Blackberry…

Unas capturas de pantalla:

Y un par de enlaces a la presentación de android, y a un primer vistazo sobre como contruir una aplicación para android:
http://www.youtube.com/watch?v=1FJHYqE0RDg
http://www.youtube.com/watch?v=I6ObTqIiYfE

14 November, 2007

Captura de pantalla desde java, la clase Robot.java

Buscando la forma de realizar una captura de pantalla desde java me he encontrado con la clase Robot.java, con ella podemos simular eventos del usuario (movimiento de ratón y control de teclado) y realizar una captura de pantalla claro :-), sun nos lo deja bien claro:

"This class is used to generate native system input events for the purposes of test automation, self-running demos, and other applications where control of the mouse and keyboard is needed. The primary purpose of Robot is to facilitate automated testing of Java platform implementations."

Enviar captura de pantalla a un BufferedImage:

  1. BufferedImage bImage = null;
  2. Robot robot = null;
  3. try
  4. {
  5.    robot =new Robot();
  6.    robot.delay(0); //sleep
  7.    bImage = robot.createScreenCapture(new Rectangle(Toolkit.getDefaultToolkit().getScreenSize()));
  8. }
  9. catch(AWTException e1)
  10. {
  11.    System.out.println( e1.getMessage());
  12. }

13 November, 2007

Conceptos básicos de estadística

Después de un largo y duro fin de semana he decidido dejar por escrito algunos conceptos básicos sobre estadística (una de las asignaturas que he escogido para este semestre).

Población: Conjunto de individuos que queremos estudiar.

Muestra: Subconjunto cualquiera de la población.

Variable: Característica de los individuos objeto de nuestro estudio, las variables cualitativas/categóricas no se expresan numéricamente mientras que las cuantitativas si. Entre estas últimas diferenciamos cuantitativas discretas que solo toman valores enteros y cuantitativas continuas que toman cualquier valor en un intervalo.

Frecuencia absoluta ni de cada valor de la variable: Número de individuos para los que la variable toma ese valor.

Frecuencia relativa fi de cada valor de la variable: proporción de individuos en los que la variable toma ese valor.

Distribución de frecuencias de una variable: Es el conjunto de los valores que adopta una variable y la frecuencia con que los adopta.

Medidas de centro

Moda: Es el valor mas repetido, el que tiene una mayor frecuencia.

Mediana: Es el valor que ocupa el lugar central una vez ordenadas las observaciones de menor a mayor.

Media: Es el valor medio de todas las observaciones de la variable, se obtiene dividiendo la suma de todas las observaciones por el numero de individuos.

Medidas de dispersión

Primer cuartil(Q1): Valor numérico tal que al menos el 25% de las observaciones son menores o iguales que el.

Segundo cuartil(Q2): Es la mediana.

Tercer cuartil(Q3): Valor numérico tal que al menos el 75% de las observaciones son menores o iguales que el.

Rango intercuartílico: Es la diferencia entre el primer y el tercer cuartil Q3-Q2.

Varianza σ: Suma al cuadrado de las desviaciones respecto a la media divido por el número de observaciones N.

Desviación típica/estándar: Raíz cuadrada positiva de la varianza.

Probabilidad

Experimento aleatorio: Aquel que tiene diferentes resultados posibles y no tenemos certeza de cual se producirá realmente.

Espacio muestral Ω: Conjunto de resultados posible que podemos obtener al realizar un experimento aleatorio.

Acontecimiento / Suceso aleatorio: Subconjunto del espacio muestral.

Suceso seguro: Es el que está formado por todos los resultados posibles. Es el mismo que el espacio muestral Ω.

Suceso imposible Ø: Es el suceso que no ocurre nunca, denotado por el conjunto vacío Ø.

Sucesos incompatibles: Son dos sucesos que no tienen ningún resultado en común.

Sucesos independientes: Dos sucesos A y B son independientes cuando el hecho de que ocurra uno no altera la probabilidad de que ocurra el otro.

12 November, 2007

Aportación española a OpenMoko

Neo1973
Vía barrapunto me entero de que ya tenemos españolitos colaborando con openmoko. Los sujetos en cuestión, kernel-labs, disponen en su web de información técnica muy interesante sobre la plataforma.

Open Moko es un una comunidad cuyo objetivo es crear el primer sistema operativo open source para teléfonos móviles. En un principio OpenMoko está diseñado para Neo1973 de FIC, el teléfono mas parecido al ya por todos conocido iphone que he visto hasta la fecha, tan parecido que a veces a uno le entran dudas acerca de la autenticidad de cada cual.

Para quien le entre el gusanillo y se lo pueda permitir ya podemos encargarlo desde https://direct.openmoko.com/ su precio ronda entre 300$ y 450$. Quien sabe, quizás dentro de no mucho tiempo podamos hacer algo como apt-get install gnome-mobile en nuestro teléfono sin tener que firmar un contrato de 3 años con la respectiva compañía telefónica.

En el wiki y el repositorio de proyectos oficial de openmoko tienen toda la información disponible sobre esta plataforma.

7 November, 2007

Automatizar copias de seguridad con rsync

Esta semana me he decidido por fin y he terminado de automatizar las copias de seguridad de mi escritorio ubuntu "Gutsy Gibbon" a un servidor debian "etch".

He utilizado rsync para transmitir todos mis ficheros, herramienta muy versátil con la que realizo mis copias de seguridad de forma incremental en un único sentido, para mantener sincronizados 2 directorios en ambos sentidos podemos utilizar unison.

Partimos de que los scripts los ejecutaremos desde la máquina cliente hacia el servidor. Lo primero que debemos conseguir para transferir los ficheros de forma programada es tener acceso al servidor sin que sea necesaria nuestra intervención. Para ello debemos generar un par de claves publica/privada sin palabra de paso en la máquina cliente y autorizar nuestra clave pública en el servidor. Ejecutamos la utilidad ssh-keygen y generamos las claves:

  1. javi@javi-dell:~/.ssh$ ssh-keygen -d
  2. Generating public/private dsa key pair.
  3. Enter file in which to save the key (/home/javi/.ssh/id_dsa): hola
  4. Enter passphrase (empty for no passphrase):
  5. Enter same passphrase again:
  6. Your identification has been saved in hola.
  7. Your public key has been saved in hola.pub.
  8. The key fingerprint is:
  9. cf:f5:d1:58:52:20:1a:4d:17:70:4c:fa:fc:e0:fc:f5 javi@javi-dell

Hemos generado 2 ficheros: hola (clave privada) y hola.pub (clave pública). Con la opción -d indicamos que utilice el algoritmo dsa (ssh v1 utiliza claves rsa, mientras que ssh v2 utiliza claves dsa), a la primera pregunta respondemos con "hola" que será el nombre de nuestra clave, a continuación nos pedirá la palabra de paso, pulsaremos enter ya que no la necesitamos.

Ahora le mostraremos a nuestro servidor cual es la clave pública con la que nos vamos a conectar. Para ello copiamos el contenido del fichero hola.pub (nuestra clave pública) a una nueva linea del fichero /home/usuario/.ssh/authorized_keys de nuestro servidor, si no existe lo creamos.
Y probamos a conectar utilizando la clave creada:

  1. ssh -i /home/usuario/.ssh/hola host

Podemos utilizar la opción -v para imprimir los pasos que se realizan para conectar y la opción -2 para forzar a que conecte mediante ssh2 si este no es nuestro protocolo por defecto.

Con esto ya deberíamos tener nuestros equipos autentificados mediante claves dsa.

Procedemos a crear el script que ejecutará los backups backup.sh

  1. #!/bin/bash
  2.  
  3. # ARRAY con los directorios origen a copiar
  4. ORG[1]="/home/usuario/_TEMP/org1";
  5. ORG[2]="/home/usuario/_TEMP/org2";
  6. ORG[3]="/home/usuario/_TEMP/org3";
  7.  
  8. # ARRAY con los directorios destino
  9. DEST[1]="/home/usuario/_TEMP/dest1";
  10. DEST[2]="/home/usuario/_TEMP/dest2";
  11. DEST[3]="/home/pepe/";
  12.  
  13. # Usuario y host de la conexion, dejar en blanco para copiar al mismo equipo o unidad extraible
  14. conn[1]="";
  15. conn[2]="";
  16. conn[3]="pepe@picaso:";
  17.  
  18. # Opciones de rsync
  19. opts[1]=" -ah";
  20. opts[2]=" -ah";
  21. opts[3]=" -avhe";
  22.  
  23. # Especificamos el fichero de clave para autentificación, dejar en blanco si no se utiliza
  24. key[1]="";
  25. key[2]="";
  26. key[3]="ssh -i /home/pepe/.ssh/hola";
  27.  
  28. fecha=`date`
  29.  
  30.  
  31. # Recorremos los arrays con los directorios a copiar
  32. i=1;
  33. for j in ${ORG[*]}; do
  34.  
  35.     if (rsync ${opts[i]} "${key[i]}" ${ORG[i]} ${conn[i]}${DEST[i]} --log-file=backup.log ) then
  36.         echo "$fecha Sincronización terminada con EXITO">> backup.log;
  37.     else
  38.         echo "$fecha se ha producido un ERROR durante la sincronización">> backup.log;
  39.     fi
  40.     echo "-----------------------------------------------------------">> backup.log;
  41.  
  42.     i=`expr $i + 1`  #Incrementamos contador en 1
  43. done

Y finalmente lo añadimos a nuestro cron para que se ejecute periódicamente, por ejemplo:

  1. crontab -e
  2.  
  3. # m h  dom mon dow   command
  4. 00 22 * * * /home/usuario/backup.sh

Le decimos que se ejecute todos los días a las 22h.

Powered by WordPress
Bajo licencia Creative Commons
Contacto sanroman.javier at gmail.com