SlideShare una empresa de Scribd logo
1 de 24
Descargar para leer sin conexión
Un poco más allá con
       Grails




          Daniel Latorre

       dani@primerviernes.com
     11/03/2011 – Madrid on Rails
            PrimerVienes
¿Quién?

             Cofundador de Jobsket.com
             Desarrollador independiente
          Principalmente Grails/Groovy/Java
Google Summer of Code 2008 y contribuidor Open Source
             Web: http://www.danilat.com/
           CV: http://www.jobsket.es/cv/dani
                Twitter: @dani_latorre
¿Qué es Grails?



 Framework web para la plataforma Java “full stack”. Escrito
en Groovy y Java utilizando como base varias herramientas
         maduras(Spring, Hibernate, Tomcat...).
                        CoC & DRY.
         Fuertemente inspirado en Ruby on Rails.
Principales características
               de Groovy
      Menos ceremonioso y más expresivo que Java
        Todo es un objeto (no hay tipos primitivos)
                    Compilado o script
    Imports por defecto (java.util.*, java.io.*, java.net.*,
java.math.BigDecimal, java.math.BigInteger, groovy.util.*)
         Compilación cruzada (Joint compilation)
                 El GDK extiende a la JDK
Expandos y MOP (añade y modifica atributos y métodos en
                tiempo de ejecución)
Artefactos de Grails

 Clases de Dominio (GORM)
         Servicios
      Controladores
      Vistas + layouts
     Librerías de tags
          Filtros
          Codecs
Soporte I18N

                 Un properties por Locale.
         Cambio de idioma con /book/list?lang=en.
<g:message code="my.localized.content" args="${['Juan']}"/>
    message(code:"my.localized.content", args:['Juan'])
 Podemos inyectar messageSoruce de Spring en cualquier
                       parte.
Usando Spring podemos incluso modificar el origen de datos
                 del messageSoruce.
Externalizar configuraciones

         Base de datos por JDNI. En el DataSoruce.groovy:
