 
  
        
         
  
  Some days ago I attended as usual to the fantastic Greach Conference, an international conference about the Apache Groovy language and ecosystem: Groovy, Grails, Gradle and a lot other things. Greach is held each year in Madrid but everything is in English, and nowadays it’s surely one of the Top worldwide events about this technologies.
Greach is a non-profitable event organized by Iván López (@ilopar) and Alberto Vilches (@albertovilches), with some help from colleagues and a lot of sponsors.
TLDR; The conference content and speakers were great, in addition to the logistics. I couldn’t attend the workshop day (my fault), and it was a pity specially because this year I had paid for it. Apart from learning (as usual), this year was specially exciting with the worldwide announcement of Micronaut.
Let me summarize some of the talks I attended:
Talks
Groovy Keynote: 2.5+ Roadmap, by Paul King (@paulk_asert)
Paul King, Groovy Technical Lead at OCI, gave a good overview on the status and roadmap of the Apache Groovy language. Paul summarized the features announced for Groovy 2.5 (GA expected Q2 2018) and Groovy 2.6 / 3.0 (RC end of 2018). Apart from more (and better) AST transformations, Groovy 2.6 / 3.0 version will come with the brand new Parrot parser that brings several improvements and better Java syntax support for a lot of use cases.
Building DSL using Groovy, by Puneet Behl (@puneetbhl)
Puneet, Software Engineer at OCI, started with a brief introduction to DSLs, for those who are not familiar with them. He focused on the advantages of the DSLs in some use cases, allowing the Domain experts to help, validate and even code DSL expressions. After that, he showed with some examples how to create a DSL language with Groovy. The talk was nice but probably he could’ve made the assumption that everyone in Greach knows Groovy basics or what a DSL is.
I’ve seen Grails code you wouldn’t believe…, by Iván López (@ilopmar)
Iván made, as usual, a well prepared an amusing talk about some mistakes that he has seen in the recent months in several Groovy projects. Names were changed and the code was partially blurred but it was clear enough to recognize the errors. Most of them were obvious and could have been detected with any static code analysis tool (like CodeNARC) but in other examples the static analysis is not enough and someone needs to read the code and think about what is written. That’s why the main recommendation that Iván gave for this kind of errors is the proper usage of Code Reviews with other peers.
Groovy GString magic, by Jacob Aae Mikkelsen (@JacobAae)
I wasn’t sure if Jacob’s talk was going to be too basic, but knowing the speaker from other conferences I was confident that I could learn something. I was right in both assumptions, the talk was a complete review of the GString class in Groovy covering all the basic usages and the differences with the Java String class, the template engines, and the main caveats but the speaker also gave several interesting tips and tricks, and I didn’t knew all of them. It was specially nice the stripIndent method.
From Functions to Monadic Style, by Dierk König (@mittie)
Dierk’s talk was mainly a live coding session. He performed an interesting exercise, typical in functional programming workshops, but with the twist of adding specific rules to the exercise in an incremental way as in a coding kata. The talk was very interesting and sometimes amusing starting with an hilarious statement: “As soon as you have understood monads, you immediately lose the ability to explain it!”.
. @mittie admitted that he's a Groovy-holic#greach18 pic.twitter.com/XRD1axwZRa
— Greach (@greachconf) March 16, 2018
Mapping a tree with Grails, by Sergio del Amo (@sdelamo)
Sergio gave a complete talk reviewing the tree data structure, commenting some use cases in which to use it and also comparing several different implementations of a data structure in Groovy: Adjacency lists, path enumeration, nested sets and closure tables. He remarked that the right design and implementation depends on the use case, if you normally need to query the leafs or an entire subtree, if the tree is mostly static or its subject to lots of insertions, etc.
 
  
  Reactive All The Way Down with Ratpack, Groovy, RxJava, React, and RabbitMQ, by Steve Pember (@svpember)
