CJUG Presentations

This is the second (and probably last post) about my time with CJUG and CJUG presentations.

Note: I have edited this page several times, and I cannot get the formatting to look the way I want. WordPress does weird things with paragraphs in list items and spacing between list items no matter what I do. I originally exported from Org mode, and at one point I edited the HTML and pasted that it, and it still does not look the way I want. A few times I got it to look the way I want in the WYSIWYG editor, but it was different after I hit “Update”. For now I will just leave it. Perhaps it is time to look at something other than WordPress.

I downloaded the posts from the old CJUG blog, and kept them on my website for years. I have decided to get rid of those posts. Here I will make a few notes about the projects/frameworks that are still around and/or look interesting to me. You can still find the old CJUG blog at archive.org (you might have to use the side menu to look at the old posts). I did not attend any CJUG West presentations.

Before going through the old posts, I had this notion that CJUG had dwindled to nothing before I showed up. That is not entirely true. Until about 2008 there were a lot of people attending. They had some pretty big names come in: Gavin King, Martin Fowler, Marc Fleury. Then for a while it was pretty bare. Sometimes it was just me, a guy named Rakesh Vidyadharan (who was the acting president for several months) and the presenter. Sometimes Rakesh was the presenter. But there were some meetings at Loyola that had decent turnouts, sometimes a dozen people. Rakesh did a good job of building it back up and kept things going when nobody else would. The meeting where the presidency was handed off to me had a decent turnout. (This was also the day of the infamous meeting where we had to change buildings.) The handoff had to be postponed for a month.

Still, I think it is fair to say that before I took over attendance had gone down a lot. Most of the board and officers seemed to move on. One was getting his masters in CS (at Loyola). A couple of others went on to Rails (this was about the time Rails was setting the world on fire). After I started running it, we never had single-digit attendance again. All in all, I would say I did pretty well.

I think I got the job because nobody really wanted it. Java had lost some of its buzz. I have a blog post about the CJUG elections stating that 2 people applied for 4 positions. I think it was Homer Simpson who said the most beautiful phrase in the English language is “by default”.

Before I became President, I spoke to someone who spent a year in Salt Lake City. He told me that he got a lot of reminders about presentations in Salt Lake City, and not much from CJUG. I did start posting more to the list and the blog. Afterwards I always posted to the blog thanking people for attending, thanking the presenter (when it wasn’t me) and thanking any sponsors and our hosts.