dataSource {
     jndiName = "java:comp/env/myDS"
}
                    Configuración del Config.groovy:
    grails.config.locations = [ "classpath:${appName}-config.groovy","file:$
                {userHome}/.grails/${appName}-config.groovy"]
Plugins Autentificación


Spring Security, casi indiscutible. También con soporte
                 OpenID, LDAP, CAS
                 Facebook Connect
                        OAuth
               Solución Do It Yourself
Plugin REST Client


Para consumir servicios REST externos. Ejemplo:
Envío de emails



        Mail Plugin, para envíos por SMTP
Postmark Plugin, servicio que asegura la recepción.
  Existen varios plugins con más funcionalidades
Lazy/eager loading
Por defecto los objetos relacionados se cargan de forma
                       perezosa.
        Podemos necesitar una session diferente al
          OpenSessionInView de Grails/Spring


static mapping = {
     books lazy: false
}

        NO evitamos el problema de N + 1 queries.
Evitando el problema N+1

                           La solución: fetch.
                     A nivel de relaciones GORM:
static mapping = {
     books fetch: 'join'
}

                           En las consultas:
Author.findAllByNameLike("John%", [fetch: [location: 'join'] ])
Caché de primer nivel de Hibernate
  Caché de primer nivel para ahorrar tráfico en red y
              aumentar la velocidad.
  Sin flush:true en save o delete, no se persisten los
cambios hasta que hibernate ejecute el próximo select.
Caché de segundo nivel de
                 Hibernate
Se cachea cada insancia de la clase de Dominio:
static mapping = {
    cache 'read-only' // cache true
}

read-only: Si los datos son sólo lectura.
non-strict-read-write: Para pocas actualizaciones, no asegura si varias
transacciones modifican la misma instancia.
read-write: Actualizaciones frecuentes. Al modificar se actualiza en
cache, no soporta transacciones y pueden surgir inconsistencias.
transactional: Necesita un proveedor que lo soporte(JBoss TreeCache)
Caché de consultas de Hibernate


    Es posible cachear queries indicándolo al ejecutar.
     Habitual para consultas que se repitan de forma
                        constante

def person = Person.findByFirstName("Fred", [cache:true])
¿Opciones para una política de
       caché propia?

                 EhCahe
                 OSCahe
                Memcache
               JBoss Cache
                 Terracota
  ¿Bases de datos NoSQL?: Redis, Mongo...
Caché de métodos de un Service
         con SpringCache

    Puede interesar cachear las llamadas al método de
                     algún Service.


@Cacheable("pirateCache")
def getPirates() {...}
@CacheFlush("pirateCache")
void registerNewPirate(Pirate pirate) {...}
Caché de HTML con SpringCache

  Cachear porciones de HTML es una práctica habitual.
Para hacerlo se combina SpringCache y el tag include en
                      las vistas.


@Cacheable("albumControllerCache")
  def list = {...}
@CacheFlush("albumControllerCache")
 def save = {...}
Caché HTTP
 Podemos cachear a nivel de navegador jugando con las
      cabeceras HTTP. Ahorrando tráfico y CPU.

 Con el plugin Caching Headers, antes de los renders de los
actions a cachear:
cache shared:true, validFor: 3600 // 1hr on content
cache shared: true, validUntil: new Date()+1
lastModified book.dateUpdate
Hay disponible también un DSL con withCacheHeaders, para permitir
más flexibilidad.
Caché de estáticos


       Resources plugin: comprime .js/.css
Cache-resources plugin: añade manejo de cacheo de
             estáticos al navegador.
Sistemas de mensajería

  Hay que tratar quitar lo máximo de la request para
 mejorar la velocidad, la UX y facilitar la escalabilidad.


          JMS Plugin. Java Message Service
Rabbit MQ Plugin. Advanced Message Queuing Protocol
                      Jabber Plugin.
Solución Do It Yourself(Con quartz o java.util.concurrent)
Optimizando para móviles
  Es posible detectar si el navegador es un teléfono en el
request.getHeader('user-agent'). Para ahorrar ese trabajo
                  manual, SpringMobile.
def list = {
 withMobileDevice {def device ->
        if(device.id.contains("iphone"){
            render(view: "iphoneList", model: [list: listInstance])
        }
        render(view: "mobileList", model: [list: listInstance])
    }
 render(view: "list", model: [list: listInstance])
}
Optimizando para móviles II


En la parte de front, hay que optimizar también el html,
     tamaño de ficheros estáticos, imágenes, etc.
Para smartphones, HTML5: Soporte de geolocalización,
                 Web Database...
Librerías Javascript que pueden ayudar: Sencha Touch
                   o jQuery Mobile.
Algunos enlaces de interés



Postmark, servicio de mailing: http://postmarkapp.com/
Reading i18n messages from the database with Grails: http://1vm.es/000K
SpringSecurity with SpringCache: Caching content per user: http://1vm.es/000L
Localizable plugin: https://github.com/danilat/localizable

Más contenido relacionado

La actualidad más candente

¿Cómo se despliega y autoescala Couchbase en Cloud? ¡Aprende de manera práctica!
¿Cómo se despliega y autoescala Couchbase en Cloud? ¡Aprende de manera práctica!¿Cómo se despliega y autoescala Couchbase en Cloud? ¡Aprende de manera práctica!
¿Cómo se despliega y autoescala Couchbase en Cloud? ¡Aprende de manera práctica!Paradigma Digital
 
Node JS (Francisco Cerdas)
Node JS (Francisco Cerdas)Node JS (Francisco Cerdas)
Node JS (Francisco Cerdas)PiXeL16
 
APIs REST: Django y Go
APIs REST: Django y GoAPIs REST: Django y Go
APIs REST: Django y GoJM Robles
 
Groovy & Grails
Groovy & GrailsGroovy & Grails
Groovy & Grailsbetabeers
 
Web Service and PHP, REST and SOAP
Web Service and PHP, REST and SOAPWeb Service and PHP, REST and SOAP
Web Service and PHP, REST and SOAPElwin Huaman
 
Mootools Y Otros Frameworks JS
Mootools Y Otros Frameworks JSMootools Y Otros Frameworks JS
Mootools Y Otros Frameworks JSIan Monge Pérez
 
High performance Web Sites
High performance Web SitesHigh performance Web Sites
High performance Web SitesopenfinanceDev
 
API REST conceptos (Rails-api)
API REST conceptos (Rails-api)API REST conceptos (Rails-api)
API REST conceptos (Rails-api)Daryl Moreno
 
Cómo crear un RESTful API con Go
Cómo crear un RESTful API con GoCómo crear un RESTful API con Go
Cómo crear un RESTful API con GoSoftware Guru
 
Construccion de proyectos con gradle
Construccion de proyectos con gradleConstruccion de proyectos con gradle
Construccion de proyectos con gradleDavid Gómez García
 
Curso completo php y mysql
Curso completo php y mysqlCurso completo php y mysql
Curso completo php y mysqlJason Arizabal
 
LaCoctelera.com y The Shaker - Conferencia Rails Hispana 2006
LaCoctelera.com y The Shaker - Conferencia Rails Hispana 2006LaCoctelera.com y The Shaker - Conferencia Rails Hispana 2006
LaCoctelera.com y The Shaker - Conferencia Rails Hispana 2006Álvaro Ortiz
 
Docker en el entorno de desarrollo
Docker en el entorno de desarrolloDocker en el entorno de desarrollo
Docker en el entorno de desarrolloAlejandro Hernández
 
Introducción al framework Symfony
Introducción al framework SymfonyIntroducción al framework Symfony
Introducción al framework SymfonyAlejandro Hernández
 

La actualidad más candente (20)

¿Cómo se despliega y autoescala Couchbase en Cloud? ¡Aprende de manera práctica!
¿Cómo se despliega y autoescala Couchbase en Cloud? ¡Aprende de manera práctica!¿Cómo se despliega y autoescala Couchbase en Cloud? ¡Aprende de manera práctica!
¿Cómo se despliega y autoescala Couchbase en Cloud? ¡Aprende de manera práctica!
 
Node JS (Francisco Cerdas)
Node JS (Francisco Cerdas)Node JS (Francisco Cerdas)
Node JS (Francisco Cerdas)
 
Semana 3 MONGODB conceptos básicos NOSQL
Semana 3   MONGODB conceptos básicos NOSQLSemana 3   MONGODB conceptos básicos NOSQL
Semana 3 MONGODB conceptos básicos NOSQL
 
APIs REST: Django y Go
APIs REST: Django y GoAPIs REST: Django y Go
APIs REST: Django y Go
 
Fury - Docker Meetup
Fury - Docker MeetupFury - Docker Meetup
Fury - Docker Meetup
 
Groovy & Grails
Groovy & GrailsGroovy & Grails
Groovy & Grails
 
Web Service and PHP, REST and SOAP
Web Service and PHP, REST and SOAPWeb Service and PHP, REST and SOAP
Web Service and PHP, REST and SOAP
 
Mootools Y Otros Frameworks JS
Mootools Y Otros Frameworks JSMootools Y Otros Frameworks JS
Mootools Y Otros Frameworks JS
 
Curso de php
Curso de phpCurso de php
Curso de php
 
Real-time web
Real-time webReal-time web
Real-time web
 
High performance Web Sites
High performance Web SitesHigh performance Web Sites
High performance Web Sites
 
API REST conceptos (Rails-api)
API REST conceptos (Rails-api)API REST conceptos (Rails-api)
API REST conceptos (Rails-api)
 
Introducción Nodejs
Introducción NodejsIntroducción Nodejs
Introducción Nodejs
 
Cómo crear un RESTful API con Go
Cómo crear un RESTful API con GoCómo crear un RESTful API con Go
Cómo crear un RESTful API con Go
 
Construccion de proyectos con gradle
Construccion de proyectos con gradleConstruccion de proyectos con gradle
Construccion de proyectos con gradle
 
Curso completo php y mysql
Curso completo php y mysqlCurso completo php y mysql
Curso completo php y mysql
 
LaCoctelera.com y The Shaker - Conferencia Rails Hispana 2006
LaCoctelera.com y The Shaker - Conferencia Rails Hispana 2006LaCoctelera.com y The Shaker - Conferencia Rails Hispana 2006
LaCoctelera.com y The Shaker - Conferencia Rails Hispana 2006
 
Docker en el entorno de desarrollo
Docker en el entorno de desarrolloDocker en el entorno de desarrollo
Docker en el entorno de desarrollo
 
Tecnologias emergentes node js
Tecnologias emergentes node jsTecnologias emergentes node js
Tecnologias emergentes node js
 
Introducción al framework Symfony
Introducción al framework SymfonyIntroducción al framework Symfony
Introducción al framework Symfony
 

Similar a Un poco más allá con grails. PrimerViernes

[ES] Introducción a las Aplicaciones Web con Java
[ES] Introducción a las Aplicaciones Web con Java[ES] Introducción a las Aplicaciones Web con Java
[ES] Introducción a las Aplicaciones Web con JavaEudris Cabrera
 
Aplicaciones web offline ITParral Prieto y Nassi
Aplicaciones web offline ITParral Prieto y NassiAplicaciones web offline ITParral Prieto y Nassi
Aplicaciones web offline ITParral Prieto y NassiGuillermo Nassi
 
Gwt seminario java_hispano_manolocarrasco
Gwt seminario java_hispano_manolocarrascoGwt seminario java_hispano_manolocarrasco
Gwt seminario java_hispano_manolocarrascoManuel Carrasco Moñino
 
Programacion web-Lenguajes del lado del servidor
Programacion web-Lenguajes del lado del servidorProgramacion web-Lenguajes del lado del servidor
Programacion web-Lenguajes del lado del servidorJose Felix Moran Agusto
 
Dragome en JavaConf Buenos Aires 2014
Dragome en JavaConf Buenos Aires 2014 Dragome en JavaConf Buenos Aires 2014
Dragome en JavaConf Buenos Aires 2014 Fernando Petrola
 
Django - Plataforma de sitios web
Django - Plataforma de sitios webDjango - Plataforma de sitios web
Django - Plataforma de sitios webjcarazo
 
Aprendiendo a Programas en 4 horas JavaScript
Aprendiendo a Programas en 4 horas JavaScriptAprendiendo a Programas en 4 horas JavaScript
Aprendiendo a Programas en 4 horas JavaScriptKarsarmi
 
01 Ext Js Introduccion
01 Ext Js   Introduccion01 Ext Js   Introduccion
01 Ext Js IntroduccionMayer Horna
 
Jsf Java Server Faces
Jsf   Java Server FacesJsf   Java Server Faces
Jsf Java Server Facescok12v
 
Introducción a Tomcat
Introducción a TomcatIntroducción a Tomcat
Introducción a TomcatIker Canarias
 
Marcos quesada caching_sf2
Marcos quesada caching_sf2Marcos quesada caching_sf2
Marcos quesada caching_sf2symfony_bcn
 
Opensouthcode: Microservicios sobre MEAN Stack
Opensouthcode: Microservicios sobre MEAN StackOpensouthcode: Microservicios sobre MEAN Stack
Opensouthcode: Microservicios sobre MEAN StackPedro J. Molina
 

Similar a Un poco más allá con grails. PrimerViernes (20)

[ES] Introducción a las Aplicaciones Web con Java
[ES] Introducción a las Aplicaciones Web con Java[ES] Introducción a las Aplicaciones Web con Java
[ES] Introducción a las Aplicaciones Web con Java
 
Ajax
AjaxAjax
Ajax
 
Aplicaciones web offline ITParral Prieto y Nassi
Aplicaciones web offline ITParral Prieto y NassiAplicaciones web offline ITParral Prieto y Nassi
Aplicaciones web offline ITParral Prieto y Nassi
 
Taller de Grails
Taller de GrailsTaller de Grails
Taller de Grails
 
Aprendiendo GWT
Aprendiendo GWTAprendiendo GWT
Aprendiendo GWT
 
Gwt seminario java_hispano_manolocarrasco
Gwt seminario java_hispano_manolocarrascoGwt seminario java_hispano_manolocarrasco
Gwt seminario java_hispano_manolocarrasco
 
Programacion web-Lenguajes del lado del servidor
Programacion web-Lenguajes del lado del servidorProgramacion web-Lenguajes del lado del servidor
Programacion web-Lenguajes del lado del servidor
 
Dragome en JavaConf Buenos Aires 2014
Dragome en JavaConf Buenos Aires 2014 Dragome en JavaConf Buenos Aires 2014
Dragome en JavaConf Buenos Aires 2014
 
Charla
CharlaCharla
Charla
 
Django - Plataforma de sitios web
Django - Plataforma de sitios webDjango - Plataforma de sitios web
Django - Plataforma de sitios web
 
HTML5-Aplicaciones web
HTML5-Aplicaciones webHTML5-Aplicaciones web
HTML5-Aplicaciones web
 
Aprendiendo a Programas en 4 horas JavaScript
Aprendiendo a Programas en 4 horas JavaScriptAprendiendo a Programas en 4 horas JavaScript
Aprendiendo a Programas en 4 horas JavaScript
 
01 Ext Js Introduccion
01 Ext Js   Introduccion01 Ext Js   Introduccion
01 Ext Js Introduccion
 
Jsf Java Server Faces
Jsf   Java Server FacesJsf   Java Server Faces
Jsf Java Server Faces
 
Introducción a Tomcat
Introducción a TomcatIntroducción a Tomcat
Introducción a Tomcat
 
Groogle
GroogleGroogle
Groogle
 
04. Implementando APIs HTML5
04. Implementando APIs HTML5 04. Implementando APIs HTML5
04. Implementando APIs HTML5
 
Marcos quesada caching_sf2
Marcos quesada caching_sf2Marcos quesada caching_sf2
Marcos quesada caching_sf2
 
Sesion03 apuntes
Sesion03 apuntesSesion03 apuntes
Sesion03 apuntes
 
Opensouthcode: Microservicios sobre MEAN Stack
Opensouthcode: Microservicios sobre MEAN StackOpensouthcode: Microservicios sobre MEAN Stack
Opensouthcode: Microservicios sobre MEAN Stack
 

Más de Dani Latorre

5 aniversario de Agile-Aragón
5 aniversario de Agile-Aragón5 aniversario de Agile-Aragón
5 aniversario de Agile-AragónDani Latorre
 
A falta de APIs buenas son tortas. XV Betabeers Zaragoza
A falta de APIs buenas son tortas. XV Betabeers ZaragozaA falta de APIs buenas son tortas. XV Betabeers Zaragoza
A falta de APIs buenas son tortas. XV Betabeers ZaragozaDani Latorre
 
Selenium como herramienta de Web Scraping
Selenium como herramienta de Web ScrapingSelenium como herramienta de Web Scraping
Selenium como herramienta de Web ScrapingDani Latorre
 
Vinalab, de visitas a clientes
Vinalab, de visitas a clientesVinalab, de visitas a clientes
Vinalab, de visitas a clientesDani Latorre
 
Cocina tu idea, crea tu producto
Cocina tu idea, crea tu productoCocina tu idea, crea tu producto
Cocina tu idea, crea tu productoDani Latorre
 
Testing en proyectos Grails del día a día. Greach 2013
Testing en proyectos Grails del día a día. Greach 2013Testing en proyectos Grails del día a día. Greach 2013
Testing en proyectos Grails del día a día. Greach 2013Dani Latorre
 
Agile Manifesto - EINA
Agile Manifesto - EINAAgile Manifesto - EINA
Agile Manifesto - EINADani Latorre
 
Como se hizo elDisparate.de
Como se hizo elDisparate.deComo se hizo elDisparate.de
Como se hizo elDisparate.deDani Latorre
 
Modulariza tus aplicaciones Grails - Springio 2012
Modulariza tus aplicaciones Grails - Springio 2012Modulariza tus aplicaciones Grails - Springio 2012
Modulariza tus aplicaciones Grails - Springio 2012Dani Latorre
 
Grails: Aumenta tu productividad en tus aplicaciones web Java
Grails: Aumenta tu productividad en tus aplicaciones web JavaGrails: Aumenta tu productividad en tus aplicaciones web Java
Grails: Aumenta tu productividad en tus aplicaciones web JavaDani Latorre
 
Optimiza tus webs Grails. Greach 2011
Optimiza tus webs Grails. Greach 2011Optimiza tus webs Grails. Greach 2011
Optimiza tus webs Grails. Greach 2011Dani Latorre
 
Opendata - TheEvnt 2011
Opendata - TheEvnt 2011Opendata - TheEvnt 2011
Opendata - TheEvnt 2011Dani Latorre
 
Groovy Koans - SpringIO 2011
Groovy Koans - SpringIO 2011Groovy Koans - SpringIO 2011
Groovy Koans - SpringIO 2011Dani Latorre
 
GHOP - GSoC Campus Party 2008
GHOP - GSoC Campus Party 2008GHOP - GSoC Campus Party 2008
GHOP - GSoC Campus Party 2008Dani Latorre
 

Más de Dani Latorre (16)

5 aniversario de Agile-Aragón
5 aniversario de Agile-Aragón5 aniversario de Agile-Aragón
5 aniversario de Agile-Aragón
 
A falta de APIs buenas son tortas. XV Betabeers Zaragoza
A falta de APIs buenas son tortas. XV Betabeers ZaragozaA falta de APIs buenas son tortas. XV Betabeers Zaragoza
A falta de APIs buenas son tortas. XV Betabeers Zaragoza
 
Selenium como herramienta de Web Scraping
Selenium como herramienta de Web ScrapingSelenium como herramienta de Web Scraping
Selenium como herramienta de Web Scraping
 
Vinalab, de visitas a clientes
Vinalab, de visitas a clientesVinalab, de visitas a clientes
Vinalab, de visitas a clientes
 
Cocina tu idea, crea tu producto
Cocina tu idea, crea tu productoCocina tu idea, crea tu producto
Cocina tu idea, crea tu producto
 
Testing en proyectos Grails del día a día. Greach 2013
Testing en proyectos Grails del día a día. Greach 2013Testing en proyectos Grails del día a día. Greach 2013
Testing en proyectos Grails del día a día. Greach 2013
 
Agile Manifesto - EINA
Agile Manifesto - EINAAgile Manifesto - EINA
Agile Manifesto - EINA
 
Agile Manifesto
Agile ManifestoAgile Manifesto
Agile Manifesto
 
Como se hizo elDisparate.de
Como se hizo elDisparate.deComo se hizo elDisparate.de
Como se hizo elDisparate.de
 
Modulariza tus aplicaciones Grails - Springio 2012
Modulariza tus aplicaciones Grails - Springio 2012Modulariza tus aplicaciones Grails - Springio 2012
Modulariza tus aplicaciones Grails - Springio 2012
 
Grails: Aumenta tu productividad en tus aplicaciones web Java
Grails: Aumenta tu productividad en tus aplicaciones web JavaGrails: Aumenta tu productividad en tus aplicaciones web Java
Grails: Aumenta tu productividad en tus aplicaciones web Java
 
Optimiza tus webs Grails. Greach 2011
Optimiza tus webs Grails. Greach 2011Optimiza tus webs Grails. Greach 2011
Optimiza tus webs Grails. Greach 2011
 
Opendata - TheEvnt 2011
Opendata - TheEvnt 2011Opendata - TheEvnt 2011
Opendata - TheEvnt 2011
 
Groovy Koans - SpringIO 2011
Groovy Koans - SpringIO 2011Groovy Koans - SpringIO 2011
Groovy Koans - SpringIO 2011
 
Taller Grails
Taller GrailsTaller Grails
Taller Grails
 
GHOP - GSoC Campus Party 2008
GHOP - GSoC Campus Party 2008GHOP - GSoC Campus Party 2008
GHOP - GSoC Campus Party 2008
 

Último

Presentación - Diseño de Algoritmos Paralelos - Grupo 2.pdf
Presentación - Diseño de Algoritmos Paralelos - Grupo 2.pdfPresentación - Diseño de Algoritmos Paralelos - Grupo 2.pdf
Presentación - Diseño de Algoritmos Paralelos - Grupo 2.pdfymiranda2
 
Actividad 1-PRESENTACIÓN ANIMADA.pptxPreservación y conservación de los docum...
Actividad 1-PRESENTACIÓN ANIMADA.pptxPreservación y conservación de los docum...Actividad 1-PRESENTACIÓN ANIMADA.pptxPreservación y conservación de los docum...
Actividad 1-PRESENTACIÓN ANIMADA.pptxPreservación y conservación de los docum...OLGAMILENAMONTAEZNIO
 
Actividad 14: Diseño de Algoritmos Paralelos Actividad 14: Diseño de Algoritm...
Actividad 14: Diseño de Algoritmos Paralelos Actividad 14: Diseño de Algoritm...Actividad 14: Diseño de Algoritmos Paralelos Actividad 14: Diseño de Algoritm...
Actividad 14: Diseño de Algoritmos Paralelos Actividad 14: Diseño de Algoritm...RaymondCode
 
Inteligencia artificial dentro de la contabilidad
Inteligencia artificial dentro de la contabilidadInteligencia artificial dentro de la contabilidad
Inteligencia artificial dentro de la contabilidaddanik1023m
 
De Código a Ejecución: El Papel Fundamental del MSIL en .NET
De Código a Ejecución: El Papel Fundamental del MSIL en .NETDe Código a Ejecución: El Papel Fundamental del MSIL en .NET
De Código a Ejecución: El Papel Fundamental del MSIL en .NETGermán Küber
 
Análisis de artefactos tecnologicos .pdf
Análisis de artefactos tecnologicos .pdfAnálisis de artefactos tecnologicos .pdf
Análisis de artefactos tecnologicos .pdfcastrodanna185
 
VIDEOS DE APOYO.docx E
VIDEOS DE APOYO.docx                                  EVIDEOS DE APOYO.docx                                  E
VIDEOS DE APOYO.docx Emialexsolar
 
Carta de Premio y Excel angeline 11-2pdf
Carta de Premio y Excel angeline 11-2pdfCarta de Premio y Excel angeline 11-2pdf
Carta de Premio y Excel angeline 11-2pdfangelinebocanegra1
 
La tablet trabajo en grupo del grado 9-2
La tablet trabajo en grupo del grado 9-2La tablet trabajo en grupo del grado 9-2
La tablet trabajo en grupo del grado 9-2montoyagabriela340
 
Tecnológia 2024.docx.Tecnológia 2024.docx.
Tecnológia 2024.docx.Tecnológia 2024.docx.Tecnológia 2024.docx.Tecnológia 2024.docx.
Tecnológia 2024.docx.Tecnológia 2024.docx.marianarodriguezc797
 
El diseño de Algoritmos Paralelos.pdf - analisis de algortimos
El diseño de Algoritmos Paralelos.pdf - analisis de algortimosEl diseño de Algoritmos Paralelos.pdf - analisis de algortimos
El diseño de Algoritmos Paralelos.pdf - analisis de algortimosLCristinaForchue
 
PRESENTACION DEL TEMA LOS MEJORES SIMULADORES DE CIRCUITOS ELCTRONICOS
PRESENTACION DEL TEMA LOS MEJORES SIMULADORES DE CIRCUITOS ELCTRONICOSPRESENTACION DEL TEMA LOS MEJORES SIMULADORES DE CIRCUITOS ELCTRONICOS
PRESENTACION DEL TEMA LOS MEJORES SIMULADORES DE CIRCUITOS ELCTRONICOSLincangoKevin
 
Actividad 14_ Diseño de Algoritmos Paralelos.pdf
Actividad 14_ Diseño de Algoritmos Paralelos.pdfActividad 14_ Diseño de Algoritmos Paralelos.pdf
Actividad 14_ Diseño de Algoritmos Paralelos.pdfalejandrogomezescoto
 
Los mejores simuladores de circuitos electrónicos.pdf
Los mejores simuladores de circuitos electrónicos.pdfLos mejores simuladores de circuitos electrónicos.pdf
Los mejores simuladores de circuitos electrónicos.pdfodalistar77
 
Inmersión global en ciberseguridad e IA en la conferencia RSA.pdf
Inmersión global en ciberseguridad e IA en la conferencia RSA.pdfInmersión global en ciberseguridad e IA en la conferencia RSA.pdf
Inmersión global en ciberseguridad e IA en la conferencia RSA.pdfOBr.global
 
TENDENCIAS DE IA Explorando el futuro de la tecnologia.pdf
TENDENCIAS DE IA Explorando el futuro de la tecnologia.pdfTENDENCIAS DE IA Explorando el futuro de la tecnologia.pdf
TENDENCIAS DE IA Explorando el futuro de la tecnologia.pdfJoseAlejandroPerezBa
 
Matriz de integración de tecnologías- Paola Carvajal.docx
Matriz de integración de tecnologías- Paola Carvajal.docxMatriz de integración de tecnologías- Paola Carvajal.docx
Matriz de integración de tecnologías- Paola Carvajal.docxPaolaCarolinaCarvaja
 
La Electricidad y La Electrónica.pdf....
La Electricidad y La Electrónica.pdf....La Electricidad y La Electrónica.pdf....
La Electricidad y La Electrónica.pdf....Aaron Betancourt
 

Último (20)

BEDEC Sostenibilidad, novedades 2024 - Laura Silva
BEDEC Sostenibilidad, novedades 2024 - Laura SilvaBEDEC Sostenibilidad, novedades 2024 - Laura Silva
BEDEC Sostenibilidad, novedades 2024 - Laura Silva
 
Presentación - Diseño de Algoritmos Paralelos - Grupo 2.pdf
Presentación - Diseño de Algoritmos Paralelos - Grupo 2.pdfPresentación - Diseño de Algoritmos Paralelos - Grupo 2.pdf
Presentación - Diseño de Algoritmos Paralelos - Grupo 2.pdf
 
Actividad 1-PRESENTACIÓN ANIMADA.pptxPreservación y conservación de los docum...
Actividad 1-PRESENTACIÓN ANIMADA.pptxPreservación y conservación de los docum...Actividad 1-PRESENTACIÓN ANIMADA.pptxPreservación y conservación de los docum...
Actividad 1-PRESENTACIÓN ANIMADA.pptxPreservación y conservación de los docum...
 
Actividad 14: Diseño de Algoritmos Paralelos Actividad 14: Diseño de Algoritm...
Actividad 14: Diseño de Algoritmos Paralelos Actividad 14: Diseño de Algoritm...Actividad 14: Diseño de Algoritmos Paralelos Actividad 14: Diseño de Algoritm...
Actividad 14: Diseño de Algoritmos Paralelos Actividad 14: Diseño de Algoritm...
 
Inteligencia artificial dentro de la contabilidad
Inteligencia artificial dentro de la contabilidadInteligencia artificial dentro de la contabilidad
Inteligencia artificial dentro de la contabilidad
 
De Código a Ejecución: El Papel Fundamental del MSIL en .NET
De Código a Ejecución: El Papel Fundamental del MSIL en .NETDe Código a Ejecución: El Papel Fundamental del MSIL en .NET
De Código a Ejecución: El Papel Fundamental del MSIL en .NET
 
Análisis de artefactos tecnologicos .pdf
Análisis de artefactos tecnologicos .pdfAnálisis de artefactos tecnologicos .pdf
Análisis de artefactos tecnologicos .pdf
 
VIDEOS DE APOYO.docx E
VIDEOS DE APOYO.docx                                  EVIDEOS DE APOYO.docx                                  E
VIDEOS DE APOYO.docx E
 
Carta de Premio y Excel angeline 11-2pdf
Carta de Premio y Excel angeline 11-2pdfCarta de Premio y Excel angeline 11-2pdf
Carta de Premio y Excel angeline 11-2pdf
 
La tablet trabajo en grupo del grado 9-2
La tablet trabajo en grupo del grado 9-2La tablet trabajo en grupo del grado 9-2
La tablet trabajo en grupo del grado 9-2
 
Tecnológia 2024.docx.Tecnológia 2024.docx.
Tecnológia 2024.docx.Tecnológia 2024.docx.Tecnológia 2024.docx.Tecnológia 2024.docx.
Tecnológia 2024.docx.Tecnológia 2024.docx.
 
BEDEC Proyecto y obra , novedades 2024 - Xavier Folch
BEDEC Proyecto y obra , novedades 2024 - Xavier FolchBEDEC Proyecto y obra , novedades 2024 - Xavier Folch
BEDEC Proyecto y obra , novedades 2024 - Xavier Folch
 
El diseño de Algoritmos Paralelos.pdf - analisis de algortimos
El diseño de Algoritmos Paralelos.pdf - analisis de algortimosEl diseño de Algoritmos Paralelos.pdf - analisis de algortimos
El diseño de Algoritmos Paralelos.pdf - analisis de algortimos
 
PRESENTACION DEL TEMA LOS MEJORES SIMULADORES DE CIRCUITOS ELCTRONICOS
PRESENTACION DEL TEMA LOS MEJORES SIMULADORES DE CIRCUITOS ELCTRONICOSPRESENTACION DEL TEMA LOS MEJORES SIMULADORES DE CIRCUITOS ELCTRONICOS
PRESENTACION DEL TEMA LOS MEJORES SIMULADORES DE CIRCUITOS ELCTRONICOS
 
Actividad 14_ Diseño de Algoritmos Paralelos.pdf
Actividad 14_ Diseño de Algoritmos Paralelos.pdfActividad 14_ Diseño de Algoritmos Paralelos.pdf
Actividad 14_ Diseño de Algoritmos Paralelos.pdf
 
Los mejores simuladores de circuitos electrónicos.pdf
Los mejores simuladores de circuitos electrónicos.pdfLos mejores simuladores de circuitos electrónicos.pdf
Los mejores simuladores de circuitos electrónicos.pdf
 
Inmersión global en ciberseguridad e IA en la conferencia RSA.pdf
Inmersión global en ciberseguridad e IA en la conferencia RSA.pdfInmersión global en ciberseguridad e IA en la conferencia RSA.pdf
Inmersión global en ciberseguridad e IA en la conferencia RSA.pdf
 
TENDENCIAS DE IA Explorando el futuro de la tecnologia.pdf
TENDENCIAS DE IA Explorando el futuro de la tecnologia.pdfTENDENCIAS DE IA Explorando el futuro de la tecnologia.pdf
TENDENCIAS DE IA Explorando el futuro de la tecnologia.pdf
 
Matriz de integración de tecnologías- Paola Carvajal.docx
Matriz de integración de tecnologías- Paola Carvajal.docxMatriz de integración de tecnologías- Paola Carvajal.docx
Matriz de integración de tecnologías- Paola Carvajal.docx
 
La Electricidad y La Electrónica.pdf....
La Electricidad y La Electrónica.pdf....La Electricidad y La Electrónica.pdf....
La Electricidad y La Electrónica.pdf....
 

Un poco más allá con grails. PrimerViernes

  • 1. Un poco más allá con Grails Daniel Latorre dani@primerviernes.com 11/03/2011 – Madrid on Rails PrimerVienes
  • 2. ¿Quién? Cofundador de Jobsket.com Desarrollador independiente Principalmente Grails/Groovy/Java Google Summer of Code 2008 y contribuidor Open Source Web: http://www.danilat.com/ CV: http://www.jobsket.es/cv/dani Twitter: @dani_latorre
  • 3. ¿Qué es Grails? Framework web para la plataforma Java “full stack”. Escrito en Groovy y Java utilizando como base varias herramientas maduras(Spring, Hibernate, Tomcat...). CoC & DRY. Fuertemente inspirado en Ruby on Rails.
  • 4. Principales características de Groovy Menos ceremonioso y más expresivo que Java Todo es un objeto (no hay tipos primitivos) Compilado o script Imports por defecto (java.util.*, java.io.*, java.net.*, java.math.BigDecimal, java.math.BigInteger, groovy.util.*) Compilación cruzada (Joint compilation) El GDK extiende a la JDK Expandos y MOP (añade y modifica atributos y métodos en tiempo de ejecución)
  • 5. Artefactos de Grails Clases de Dominio (GORM) Servicios Controladores Vistas + layouts Librerías de tags Filtros Codecs
  • 6. Soporte I18N Un properties por Locale. Cambio de idioma con /book/list?lang=en. <g:message code="my.localized.content" args="${['Juan']}"/> message(code:"my.localized.content", args:['Juan']) Podemos inyectar messageSoruce de Spring en cualquier parte. Usando Spring podemos incluso modificar el origen de datos del messageSoruce.
  • 7. Externalizar configuraciones Base de datos por JDNI. En el DataSoruce.groovy: dataSource { jndiName = "java:comp/env/myDS" } Configuración del Config.groovy: grails.config.locations = [ "classpath:${appName}-config.groovy","file:$ {userHome}/.grails/${appName}-config.groovy"]
  • 8. Plugins Autentificación Spring Security, casi indiscutible. También con soporte OpenID, LDAP, CAS Facebook Connect OAuth Solución Do It Yourself
  • 9. Plugin REST Client Para consumir servicios REST externos. Ejemplo:
  • 10. Envío de emails Mail Plugin, para envíos por SMTP Postmark Plugin, servicio que asegura la recepción. Existen varios plugins con más funcionalidades
  • 11. Lazy/eager loading Por defecto los objetos relacionados se cargan de forma perezosa. Podemos necesitar una session diferente al OpenSessionInView de Grails/Spring static mapping = { books lazy: false } NO evitamos el problema de N + 1 queries.
  • 12. Evitando el problema N+1 La solución: fetch. A nivel de relaciones GORM: static mapping = { books fetch: 'join' } En las consultas: Author.findAllByNameLike("John%", [fetch: [location: 'join'] ])
  • 13. Caché de primer nivel de Hibernate Caché de primer nivel para ahorrar tráfico en red y aumentar la velocidad. Sin flush:true en save o delete, no se persisten los cambios hasta que hibernate ejecute el próximo select.
  • 14. Caché de segundo nivel de Hibernate Se cachea cada insancia de la clase de Dominio: static mapping = { cache 'read-only' // cache true } read-only: Si los datos son sólo lectura. non-strict-read-write: Para pocas actualizaciones, no asegura si varias transacciones modifican la misma instancia. read-write: Actualizaciones frecuentes. Al modificar se actualiza en cache, no soporta transacciones y pueden surgir inconsistencias. transactional: Necesita un proveedor que lo soporte(JBoss TreeCache)
  • 15. Caché de consultas de Hibernate Es posible cachear queries indicándolo al ejecutar. Habitual para consultas que se repitan de forma constante def person = Person.findByFirstName("Fred", [cache:true])
  • 16. ¿Opciones para una política de caché propia? EhCahe OSCahe Memcache JBoss Cache Terracota ¿Bases de datos NoSQL?: Redis, Mongo...
  • 17. Caché de métodos de un Service con SpringCache Puede interesar cachear las llamadas al método de algún Service. @Cacheable("pirateCache") def getPirates() {...} @CacheFlush("pirateCache") void registerNewPirate(Pirate pirate) {...}
  • 18. Caché de HTML con SpringCache Cachear porciones de HTML es una práctica habitual. Para hacerlo se combina SpringCache y el tag include en las vistas. @Cacheable("albumControllerCache") def list = {...} @CacheFlush("albumControllerCache") def save = {...}
  • 19. Caché HTTP Podemos cachear a nivel de navegador jugando con las cabeceras HTTP. Ahorrando tráfico y CPU. Con el plugin Caching Headers, antes de los renders de los actions a cachear: cache shared:true, validFor: 3600 // 1hr on content cache shared: true, validUntil: new Date()+1 lastModified book.dateUpdate Hay disponible también un DSL con withCacheHeaders, para permitir más flexibilidad.
  • 20. Caché de estáticos Resources plugin: comprime .js/.css Cache-resources plugin: añade manejo de cacheo de estáticos al navegador.
  • 21. Sistemas de mensajería Hay que tratar quitar lo máximo de la request para mejorar la velocidad, la UX y facilitar la escalabilidad. JMS Plugin. Java Message Service Rabbit MQ Plugin. Advanced Message Queuing Protocol Jabber Plugin. Solución Do It Yourself(Con quartz o java.util.concurrent)
  • 22. Optimizando para móviles Es posible detectar si el navegador es un teléfono en el request.getHeader('user-agent'). Para ahorrar ese trabajo manual, SpringMobile. def list = { withMobileDevice {def device -> if(device.id.contains("iphone"){ render(view: "iphoneList", model: [list: listInstance]) } render(view: "mobileList", model: [list: listInstance]) } render(view: "list", model: [list: listInstance]) }
  • 23. Optimizando para móviles II En la parte de front, hay que optimizar también el html, tamaño de ficheros estáticos, imágenes, etc. Para smartphones, HTML5: Soporte de geolocalización, Web Database... Librerías Javascript que pueden ayudar: Sencha Touch o jQuery Mobile.
  • 24. Algunos enlaces de interés Postmark, servicio de mailing: http://postmarkapp.com/ Reading i18n messages from the database with Grails: http://1vm.es/000K SpringSecurity with SpringCache: Caching content per user: http://1vm.es/000L Localizable plugin: https://github.com/danilat/localizable