This talk was also very complete, describing the advantages of a reactive environment, the anatomy of a reactive service and how to make the main technology choices to build a proper Reactive application. Among all the advantages described by Steve I’ll highlight the optimized usage of resources, the reduction of synchronous communications and the increase of error protection due to have more decoupled and independent systems.
Another hilarious moment for me came when Steve described as a reason to keep using RabbitMQ that “you don’t mind being looked down upon by Kafka fans”. Not related to this, but in my company we are precisely replacing RabbitMQ with Apache Kafka everywhere.
Launching the Micro Future: Groovy, Grails and MicroNaut, by Graeme Rocher (@graemerocher)
Iván López warned us about this talk and it was much more that what I expected. Graeme Rocher made the worldwide presentation of MicroNaut, an ultra-light cloud native reactive framework for the JVM. It’ll be compatible with Groovy and Java, but also with other languages of the JVM like Kotlin. The first milestones will be released by Q2 2018 and the GA version is expected by the end of the year.
Hello #greach18 conf attendees! It's here! It's here! It's finally here! https://t.co/lt3Bglsb90 pic.twitter.com/iGbUZMn0gO
— The Micronaut Framework (@micronautfw) March 16, 2018
Graeme and the rest of the OCI people have been working on this since at least 1.5 years ago. They released Grails ten years ago, so they have all our confidence and respect. The premise is that Grails, and Spring of course, were not designed for a microservices world. They come from an era without most of the things that are common nowadays: microservices, without containers,…
Some quick hints about MicroNaut:
- It is designed from scratch with Microservices in mind
- It’s ultra-light weight (Grame shared some amazing numbers) and reactive (it’s based on Netty)
- Can be run with as little as 10Mb Max Heap for Java (24MB for Groovy)
- Start-up time is below a second for Java (1 second for Groovy)
 
- Compatible with any Reactive Streams implementation: RxJava 2.x, Reactor 3.x, Akka,…
- Integrates AOP and compile time dependency injection (and this implies a lot, great topic to talk about), so no reflection and no runtime proxies
- It’s both HTTP client and server
- Service Discovery: Consul and Eureka are supported, Route 53 planned
- Client Side Load Balancing: Integrated with Netflix Ribbon
- Support for serverless computing via AWS Lambda
- Developed via the annotations from Java and the powerful AST transformations from Groovy.
Graeme also commented the roadmap of Grails (4.0 version in Q4 2018). We were all just too excited with MicroNaut but he confirmed that OCI will still evolve Grails (with MicroNaut integration), and that’s good news for everyone.
Getting right to it, @graemerocher shows off some cool stuff that @micronautfw can do with a demo @greachconf! #micronautfw #grailsfw #groovylang #greach18 pic.twitter.com/laViV7iJ0s
— Object Computing (@ObjectComputing) March 16, 2018
Reactive Microservices with MicroNaut, by Álvaro Sánchez-Mariscal (@alvaro_sanchez)
This was my first talk of the Saturday at Greach. After the hype with MicroNaut in the previous day, the room was packed full to hear more details about the new framework from Álvaro. Álvaro made a detailed technical explanation about MicroNaut, comparing some of the decisions to the ones with Spring/Grails.
He also made a live demo testing some of the capabilities: service discovery, load balancing, reactive and fault tolerant. He showed a demo project that will be released with the framework: a pet store composed with several microservices built in different technologies (Java and Groovy) and each of them connected to a different backend (PostgreSQL, Redis, Cassandra, Neo4J, etc.).
 
  
  GORM Reloaded – Data Services for the Win, by Graeme Rocher (@graemerocher)
Graeme gave another very good talk, this time about GORM Data Services. He explained a lot of improvements, mainly related to joins and multi-tenancy. It was very interesting, now in my project we are analyzing the approach for a bunch of multi-tenant data bases and the talk gave me some ideas. He offered two distinct modes to tackle the multi-tenancy problems: data partitioning and isolating connections/sessions. GORM supports both approaches perfectly.
I saw a lot of powerful features behind GORM Data Services, improving the performance and code maintenance, and simplifying amazingly the multi-tenant application development.
101 scripts that can save you the day, by Jorge Aguilera (@jagedn) and Miguel Ángel Rueda (@MiguelRuGa)
Jorge and Miguel Ángel offered a funny theatrical performance to show the advantages of their project (101 Scripts) offering dozens of very useful scripts made in Groovy for a lot of common tasks. I had already reviewed the project page (baked with JBake, my previous static site generator) and some of the scripts and I loved it. I hope I’d be able to contribute in the future, at least with some translations.
Surviving in a Microservices Environment, by Steve Pember (@svpember)
My last choice in Greach 2018 was to listen again to Steve Pember. This talk was focused on the technical and not technical choices and challenges in a microservices environment. Steve put the emphasis on three main topics (and I agree with him): infrastructure, architecture and team communication. He provided a valuable vision on this, with some useful insights. I’ll highlight one of them, related to team communication.
He reminded the audience Conway’s Law, with the assumption from his side (and I totally agree) that it’s completely real. If a company is not able to integrate all the required capabilities in its squads, it’ll be doomed to have knowledge silos and complex dependencies everywhere.
organizations which design systems ... are constrained to produce designs which are copies of the communication structures of these organizations. — M. Conway
 
  
  And that’s all. See you in Greach 2019!!

 
   
   
   
  