I imagine that running a group now is a lot different. You can have meetings over Zoom or WebEx, so space and food are not a problem. Content is still a challenge.

  • 2006-02-21: Spring Web Flow at CJUG West. Honestly, I think I am done with Spring. I will say that Spring Boot looks interesting, and would probably solve a few pain points at my current job. If I do Java at another job, I would like to try other frameworks: Dropwizard, Javalin, Quarkus, Spark, Vert.x (which I am leery of since it is an Eclipse project), Web4J from the guy behind Java Practices, as well as a few mentioned later in this post.I took a few tutorials on Spring. They mentioned that a lot of Spring developers got tired of writing XML and they preferred writing Java code, so Spring started using annotations for configuration. Now it seems like in Spring you just mess with annotations instead of XML or writing Java.
  • 2006-06-01: Lucene at CJUG West.
  • 2006-07-06: Rich Client Development at CJUG West. I do not know a whole lot about Eclipse Rich Client Platform. Desktop apps have declined in use in the past decade. On the other hand, there is always somebody using something, and like COBOL and FORTRAN, there are probably more desktop apps and developers out there than people think. Eclipse started in IBM, and at this point I am leery of IBM. IBM was Microsoft before Microsoft: They structure everything to maintain your dependence on them. Even when they open source a project and it leaves the nest, it is more complicated than it needs to be.There are other platforms for desktop apps that can run on mulitple OSes: Free Pascal and Lazarus, and Google’s Flutter. There is also Gambas, an IDE for BASIC, and there is a company called DevExpress which sells Delphi components. Even JavaFX is still around. Now that I am starting to use Emacs more, perhaps I will have less need for desktop apps.
  • 2006-09-07: Practical Pair Programming at CJUG West. I do not have a lot of experience with Agile. I was on a project that used Scrum. There were a lot of charts and numbers and forms to fill out. To boil it down to a sentence: Agile is about technology teams making their own process and adjusting, it, while Scrum is the business pinheads doing what they always do: making it about metrics and numbers and generally missing the point. On the Scrum project, there was a lot of “grooming” of stories. It involved a lot of time sitting in a hot, crowded room that had more chairs than necessary.The first time I heard about Agile was at a CJUG presentation (which was before the blog posts I was able to save) and the presenter said one thing he loved about Agile was that it used terms people understand: People know what a story is, but not what a “use case” is. But I don’t think Agile people use words that people understand. They use words people understand and give them different meanings, which I think is even worse. The uses of the words “Sprint”, “Story”, “Epic”, “Grooming” and “Spike” in scrum/agile are different than they are in other contexts.

    Like REST and Roy Fielding’s dissertation, the Agile Manifesto is not an ISO standard. You can do whatever you want and call yourself “Agile”. I think a lot of the practices associated with Agile are from Extreme Programming (aka XP). I know the term “Extreme Programming” was coined by Kent Beck, who also signed the Agile Manifesto. What is Agile and what is XP is kind of fluid.

    The Agile/XP practice that I got the most value from was pair programming, yet it was the one we did the least. It never seemed to be the default. It was a fallback when someone was stuck. But when I paired with someone, we were usually able to solve in less than 20 minutes something I had struggled with for far longer. They did not give me the answer, we just figured it out more quickly together. I guess measuring output is more important to some people than producing it.

  • 2006-11-02: JRuby at CJUG West. I have tried JRuby, and I do not like it. I know that some Ruby people like it because Ruby was not able to handle multiple threads (I do not know if that is still true). Coming at it from the Java side, I honestly do not see the point.I went to the GR8 Conf a few years ago, and Guillaume Laforge told some of us about the origins of the project and how he got involved. He was the head of the project for several years but did not initiate it. He said one of the initiators was trying out Python on their laptop at an airport. Python has an interactive shell like Ruby, and he thought, “We need something like this in the Java space.” And that is how Groovy was started. So if you want an agile, dynamic scripting language on the JVM that can also be used to build large applications, that is what Groovy is for. It is made to work with Java. JRuby is like sticking a square peg into a round hole. I always got the feeling that Java shops that use JRuby use it to impress their Ruby friends. News flash: They won’t care, and you are making you life more difficult than you need it to be.
  • 2006-12-07: Spring AOP at CJUG West. There was a later presentation on aspect-oriented programming at a downtown meeting, and I think I attended that one. I will leave comments there.
  • 2007-01-16: Network Attached Memory at CJUG Downtown with Ari Zilka. Ari Zilka founded Terracotta. He is a really smart guy; I should look him up and see what he is doing. He also spoke at CJUG downtown again in 2010 about Ehcache. This was around the time MongoDB was the big thing because “SQL is not web-scale”. Ari said that the people who think SQL cannot scale really do not know what they are doing. (Perhaps we should call him “Ari Zinger”.) Granted, he was at CJUG to talk his book, and MongoDB is still around, but the “NoSQL” hype has died down. Why learn a whole new database technology when you can use some open source projects to help you scale?I have heard the idea that a lot of people would not need extra tech for their relational databases if they knew the relational model better quite a few times. That is one thing on my ever-expanding to-do list. I honestly do not know if I could explain the different levels of database normalization.
  • 2007-03-10: Enterprise Search Technology at CJUG Downtown. This was about internal search for a corporation. The speaker was from a company named Dieselpoint.
  • 2007-04-17: Tomcat Security at CJUG Downtown.
  • 2007-05-15: Echo2: Ajax-based Web Development Framework at CJUG Downtown. The repo for Echo3 has not been updated since 2018, so I think this one is dead.
  • 2007-06-07: Another presentation about Eclipse RCP at CJUG West by the same guy who did the last one.
  • 2007-06-19: Agile and Secure: Can We Be Both? at CJUG Downtown.
  • 2007-07-17: JBoss Seam at CJUG Downtown. According to the Seam website, this project is dead.I had a job using Seam. I hated it. The boss said he was disappointed that I was not more involved in making decisions about their product. I said nothing because my only suggestion was to stop using Seam, and I knew he wasn’t going to do that. I remember one day one of the co-founders and I spent several minutes trying to get the other co-founder to grasp the concept of the sunk-cost fallacy. But looking back I cannot remember which one got it and which one did not.

    I do not remember what I did not like about Seam. I am just glad it’s dead. If you ever wondered why nobody cares about Gavin King any more, I think Seam is part of the reason.

  • 2007-08-21: Google Web Toolkit at CJUG Downtown. My understanding is that with GWT you can write the front-end of your app in Java, and it will transpile into Javascript. Granted, the site does not use any form of the word “transpile”, and I do not think I encountered the word “transpile” until just a few years ago, but that sounds like what is happening.Honestly I do not know why GWT is more popular. And I do not get why JavaScript is so popular. Why so many people think EVERYTHING has to be in Javascript. A lot of people only seem to know Javascript. It is like a dumbing down of technology. Javascript is to a lot of technology people what Microsoft is to a lot of business pinheads: It is the one thing they cling to, and the rules are different for it than they are for everything else, just because * * jazz hands * *

    It is bizarre to me the way some people complain about Java, and the semicolons, yet Javascript which stacks braces, parentheses and semicolons (and is so awful that people build entire languages to shield them from it) gets a total pass.

    Anyway, GWT looks interesting, and it is something I will keep an eye on. I think Vaadin uses GWT.

  • 2007-09-06: Dynamic Languages and the JVM at CJUG West: JRuby, Groovy and Rhino.
  • 2007-09-18: Groovy/Java Integration at CJUG Downtown. This presentation was given by Jeff Brown of Object Computing, one of the companies contributing to Grails.
  • 2007-10-16: Grails at CJUG Downtown.
  • 2007-11-20: Overview of Coherence Data Grids at CJUG Downtown. The presenter was Cameron Purdy. Oracle Coherence is now open source. From the Github page: Coherence is a scalable, fault-tolerant, cloud-ready, distributed platform for building grid-based applications and reliably storing data.
  • 2007-12-18: Aspect-Oriented Programming and Software Design in Java and AspectJ at CJUG Downtown. I never quite got AOP. I understood it when I was reading about or hearing a lecture, but it never quite stuck. When I learned about metaprogramming in Groovy, then the ideas seemed to stick. AOP uses a lot of terms that it either makes up and do not really make any sense (“join point”, “point cut”), or like Agile/Scrum they use everyday words and give it a different meaning (“advice”) which makes it all less clear. In Groovy the terminology is more verbose but at the same time more clear. I prefer clear over concise.
  • 2008-01-15: JavaFX Script at CJUG Downtown. JavaFX is still around, but JavaFX Script has been discontinued.
  • 2008-02-19: JSR 170: Content Repository for Java technology API at CJUG Downtown.
  • 2008-05-20: Object Databases at CJUG Downtown.
  • 2008-06-05: Inside Spring Batch at CJUG West. I think this was the last CJUG West presentation.
  • 2008-07-15: Another presentation on JRuby at CJUG Downtown.
  • 2008-07-29: Cloud Dreams: From Ideas to Innovation at CJUG Downtown. I think this is one of the first times I heard about Amazon Web Services.
  • 2008-08-19: An Architect’s View of Domain Specific Language (DSL) for Enterprise Applications and Services at CJUG Downtown. The presenter was from a now-defunct company called Skyway Software. They had a RAD tool based on Eclipse that you could use to quickly build web applications.
  • 2008-09-16: OSGi – Why Java Modularity Matters at CJUG Downtown.
  • 2008-10-21: Open Source Barometer at CJUG Downtown. This was a presentation by Alfresco Software about how their customers use open source. As of 2022-04-23, you can still read about here and here.
  • 2008-11-18: Zero Turnaround in Java at CJUG Downtown. This was about the product now known as JRebel. It allows you to deploy Java class changes immediately without a full restart. I think Spring Boot also has this capability.
  • 2008-12-16: The Seductions of Scala at CJUG Downtown. No comment.
  • 2009-01-20: Maintaining agility on a mature project at CJUG Downtown. This is when I found out that “spike” is another word that agile people use differently.
  • 2009-02-17: iPhone SDK: Java Developers Perspective at CJUG Downtown. From the summary: ” This presentation will introduce Objective-C/Cocoa to Java Developers and show how Java developers can get productive with the technology very quickly.”. This really had nothing to do with Java. Whatever the opposite of “Peak CJUG” is, this might be when we hit it.
  • 2009-03-17: Exploring Terracotta at CJUG Downtown. This presentation was by Alex Miller. Back then he was with Terracotta. Now he is with Coginitect working on Clojure.
  • 2009-04-21: Scripting on the JVM at CJUG Downtown. Yet another JRuby/Rhino/Jython talk.
  • 2009-05-19: Don’t Do This! How Not to Write Java Software at CJUG Downtown. Here are some bad ideas from the summary:
    • This code will never be used in a multithreaded environment.
    • Just because you’re paranoid doesn’t mean you shouldn’t check for nulls!
    • Comment everything!
    • I’ll create my own JDBC Connection, thank you very much!
    • Why retest when you can copy and paste?
    • Why use two methods when one will do?
    • Here, have an exception.
  • 2009-06-16: OpenSSO and Identity Federation at CJUG Downtown.
  • 2009-07-21: Google App Engine for Java: welcome to the cloud at CJUG Downtown.
  • 2009-08-05: Programming Clojure at CJUG Downtown. The presenter was Stuart Halloway. Despite my current interest in Clojure, I do not recall attending this one. There was another presentation later that month, so perhaps this one was thrown together very suddenly.
  • 2009-08-18: GridGain – Open Cloud Platform at CJUG Downtown. You can find the GridGain page here. I made a blog post on 2009-08-26 that the handover of the CJUG presidency was postponed since one of the current acting officers was not there.
  • 2009-09-15: Flex and Java at CJUG Downtown. The presenter was James Ward. This is when the CJUG presidency was handed over, and this was the disastrous meeting where we had to go to another building halfway through. Adobe gave Flex to the Apache project, and the last update was in 2017. Flex was based on Flash, so I am guessing it is dead. This was not anti-Peak CJUG. This was anti-anti-anti-Peak CJUG.
  • 2009-10-20: Testing the Web Layer at CJUG Downtown. Another not-Peak CJUG moment. The speaker was from No Fluff Just Stuff. Smart guy, but not a Java guy, which is kind of an issue for a Java group. No Fluff sent us a speaker every year and let us raffle off a ticket to that year’s Chicago event. That year they chose the speaker, and we had to choose the topic, none of which were JVM related. Back then NFJS sold itself as “Like JavaOne, but it’s cheaper and it comes to you”, so getting a non-Java speaker was a bit frustrating. Now they have some conferences that are focused on JavaScript, but I think “Woodstock for Java without the mud” is still their main focus.
  • 2009-11-17: Java Content Repository (JSR 170, 283) at CJUG Downtown.
  • 2009-12-15: JavaFX at CJUG Downtown. There was also a presentation by a recruiter on interviewing. I had hoped to have more presentations on all the things tech people need to do but don’t want to think about, but that did not work out too well.
  • 2010-01-19: Lightning Talks: JackRabbit Configuration, Apache James, JUnit Testing Tricks, More? at CJUG Downtown. Three board members gave lightning talks. Rakesh Vidyadharan gave a follow-up to his November talk; he spoke about JackRabbit configuration and deployment models. I spoke about configuration of the Apache James email server and the future direction of the project. Jim Breen reviewed the proposal to add closures to JDK 7.
  • 2010-02-16: Instant Messaging and DSLs in Java at CJUG Downtown. This was hosted by a company called Dotomi, which I think was in the West Loop. The speaker was Yair Goldfinger. He was one of the original developers of ICQ, one of the first instant messaging applications. He spoke about that as well as DSLs in Java.They made ICQ because back in those days people still used modems over phone lines. If you were on the computer, you could not be on the phone. So they made ICQ so they could chat while online. I honestly think he lifted some of his DSL presentation from this InfoQ article dated 2008-02-19. His presentation is the first time I had heard of fluent interfaces (check) and I am pretty sure one of his examples was about booking a vacation at the Paris Hilton (check). Maybe the authors got their information from him, or they had worked at Dotomi, but I am pretty sure the article and the presentation have some of the same material.
  • 2010-03-16: Agile All The Way Down and Update On the Oracle/Sun Merger at CJUG Downtown. Earlier that day Oracle had a seminar about their merger with Sun and how it would affect their product lines. I went, took notes, and gave a presentation about it. There was also a presentation by Bjorn Freeman-Benson about New Relic.
  • 2010-04-20: Tomcat 6 at CJUG Downtown. This was the meeting where we were in a different room that had a very large projection screen but could not get a projector. This is when I decided that we needed to find a different location than Loyola. The speaker did well under the circumstances.
  • 2010-05-18: Google DataStore API and App Engine Deployment at CJUG Downtown. One speaker covered the low-level APIs, and another covered deployment.
  • 2010-06-15: Liferay Caching at CJUG Downtown. I think this was the first meeting at ThoughtWorks.
  • 2010-07-20: JavaFX 1.3 at CJUG Downtown. This presentation was given by Sten Anderson, who also gave the JavaFX presentation on 2009-12-15. He mostly talked about the new features in 1.3.
  • 2010-08-17: ActiveJDBC at CJUG Downtown. The presenter was Igor Polevoy. ActiveJDBC is a Java implementation of the Active Record pattern. It is part of JavaLite, “a cohesive collection of frameworks designed from ground up to add pleasure back to your daily life.” It is still used and still maintained. Here is a link to the presentation. This is another technology I will keep an eye on.
  • 2010-09-21: What’s Brewing in Java at CJUG Downtown. I think this was the first presentation at CME. The content was about changes in the upcoming version of Java. You know it was good, because it was Venkat.
  • 2010-10-21: High-Performance Scalability for Enterprise Applications with Enterprise Ehcache at CJUG Downtown. This was Ari Zilker’s second time speaking at CJUG. I think this is when he told me a lot of people using NoSQL think they have to because they do not understand RDBMSs very well. He was probably talking about document databases like MongoDb, since some NoSQL technologies like graph databases are never touted as replacements for relational databases.
  • 2010-11-16: Intro to Hadoop at CJUG Downtown. Back in the day when “MapReduce” was an exotic procedure. Again, this is a time when bad terminology makes a simple concept harder than it needs to be. I think “map” is a bad name for what the map function does (I think “apply-to-all” is better), and “reduce” is an even worse name (surpassed in badness only by “fold“, which is the same thing as reduce; I think “accumulate” or “aggregate” are better).
  • 2011-01-18: What’s new in Java EE6 at CJUG Downtown.
  • 2011-02-15: Drools at CJUG Downtown. I use another rules engine at my job, so I might look into Drools. One issue is I think you have to run it in a web app. At least the Drools docs only talk about using it that way. Drools is one of those JBoss projects where you have to do five things in order to do the one thing you really want to do. I think Clara can handle rules outside of a web app.
  • 2011-03-15: Android at CJUG Downtown. I gave this presentation. You can find it here. I did it because I wasn’t able to get anything lined up in time. Sometimes you have to do that when you run a group.
  • 2011-04-11: Groovy on Grails at CJUG Downtown.
  • 2011-05-17: Java and R at CJUG Downtown. This was a presentation on using Java with the R language. It seems like R has been supplanted by either deep learning libraries in various languages (many of which are wrappers around C or Fortran libraries) or Julia.
  • 2011-06-21: Arquillian at CJUG Downtown. The speaker was Andrew Lee Rubinger. Arquillian is an integration testing framework that tests J2EE apps without using mocks or requiring a full deployment. Like many JBoss projects, some of the links to their own sites are dead. I might suggest this at work. I think this might be something we need. Their website does not state this, but I think the etymology of “Arquillian” is that it is a species from the film Men In Black.
  • 2011-07-19: Play Framework at CJUG Downtown. The Play Framework was a Java web framework that uses REST and convention over configuration. It is a stateless, asynchronous, full-stack, pure Java framework that aims to help web developers have more fun and be more productive. Then Lightbend decided to make it all Scala. There is a Java web framework called Ninja that I think came about because some users of Play did not like Scala. (A note to Scala developers: A lot of people do not like Scala, and never will. Stop trying to make us do stuff in Scala.)The speaker was Jeff Schwartz. He gave a presentation about Play at another meetup, and I asked him if he would be willing to give the presentation to CJUG.
  • 2011-08-16: ActiveWeb at CJUG Downtown. This was another presentation by Igor Polevoy. ActiveWeb is the web framework component of JavaLite. Check out the presentation, see the lite.
  • 2011-09-20: State of Java at CJUG Downtown by Roger Brinkley. He was a Java developer advocate. I am not clear what he is doing these days. Based on his Twitter feed, I am guessing he is retired.
  • 2011-10-18: Gradle: Bringing Engineering Back to Builds at CJUG Downtown by Tim Berglund. This was the first time I had heard about Gradle. I used to use Gradle when I was into Groovy. I liked it. You don’t need it for Clojure, so I don’t use it much anymore. They went to Kotlin and all my scripts broke, and they changed a lot of the API function names. I am not saying I will never touch it again, but changing the names of an API that was notoriously difficult was pretty dumb. It’s not really any different, just the names are different.
  • 2011-11-15: Security In Java at CJUG Downtown.
  • 2012-01-17: Tips and Tricks for Writing Low Latency Java Applications at CJUG Downtown. This was well-attended. The presenter was Charlie Hunt, who at the time was JVM Performance Engineer at Oracle. He wrote a book on Java performance. He offered to sign any copies people brought to the presentation.
  • 2012-03-20: Graph Traversals in Neo4j with Gremlin Java at CJUG Downtown. From the presentation: Graph databases are a NoSQL/polyglot persistence solution that provide a natural way to model complex, interrelated data.
  • 2012-04-17: Real World Groovy on Grails at CJUG Downtown. This was at Jak’s Tap instead of CME.
  • 2012-05-15: Build your own CMS with Apache Sling at CJUG Downtown. This was at the Sears Office (not the building now known as Willis Tower). The presenter was Bob Paulin, who helped run CJUG after I left.
  • 2012-06-19: JavaFX at CJUG Downtown with Roger Brinkley.
  • 2012-07-17: Spring Data at CJUG Downtown. The presenter was Andrew C. Oliver who wrote the POI library.
  • 2012-08-21: CDI meets GWT within Errai at CJUG Downtown. I have the announcement in my “Sent” folder, but I have no memory of it, and I do not remember ever hearing about the Errai Framework.
  • 2012-09-18: Embedded Java at CJUG Downtown. This is the last meeting for which I sent out an announcement, and the last I attended.


Image from The Codex of Fernando I and Doña Sancha, aka Beatus Facundus, an 11th century manuscript manuscript of ‘Commentary on the Apocalypse‘, written in the 8th century by Beatus of Liébana; manuscript created at monastery of Santo Toribio de Liébana  (Wikipedia page here), currently housed at the National Library of Spain; manuscript information here. Image from World Document Library, licensed under CC BY-NC-SA 4.0.

There are 4681 words in this article.