<?xml version="1.0" encoding="UTF-8"?><!-- generator="wordpress.com" -->
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	>

<channel>
	<title>theserverside &amp;laquo; WordPress.com Tag Feed</title>
	<link>http://en.wordpress.com/tag/theserverside/</link>
	<description>Feed of posts on WordPress.com tagged "theserverside"</description>
	<pubDate>Fri, 04 Dec 2009 07:21:04 +0000</pubDate>

	<generator>http://en.wordpress.com/tags/</generator>
	<language>en</language>

<item>
<title><![CDATA[Article about CP2JavaWS 0.85 at TheServerSide]]></title>
<link>http://cjedaudio.wordpress.com/2009/08/07/article-about-cp2javaws-0-85-at-theserverside/</link>
<pubDate>Fri, 07 Aug 2009 14:37:33 +0000</pubDate>
<dc:creator>Jerome Denanot</dc:creator>
<guid>http://cjedaudio.wordpress.com/2009/08/07/article-about-cp2javaws-0-85-at-theserverside/</guid>
<description><![CDATA[The article introducing the new 0.85 version of CP2JavaWS Cappuccino/Java bridge is now online at th]]></description>
<content:encoded><![CDATA[<div class='snap_preview'><p>The article introducing the new 0.85 version of CP2JavaWS Cappuccino/Java bridge is now <a href="http://www.theserverside.com/news/thread.tss?thread_id=55381">online</a> at theserverside.com.</p>
</div>]]></content:encoded>
</item>
<item>
<title><![CDATA[InfoQ x TheServerSide]]></title>
<link>http://blpsilva.wordpress.com/2008/03/31/infoq-x-theserverside/</link>
<pubDate>Tue, 01 Apr 2008 01:02:08 +0000</pubDate>
<dc:creator>blpsilva</dc:creator>
<guid>http://blpsilva.wordpress.com/2008/03/31/infoq-x-theserverside/</guid>
<description><![CDATA[Atenção, este blog foi migrado para: http://brunopereira.org Alguns anos atrás o TheServerSide era o]]></description>
<content:encoded><![CDATA[<div class='snap_preview'><p><strong>Atenção, este blog foi migrado para: <a href="http://brunopereira.org" target="_self">http://brunopereira.org</a></strong></p>
<p>Alguns anos atrás o <a href="http://www.theserverside.com" target="_blank">TheServerSide</a> era o meu site de tecnologia (e Java) preferido em geral. Muitas discussões interessantes rolavam por lá, tinha os Tech Talks, os simpósios, artigos, etc. Era muito bom para acompanhar o que estava acontecendo de importante na nossa área.</p>
<p>De uns tempos para cá, a qualidade do site despencou, e agora praticamente só noticiam coisas do tipo &#8220;XYZ was released&#8221;. Onde XYZ podia ser qualquer coisa. Framework, servidor de aplicações, biblioteca, livro, qualquer coisa. Muito raramente eu vejo alguma coisa que me motive a ler mais do que o título.</p>
<p>Já o <a href="http://www.infoq.com" target="_blank">InfoQ</a> traz diariamente várias coisas pelas quais me interesso. Tem tanto conteúdo de qualidade que eu não consigo acompanhar a velocidade de divulgação das coisas. E isso é ótimo, pois sempre sei que encontrarei coisas boas para ler por lá. Uma coisa que eu  gosto no InfoQ é que nele eu vejo muita coisa boa além de Java. Conteúdo sobre metodologias de desenvolvimento, outras linguagens, outras plataformas. Novidades que podem me agregar bastante coisa. Quase todas as vezes que sai alguma notícia &#8220;XYZ was released&#8221; no TheServerSide eu não ligo a mínima pro que tá sendo lançado. E se é algo que me interessa, eu rapidamente viria a saber do lançamento em algum outro lugar.</p>
<p>Uma coisa que o InfoQ e o TheServerSide têm em comum é que ambos foram fundados pelo Floyd Marinescu. O TheServerSide foi fundado no final de 99, e o InfoQ no começo de 2006. Floyd Marinescu deixou o TSS em agosto de 2005, então muito provavelmente sua saída teve significativo impacto na qualidade do site. Atualmente o TSS é o 4o site da minha lista de preferências, atrás do InfoQ, <a href="http://www.artima.com" target="_blank">Artima</a> e <a href="http://www.ibm.com/developerworks/" target="_blank">DeveloperWorks</a>. Mas do jeito que a coisa está indo não sei se ele vai conseguir sobreviver por muito tempo.</p>
<p>Especialmente depois que eu comecei a escrever artigos pra <a href="http://www.javamagazine.com.br" target="_blank">Java Magazine</a>, eu passei a reparar bastante nas formas de exposição de conteúdo técnico. Conseguir cativar um público de alto nível é muito difícil. Desenvolvedores, arquitetos e gerentes de software não têm muito tempo para desperdiçar, pois a quantidade de coisas a estudar é enorme. Para conseguir que um público assim leia o que você se propõe a escrever, você precisa escrever de forma precisa, mas também estimulante. Se você simplesmente jogar informações nos leitores, não vai conquistar o apreço deles e eles não continuarão acompanhando as suas publicações.</p>
<p>Uma coisa que eu tento fazer nos meus artigos é sempre mostrar a motivação por trás do que estou falando. Especialmente se for um tema polêmico ou controverso, é fundamental estimular a discussão das pessoas. Ninguém gosta de ouvir a &#8220;Voz do Brasil&#8221;, mas conheço muitas pessoas que gostam de ouvir a Band News, com a apresentação do Ricardo Boechat (eu sou uma dessas pessoas). Talvez as notícias presentes nos 2 programas sejam as mesmas. Entretanto, eu sempre me interesso pelas opiniões do Boechat, e eu nunca ouvi coisa mais enfadonha que a Voz do Brasil.</p>
<p>Comecei falando do InfoQ e terminarei falando sobre o mesmo. Este site é um belo exemplo de conteúdo técnico de qualidade, com temas que realmente atraem os leitores mais exigentes. O Floyd Marinescu parece uma excelente referência de como oferecer conteúdo para a nossa área.</p>
<p>Aos poucos venho começando a escrever meus artigos e também aqui no blog, e meu objetivo será sempre a linha do InfoQ. Conteúdo de qualidade com inteligência por trás. Quero escrever coisas que eu gostaria de ler se fosse outra pessoa escrevendo. Escrever bem é muito mais do que escrever corretamente. Espero conseguir atingir estes objetivos, e se possível ajudar a Java Magazine a ganhar cada vez mais qualidade. E é claro que sempre vou receber muito bem as críticas e opiniões de quem quiser colaborar nesta empreitada <img src='http://s.wordpress.com/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
</div>]]></content:encoded>
</item>
<item>
<title><![CDATA[TSS Java Symposium Best Talk: Brian Goetz tackles Java Performance Myths]]></title>
<link>http://arsenalist.wordpress.com/2007/03/26/tss-java-symposium-best-talk-brian-goetz-tackles-java-performance-myths/</link>
<pubDate>Mon, 26 Mar 2007 18:49:00 +0000</pubDate>
<dc:creator>Arsenalist</dc:creator>
<guid>http://arsenalist.wordpress.com/2007/03/26/tss-java-symposium-best-talk-brian-goetz-tackles-java-performance-myths/</guid>
<description><![CDATA[Brian Goetz&#8217;s talk on Java Performance Myth had to be the funniest of them all. Laughing at C ]]></description>
<content:encoded><![CDATA[<div class='snap_preview'><p>Brian Goetz&#8217;s talk on Java Performance Myth had to be the funniest of them all.  Laughing at C programmers who insist on writing object pools and backwards for loops is both fun and easy.  Let&#8217;s all write &#8220;clean, dumb code&#8221; was Goetz&#8217;s plea to everybody and insisted the JVM doesn&#8217;t suck and is smarter than those sorry, mangled-up minds that think public getters/setters is an overhead.   Basically, the JVM puts some serious thought in the optimization of compiled code including dead code elimination, optimized garbage collection and resource allocation.</p>
<p>His assault on all those pricks who write micro-benchmarks and happily conclude that X is faster than Y was also refreshing.  A counter-example goes a long way in debunking a myth and that&#8217;s what he resorted to when showing that in some cases it might be faster to compute 1+1 by doing 1+2-1.  Pure nonsense, it turns out the JVM remembers execution paths and the order of operation does matter.  Conclusion: most micro-benchmarks are useless since they ignore JVM optimizations and runtime correction.</p>
<p>My favorite part of the talk was a production code example he gave when iterating an array, I reproduce it here for it&#8217;s humorous value:</p>
<pre>int i = 0;
try {
  while (true)
  doSomething(array[i++]);
} catch (ArrayIndexOutOfBoundsException e) {
  /* exit loop */
}</pre>
<p>Pure genius eh?</p>
<p>I&#8217;m starting to like this guy, he&#8217;s saying Java should be faster than C and since this is already true for resource allocation and memory management, it should be completely true in ten years when those JVM dudes figure out some more ways of stealing CPU cycles.  Here&#8217;s a great example of some JVM optimization: Virtual methods have been a performance hit since the object hierarchy needs to be searched at runtime and since every method in Java is overridable and thus virtual, the JVM must do some searching. Or does it? Well, it doesn&#8217;t.  If a method is not overridden, the JVM will treat it as mono-morphic and optimize it accordingly making it inline.  Same goes true for declaring final methods &#8211; it doesn&#8217;t help, just clutters up the code base.</p>
<p>I&#8217;m glad that Vector has finally received a reprieve and can finally be used in Java code (local variables only please) without suffering embarrassment or humiliation.  Synchronization for local variables is much different than members and Goetz authorized the use of Vectors with reckless abandon.  I&#8217;m going to go and change all my ArrayLists to Vectors right now.  No seriously, its good to know there&#8217;s no penalty where there shouldn&#8217;t be.  JVMs are smart enough to make unshared synchronized collections as fast as unsychronized ones.  But this leads me to a deeper question, why would you have an unshared synchronized collection, wouldn&#8217;t that be a paradox?  Besides the point.</p>
<p>Poor Java does suffer from this label that it&#8217;s slow as molasses, but times have changed and so has the JVM, what might have been true 6 years ago is probably not anymore.  Goetz&#8217;s claim that performance advice has a finite shelf life is 100% bang-on.  The JVM now keeps multiple copies of compiled code and can swap it out based on runtime patterns, that&#8217;s a feature that .NET loves to pride itself on but it&#8217;s hardly even mentioned in the Java world.</p>
<p>Clever code is NOT faster code so stop trying to be a smart-ass and just write simple Java.  Even if you have to make your code ugly to increase performance by a nanosecond, there&#8217;s a great chance that the next version of the JVM will make your efforts redundant. So unless you have some serious performance requirements, there&#8217;s no reason to write code that looks like shit.</p>
<p><strong>Random Notes:</strong> International Terminal sucks, Blackjack is not easy, They make you walk through the casino to get to your room, Air Canada staff are idiots, Airport security is lax</p>
</div>]]></content:encoded>
</item>
<item>
<title><![CDATA[TSS Java Symposium Best Talk: Brian Goetz tackles Java Performance Myths]]></title>
<link>http://depressedprogrammer.wordpress.com/2007/03/26/tss-java-symposium-best-talk-brian-goetz-tackles-java-performance-myths/</link>
<pubDate>Mon, 26 Mar 2007 18:49:00 +0000</pubDate>
<dc:creator>Arsenalist</dc:creator>
<guid>http://depressedprogrammer.wordpress.com/2007/03/26/tss-java-symposium-best-talk-brian-goetz-tackles-java-performance-myths/</guid>
<description><![CDATA[Brian Goetz&#8217;s talk on Java Performance Myth had to be the funniest of them all. Laughing at C ]]></description>
<content:encoded><![CDATA[<div class='snap_preview'><p>Brian Goetz&#8217;s talk on Java Performance Myth had to be the funniest of them all.  Laughing at C programmers who insist on writing object pools and backwards for loops is both fun and easy.  Let&#8217;s all write &#8220;clean, dumb code&#8221; was Goetz&#8217;s plea to everybody and insisted the JVM doesn&#8217;t suck and is smarter than those sorry, mangled-up minds that think public getters/setters is an overhead.   Basically, the JVM puts some serious thought in the optimization of compiled code including dead code elimination, optimized garbage collection and resource allocation.</p>
<p>His assault on all those pricks who write micro-benchmarks and happily conclude that X is faster than Y was also refreshing.  A counter-example goes a long way in debunking a myth and that&#8217;s what he resorted to when showing that in some cases it might be faster to compute 1+1 by doing 1+2-1.  Pure nonsense, it turns out the JVM remembers execution paths and the order of operation does matter.  Conclusion: most micro-benchmarks are useless since they ignore JVM optimizations and runtime correction.</p>
<p>My favorite part of the talk was a production code example he gave when iterating an array, I reproduce it here for it&#8217;s humorous value:</p>
<pre>int i = 0;
try {
  while (true)
  doSomething(array[i++]);
} catch (ArrayIndexOutOfBoundsException e) {
  /* exit loop */
}</pre>
<p>Pure genius eh?</p>
<p>I&#8217;m starting to like this guy, he&#8217;s saying Java should be faster than C and since this is already true for resource allocation and memory management, it should be completely true in ten years when those JVM dudes figure out some more ways of stealing CPU cycles.  Here&#8217;s a great example of some JVM optimization: Virtual methods have been a performance hit since the object hierarchy needs to be searched at runtime and since every method in Java is overridable and thus virtual, the JVM must do some searching. Or does it? Well, it doesn&#8217;t.  If a method is not overridden, the JVM will treat it as mono-morphic and optimize it accordingly making it inline.  Same goes true for declaring final methods &#8211; it doesn&#8217;t help, just clutters up the code base.</p>
<p>I&#8217;m glad that Vector has finally received a reprieve and can finally be used in Java code (local variables only please) without suffering embarrassment or humiliation.  Synchronization for local variables is much different than members and Goetz authorized the use of Vectors with reckless abandon.  I&#8217;m going to go and change all my ArrayLists to Vectors right now.  No seriously, its good to know there&#8217;s no penalty where there shouldn&#8217;t be.  JVMs are smart enough to make unshared synchronized collections as fast as unsychronized ones.  But this leads me to a deeper question, why would you have an unshared synchronized collection, wouldn&#8217;t that be a paradox?  Besides the point.</p>
<p>Poor Java does suffer from this label that it&#8217;s slow as molasses, but times have changed and so has the JVM, what might have been true 6 years ago is probably not anymore.  Goetz&#8217;s claim that performance advice has a finite shelf life is 100% bang-on.  The JVM now keeps multiple copies of compiled code and can swap it out based on runtime patterns, that&#8217;s a feature that .NET loves to pride itself on but it&#8217;s hardly even mentioned in the Java world.</p>
<p>Clever code is NOT faster code so stop trying to be a smart-ass and just write simple Java.  Even if you have to make your code ugly to increase performance by a nanosecond, there&#8217;s a great chance that the next version of the JVM will make your efforts redundant. So unless you have some serious performance requirements, there&#8217;s no reason to write code that looks like shit.</p>
<p><strong>Random Notes:</strong> International Terminal sucks, Blackjack is not easy, They make you walk through the casino to get to your room, Air Canada staff are idiots, Airport security is lax</p>
</div>]]></content:encoded>
</item>
<item>
<title><![CDATA[TSS Java Symposium Review Part 3: Filthy Rich GWT Clients using SBA]]></title>
<link>http://depressedprogrammer.wordpress.com/2007/03/26/tss-java-symposium-review-part-3-filthy-rich-gwt-clients-using-sba/</link>
<pubDate>Mon, 26 Mar 2007 17:48:56 +0000</pubDate>
<dc:creator>Arsenalist</dc:creator>
<guid>http://depressedprogrammer.wordpress.com/2007/03/26/tss-java-symposium-review-part-3-filthy-rich-gwt-clients-using-sba/</guid>
<description><![CDATA[There has to be a better way than to write Java code and have it &#8220;compile&#8221; to JavaScript]]></description>
<content:encoded><![CDATA[<div class='snap_preview'><p><strong>There has to be a better way than to write Java code</strong> and have it &#8220;compile&#8221; to JavaScript for anybody to use AJAX functionality.  Bruce Johnson&#8217;s cry to the crowd that there&#8217;s absolutely no performance hit in doing so was falling on on deaf ears until his claim of the &#8220;perfect caching&#8221; implemented by GWT.  A statement that sent murmurs through the crowd and promptly encouraged everyone to grab their session evaluation sheet and circle the 1 in all categories.</p>
<p>All this talk of leveraging the Java language is making me nauseous.  I can&#8217;t help but think of the poor bastard who&#8217;s been developing in JavaScript all these years and has pretty much become a guru at it, only to realize that he&#8217;s been using the wrong language all along.  Basically they want your application to be one page and every transition happens using GWT &#8211; talk about being tied to a product!  Not that Google&#8217;s going bankrupt anytime soon but once you go to GWT, you really, really can&#8217;t go back.  GWT seems like a decent product but I&#8217;m wondering whether adopting it early in a project isn&#8217;t &#8220;slipping into poorly planned AJAX development&#8221; as Johnson claims people are doing.</p>
<p>So what happens if your application becomes too big and increases in size, why you GZip it of course! Give Google credit for thinking outside the box and adopting a Maven&#8217;ish approach to developing in JavaScript &#8211; compile, package, deploy.  They even give you an embedded browser of sorts to use during development where your edited Java code is &#8220;deployed&#8221; using a simple refresh.  All those Google aficionados are free to wet their pants at the sight of GWT, but they&#8217;d be a fool to not try out Scriptaculous or Dojo first.  There&#8217;s no reason to kill a bird with a cannon.</p>
<p><strong>Nati Shalom and some programmer talked about Space Based Architecture</strong> and it&#8217;s Spring Integration until he was blue in the face and the audience was close to tears.  The coming up lunch break didn&#8217;t help matters.  Yes, you guessed it, there&#8217;s also a &#60;space&#62; XML namespace in Spring2 making declarative SBA very easy to use and abuse.  The concept of SBA is simple enough to wrap your head around but if your demo consists of showing the EXTREMELY verbose logging of three JVM&#8217;s at the same time, things are going to get hairy.  At least have the decency to turn the log level down or maybe even completely off and just use System.out.println() statements.  I tell you the people in the back were getting shifty for every time he said, &#8220;It&#8217;s that easy&#8221; or &#8220;It&#8217;s that simple&#8221;.</p>
<p>The cool part of this presentation was how nicely the architecture handled failover and relocation using SLA.  The declarative approach of using annotations and Spring configuration was also something good.  It&#8217;s easy to extend the model and any  underlying implementations without having an effect on the deployed application.  But really, when have we ever been forced to swap out a DAO layer at runtime?  The point is taken though.  Gigaspaces seems to have it&#8217;s dirty little hands all over distributed persistence and JavaSpaces, it&#8217;s just too bad they don&#8217;t throw the parties Virtuas threw.</p>
<p><strong>Chet Haase apologized on America&#8217;s behalf</strong> for Romain Guy (pronounced Gee) being denied a US visa insisting that Guy is not a terrorist, just French.  He seemed almost apologetic for even being there and showed his genuine shock that he wasn&#8217;t alone in the Filthy Rich Clients presentation.  He tried to get some hormones jumping by showing &#8220;cool&#8221; demos like Guy&#8217;s Aerith application but it would take a lot more than a fade-out to get this crowd excited.  But wisely, Haase had a Plan B which included plugging his Timing Framework by showing interpolators, Glasspanes and non-linear interpolation, all good stuff, but hardly applicable to 90% of the developers out there.  Some poor sap in the front row wondered where the HTML port and CSS integration was, to which Haase responded and I&#8217;m doing some serious paraphrasing, &#8220;You&#8217;re in the wrong room&#8221;.</p>
<p>Fades, Pulses, Morphing, Animated Transitions are all cool stuff and there&#8217;s no denying that but I wonder how much time companies doing  Java clients have to make things look pretty, especially when testing this stuff is fairly hard.  It&#8217;s not like you can use Selenium for this stuff.  The coolest thing he showed was the PropertySetter and how it reduces the boilerplate code to do animations, tie this along with acceleration and deceleration and you got yourself a filthy rich client that will &#8220;ooze cool&#8221;.    This would&#8217;ve been a much more impressive talk if the AV team had figured out how to dim the lights in the room.  Main theme of the presentation: Buy the book, it&#8217;s called Filthy Rich Clients.</p>
</div>]]></content:encoded>
</item>
<item>
<title><![CDATA[Attending TSS Java Symposium in Las Vegas]]></title>
<link>http://depressedprogrammer.wordpress.com/2007/03/06/attending-tss-java-symposium-in-las-vegas/</link>
<pubDate>Tue, 06 Mar 2007 23:54:38 +0000</pubDate>
<dc:creator>Arsenalist</dc:creator>
<guid>http://depressedprogrammer.wordpress.com/2007/03/06/attending-tss-java-symposium-in-las-vegas/</guid>
<description><![CDATA[So I&#8217;m attending The Server Side&#8217;s Java Symposium in Las Vegas this year from March 21st]]></description>
<content:encoded><![CDATA[<div class='snap_preview'><p>So I&#8217;m attending <a href="http://javasymposium.techtarget.com/">The Server Side&#8217;s Java Symposium</a> in Las Vegas this year from March 21st to 23rd.   JavaOne last year was fun but it&#8217;s time to try something different.  TSS Java Symposium focuses more on enterprise development which is what interests me more.</p>
<p>I <a href="http://weblogs.java.net/blog/zarar/archive/2007/03/javaone_vs_tss.html">updated my java.net blog</a> citing some of the problems with JavaOne.  Hopefully I won&#8217;t be regretting my decision to switch conferences.</p>
</div>]]></content:encoded>
</item>
<item>
<title><![CDATA[TSS Java Symposium Review Part 3: Filthy Rich GWT Clients using SBA]]></title>
<link>http://arsenalist.wordpress.com/2007/03/26/tss-java-symposium-review-part-3-filthy-rich-gwt-clients-using-sba/</link>
<pubDate>Mon, 26 Mar 2007 17:48:56 +0000</pubDate>
<dc:creator>Arsenalist</dc:creator>
<guid>http://arsenalist.wordpress.com/2007/03/26/tss-java-symposium-review-part-3-filthy-rich-gwt-clients-using-sba/</guid>
<description><![CDATA[There has to be a better way than to write Java code and have it &#8220;compile&#8221; to JavaScript]]></description>
<content:encoded><![CDATA[<div class='snap_preview'><p><strong>There has to be a better way than to write Java code</strong> and have it &#8220;compile&#8221; to JavaScript for anybody to use AJAX functionality.  Bruce Johnson&#8217;s cry to the crowd that there&#8217;s absolutely no performance hit in doing so was falling on on deaf ears until his claim of the &#8220;perfect caching&#8221; implemented by GWT.  A statement that sent murmurs through the crowd and promptly encouraged everyone to grab their session evaluation sheet and circle the 1 in all categories.</p>
<p>All this talk of leveraging the Java language is making me nauseous.  I can&#8217;t help but think of the poor bastard who&#8217;s been developing in JavaScript all these years and has pretty much become a guru at it, only to realize that he&#8217;s been using the wrong language all along.  Basically they want your application to be one page and every transition happens using GWT &#8211; talk about being tied to a product!  Not that Google&#8217;s going bankrupt anytime soon but once you go to GWT, you really, really can&#8217;t go back.  GWT seems like a decent product but I&#8217;m wondering whether adopting it early in a project isn&#8217;t &#8220;slipping into poorly planned AJAX development&#8221; as Johnson claims people are doing.</p>
<p>So what happens if your application becomes too big and increases in size, why you GZip it of course! Give Google credit for thinking outside the box and adopting a Maven&#8217;ish approach to developing in JavaScript &#8211; compile, package, deploy.  They even give you an embedded browser of sorts to use during development where your edited Java code is &#8220;deployed&#8221; using a simple refresh.  All those Google aficionados are free to wet their pants at the sight of GWT, but they&#8217;d be a fool to not try out Scriptaculous or Dojo first.  There&#8217;s no reason to kill a bird with a cannon.</p>
<p><strong>Nati Shalom and some programmer talked about Space Based Architecture</strong> and it&#8217;s Spring Integration until he was blue in the face and the audience was close to tears.  The coming up lunch break didn&#8217;t help matters.  Yes, you guessed it, there&#8217;s also a &#60;space&#62; XML namespace in Spring2 making declarative SBA very easy to use and abuse.  The concept of SBA is simple enough to wrap your head around but if your demo consists of showing the EXTREMELY verbose logging of three JVM&#8217;s at the same time, things are going to get hairy.  At least have the decency to turn the log level down or maybe even completely off and just use System.out.println() statements.  I tell you the people in the back were getting shifty for every time he said, &#8220;It&#8217;s that easy&#8221; or &#8220;It&#8217;s that simple&#8221;.</p>
<p>The cool part of this presentation was how nicely the architecture handled failover and relocation using SLA.  The declarative approach of using annotations and Spring configuration was also something good.  It&#8217;s easy to extend the model and any  underlying implementations without having an effect on the deployed application.  But really, when have we ever been forced to swap out a DAO layer at runtime?  The point is taken though.  Gigaspaces seems to have it&#8217;s dirty little hands all over distributed persistence and JavaSpaces, it&#8217;s just too bad they don&#8217;t throw the parties Virtuas threw.</p>
<p><strong>Chet Haase apologized on America&#8217;s behalf</strong> for Romain Guy (pronounced Gee) being denied a US visa insisting that Guy is not a terrorist, just French.  He seemed almost apologetic for even being there and showed his genuine shock that he wasn&#8217;t alone in the Filthy Rich Clients presentation.  He tried to get some hormones jumping by showing &#8220;cool&#8221; demos like Guy&#8217;s Aerith application but it would take a lot more than a fade-out to get this crowd excited.  But wisely, Haase had a Plan B which included plugging his Timing Framework by showing interpolators, Glasspanes and non-linear interpolation, all good stuff, but hardly applicable to 90% of the developers out there.  Some poor sap in the front row wondered where the HTML port and CSS integration was, to which Haase responded and I&#8217;m doing some serious paraphrasing, &#8220;You&#8217;re in the wrong room&#8221;.</p>
<p>Fades, Pulses, Morphing, Animated Transitions are all cool stuff and there&#8217;s no denying that but I wonder how much time companies doing  Java clients have to make things look pretty, especially when testing this stuff is fairly hard.  It&#8217;s not like you can use Selenium for this stuff.  The coolest thing he showed was the PropertySetter and how it reduces the boilerplate code to do animations, tie this along with acceleration and deceleration and you got yourself a filthy rich client that will &#8220;ooze cool&#8221;.    This would&#8217;ve been a much more impressive talk if the AV team had figured out how to dim the lights in the room.  Main theme of the presentation: Buy the book, it&#8217;s called Filthy Rich Clients.</p>
</div>]]></content:encoded>
</item>
<item>
<title><![CDATA[TSS Java Symposium Review Part 2: Spring2 + &lt;anything&gt; = cool; ESBs exposed; OSGi love]]></title>
<link>http://arsenalist.wordpress.com/2007/03/26/tss-java-symposium-review-part-2-spring2-anything-cool-esbs-exposed-osgi-love/</link>
<pubDate>Mon, 26 Mar 2007 06:51:39 +0000</pubDate>
<dc:creator>Arsenalist</dc:creator>
<guid>http://arsenalist.wordpress.com/2007/03/26/tss-java-symposium-review-part-2-spring2-anything-cool-esbs-exposed-osgi-love/</guid>
<description><![CDATA[Ross Mason, the Mule head-honcho, tried his best to combat the increasingly hostile AV equipment whi]]></description>
<content:encoded><![CDATA[<div class='snap_preview'><p><strong>Ross Mason, the Mule head-honcho, </strong>tried his best to combat the increasingly hostile AV equipment while promoting Mule2&#8217;s integration with Spring2, the former not yet GA&#8217;d.  His moaning of how hard the team is working to get Mule2 out was in direct contradiction with the entire weekend he spent gambling away at The Venetian &#8211; yeah Ross, I saw you near the slots over the weekend.  So Mule2&#8217;s approach is something called &#8220;The Hollywood Principal&#8221; which means &#8220;Don&#8217;t call us, we&#8217;ll call you&#8221; &#8211; damned if I know what that means.  Mule is the latest to create their own Spring XML namespace and from the examples, it didn&#8217;t seemed terribly hard to get an ESB going.</p>
<p>Mule&#8217;s also proud that you don&#8217;t have to mention class names in your Spring config files anymore which is seen as a big plus? Not sure if that&#8217;s really the case since there will be a tight binding somewhere else and you&#8217;ll just be jumping through another hoop to get Spring to work.  Of course, no talk is complete this year without a mention of OSGi and this one was no exception.  Turns out an OSGi container will do hot deployment of Mule endpoints, services, transformers and anything else you dream up.  Not a bad talk, would be better if his audio worked.</p>
<p>The guy sure is proud that the Mule IDE doesn&#8217;t overwrite your code changes once you go from code-view to design-view.  Is that really something so special that you have to point it out? And one more thing, stop showing the donkey from Shrek and pretending it&#8217;s a mule &#8211; it&#8217;s not a mule, it&#8217;s a donkey!  I was going to download Mule to test it out, may as well do it once it&#8217;s got the Spring2 stuff in it.  Also, stop wasting your time on Drag&#8217;n Drop features for the IDE, that&#8217;s stupidness.</p>
<p><strong>Mark Richards seems like a guy </strong>who could talk for 16 hours straight without any water or oxygen.  When this talk ended I felt a lot better because I finally saw some people who were as confused as me about what an ESB is and what it does and doesn&#8217;t do.  Instead of defining what an ESB is, Richards first proved that nobody really knows what it is by whipping out three different but widely accepted definitions of an ESB through &#8220;Buzzword Bingo&#8221; which I loved.  Instead, he tried to solve the problem of how to deploy a distributed environment and offered point-to-point solutions using JMS Queues and Adapters which ended up solving the problem but required additional work such as wrapping the messaging protocol etc.  So even if we supply a good level of abstraction, we&#8217;re still bound to a contract and if the application changes, so must the client.  The answer to this problem? An ESB.</p>
<p>Service Locational Transparency and enterprise wide security seem to be the two major benefits of having an ESB, both of which are currently undoable using point-to-point techniques and plain old web services.  It was a great talk by Mark Richards who was nice enough to dumb it down to code examples when talking about SLT, consistent service access and implementation decoupling.</p>
<p>The talk was titled <em>The Enterprise Service Bus: Do We Really Need it?</em> and Richards seemed to answer, <em>Yes, unless you&#8217;re a wannabe architect working on one pathetic system.  </em>The need for an ESB seems directly proportional to the number of different transport methods and disparate systems your services are being provided from.  If you&#8217;re doing POWS (Plain Old Web Services) on a single cluster, it&#8217;s definitely overkill.  If you&#8217;re managed to get yourself tangled up in queues, web services and RMI, I say go for it.</p>
<p><strong>Rod Johnson pitched Adrian Colyer&#8217;s talk </strong>on Spring&#8217;s OSGi integration and I bit.  It&#8217;s surprising that an idea so old and good is only now being realized and accepted.  I raise me hand when I say I had little clue of what OSGi was until this conference except that Eclipse&#8217;s plugin system was based on it.  Lots of talk about visibility, versioning and operational control coming through a British accent makes you feel warm and fuzzy but let&#8217;s face it, we&#8217;re years away from OSGi actually being adopted in the mainstream.  No matter how hard Spring tries to &#8220;osgi&#8221; their modules, they&#8217;ll still have to wait for the likes of commons-lang to comply with OSGi before somebody can actually build a true OSGi based system.</p>
<p>So the idea of having more than one version of a module in the same JVM seems to excite everybody but I&#8217;m wondering if that really is a good thing? What does it say about your application if it&#8217;s dependent on spring-jdbc 1.2.8and spring-jdbc 2.0? Sounds to me you&#8217;re using OSGi to cover up some pretty crappy software design and decisions.  Colyer had a good, concise and short-scoped talk on OSGi and anybody who didn&#8217;t know what it was before they entered the room, had a damned good idea when they left it.  These Interface21 guys don&#8217;t seem so bad in person as they do on the forums.</p>
<p><strong>Random Notes:</strong> Lost around 15 bucks, Cirque Du Soleil is overrated, Gondola rides are for posers, 10 dollars for a drink at The V is robbery</p>
</div>]]></content:encoded>
</item>
<item>
<title><![CDATA[TSS Java Symposium Review Part 1: Gamma pitches Jazz, Johnson disses J2EE]]></title>
<link>http://arsenalist.wordpress.com/2007/03/23/tss-java-symposium-review-part-1-eclipse-eric-gamma-rod-johnson-spring/</link>
<pubDate>Fri, 23 Mar 2007 18:55:19 +0000</pubDate>
<dc:creator>Arsenalist</dc:creator>
<guid>http://arsenalist.wordpress.com/2007/03/23/tss-java-symposium-review-part-1-eclipse-eric-gamma-rod-johnson-spring/</guid>
<description><![CDATA[Eric Gamma, when I hear that name I think of Gang of Four and the great book Elements of Reusable Ob]]></description>
<content:encoded><![CDATA[<div class='snap_preview'><p><strong>Eric Gamma,</strong> when I hear that name I think of Gang of Four and the great book Elements of Reusable Object Oriented Design. So when I read that Gamma was going to be the keynote speaker at TSSJS, I resolved to wake up earlier than I wanted to just to go check out what the SLDC guru had to say. For what I hoped to be an inspirational and insightful affair turned out to be a product pitch of the most boring wavelength. The subject was Eclipse and something called &#8220;The Eclipse Way&#8221; which really is another way of saying use continuous integration for your projects and make sure you test stuff. For a keynote speech the material focused way too much on specific tools (Eclipse and Jazz) and not enough on the theme of the conference or any technology or trend which might carry some gravitational pull.</p>
<p>Gamma kept dropping quotes saying &#8220;Jazz knows how developers work&#8221; which is like saying, &#8220;I can predict the weather&#8221;.  No, Jazz does not know how developers work, it thinks it knows it by forcing you to create things like &#8220;process rules&#8221; through tedious XML configuration and promoting concepts like pervasive transparency like they were the first to use it. Throw in some more pie-in-the-sky terms like &#8220;Process Awareness&#8221; and &#8220;Village Effect&#8221; and you got yourself a keynote speaker. Bloody waste of time.</p>
<p>Gamma then offered to fix my &#8220;pain points&#8221; and try as I could to figure out what he was saying, I was too busy trying to figure how which word he used more than 500 times, process or collaboration.  Hey, all I&#8217;m saying for a keynote speaker, this was a completely unexpected speech, he said nothing of any consequence and insisted that we use Eclipse + Jazz to do all our work because &#8220;The Eclipse Way&#8221; was the best way and you&#8217;d be a damn fool not to use it.  I was expecting more talk about high-level SD and something I didn&#8217;t know, not rampant prostitution.</p>
<p><strong>Next up, it was Rod Johnson and his Spring pitch. </strong>To sum it up he concluded, &#8220;Spring kicks J2EE&#8217;s ass and you shouldn&#8217;t be using J2EE just because somebody told you to do it&#8221;. The great part about this theme is that he does have a great point which is backed by concrete arguments and industry-proven usage. Spring loves AOP and regardless of the people bitching about, it does kick ass. Custom XML namespaces and support for Java6 scripting languages dominated his talk but the guy never fails to diss J2EE whenever he gets a chance calling the entity bean an &#8220;abomination&#8221;. I&#8217;m starting to like this guy or maybe it&#8217;s just the accent.</p>
<p>OSGi (which I knew very little about) is a big hit with Spring and they&#8217;ll be packaging all their modules to be OSGi compliant. That&#8217;s great news and probably a good step but it won&#8217;t really matter until all those 3rd party Jars end up being OSGi modules too.  Spring has the completely opposite view of XML than <a href="http://www.bileblog.org/?p=13">some people</a>.  He&#8217;s calling Java messy and complicated and the example he gave was having a Spring config in Java instead of XML (using annotations in the config classes, not the source code) and sure enough he was right, but who the hell uses annotations that way anyways? Compare that with the Spring config and of course it&#8217;s going to be more attractive. No shit.</p>
<p>I talked to Rod in the refreshments room (very average, they didn&#8217;t label the decaf as decaf, what garbage is that?) and talked to him about Google Guice and any threat they posed. Johnson let out an evil laugh and roared, &#8220;Guice will be so sorry when we release DI annotations in 2.1&#8243;</p>
<p><strong>Random Notes:</strong> Elevator music is way too loud, lots of prostitutes around, I went over to the Wynn which is a better hotel/casino than this.  I lost 3 dollars in the slot machines.</p>
</div>]]></content:encoded>
</item>
<item>
<title><![CDATA[Attending TSS Java Symposium in Las Vegas]]></title>
<link>http://arsenalist.wordpress.com/2007/03/06/attending-tss-java-symposium-in-las-vegas/</link>
<pubDate>Tue, 06 Mar 2007 23:54:38 +0000</pubDate>
<dc:creator>Arsenalist</dc:creator>
<guid>http://arsenalist.wordpress.com/2007/03/06/attending-tss-java-symposium-in-las-vegas/</guid>
<description><![CDATA[So I&#8217;m attending The Server Side&#8217;s Java Symposium in Las Vegas this year from March 21st]]></description>
<content:encoded><![CDATA[<div class='snap_preview'><p>So I&#8217;m attending <a href="http://javasymposium.techtarget.com/">The Server Side&#8217;s Java Symposium</a> in Las Vegas this year from March 21st to 23rd.   JavaOne last year was fun but it&#8217;s time to try something different.  TSS Java Symposium focuses more on enterprise development which is what interests me more.</p>
<p>I <a href="http://weblogs.java.net/blog/zarar/archive/2007/03/javaone_vs_tss.html">updated my java.net blog</a> citing some of the problems with JavaOne.  Hopefully I won&#8217;t be regretting my decision to switch conferences.</p>
</div>]]></content:encoded>
</item>

</channel>
</rss>
