I'm dare say I'm a seasoned Hudson user (admin) and proponent. For over five years I've been introducing different kinds of CI at whichever place I worked at. When Hudson entered my radar, this work became a lot easier. I'm also a heavy Maven user, and Nexus did for Maven repositories what Hudson did for CI.
The Plot
Over recent weeks, the community around Hudson has been shaken by a fork: The main developers (Koshuke and crew) have renamed Hudson to Jenkins, while Oracle have kept on developing Hudson in partnership with Sonatype. Here's a simple illustration of what happened:
These are my pure external speculations about what has happened recently in the forking process, with regards to Sonatype's involvement in particular.
So who is running this show?
I noticed that Sonatype (usually personified by Jason) have gotten their fingers pretty deeply into the Hudson infrastructure already:
It's no secret that Sonatype and Oracle are tightly partnered on this. But I think the relationship is more like one of a smart trickster sitting on the shoulders of a dumb giant.
Backstabbers and Benson
A lot of people felt betrayed when Sonatype chose to side with Hudson/Oracle in the fork. Heck, even I was disgruntled that my Maven heroes were going with the big evil anti-open source Oracle..
I've been pondering on why they did this unpopular move, and here's my rough guess:
The reason is Benson:
A Genius Take-overHad Hudson stayed under Koshuke's rapid development, Sonatype would've had to keep on maintaining Benson, merging in conflicting Hudson changes as they grew ever more distant from the fork.
Now, they can achieve the same with Hudson itself, and in the process they gain a huge brand by sticking to the Hudson name, and they also stay under Oracle's wing (this has its own con's, of course), with infrastructure and paid coding contributors.
So in a way, Hudson is the new Benson.
You can actually see this manifestation taking place right now. I guess you could simplify this to mean that Sonatype are now merging back the development they made in Benson. What the community is wondering, is why they didn't offer to do so before the fork (see the discussion in the comments), but that doesn't really matter anymore. Sonatype came in at exactly the right time, and did what was best for their company and customers. Nothing wrong with that.
My two biggest questions of this are:
This is a Good Thing
Nexus is an awesome product. It shares many of Hudson's qualities: It *just works*, it looks nice, it's easy to upgrade and maintain. I hope Hudson will retain these qualities. I'm sure Jenkins will.
What path will you take?
The Plot
Over recent weeks, the community around Hudson has been shaken by a fork: The main developers (Koshuke and crew) have renamed Hudson to Jenkins, while Oracle have kept on developing Hudson in partnership with Sonatype. Here's a simple illustration of what happened:
These are my pure external speculations about what has happened recently in the forking process, with regards to Sonatype's involvement in particular.
So who is running this show?
I noticed that Sonatype (usually personified by Jason) have gotten their fingers pretty deeply into the Hudson infrastructure already:
Like this tweet noted, it appears they are controlling Hudson's Twitter account. The @hudsonci account tweeted about something Maven-related, and it appeared it it was indeed meant for a Sonatype account.
And here it appears Jason is administering some of the Hudson infrastructure.
It's no secret that Sonatype and Oracle are tightly partnered on this. But I think the relationship is more like one of a smart trickster sitting on the shoulders of a dumb giant.
Backstabbers and Benson
A lot of people felt betrayed when Sonatype chose to side with Hudson/Oracle in the fork. Heck, even I was disgruntled that my Maven heroes were going with the big evil anti-open source Oracle..
I've been pondering on why they did this unpopular move, and here's my rough guess:
The reason is Benson:
Benson is Sonatype's Maven-focused distribution of Hudson taking into account everything that we've learned about Maven 3.0 during its development and how Maven should operate optimally within a CI environment: there will be no better way to work with Maven and Hudson. Benson is Hudson's brother from another mother. (source)As with any fork, maintaining it is expensive. I think Sonatype found it hard to keep Benson up to date with Hudson and all its plugins. Or maybe they wanted more changes in direction Nexus/Maven than the Koshuke crew were willing to go with.
See more about Benson in Jason's presentation from JavaZone 2010 (time 39:20).
A Genius Take-over
Now, they can achieve the same with Hudson itself, and in the process they gain a huge brand by sticking to the Hudson name, and they also stay under Oracle's wing (this has its own con's, of course), with infrastructure and paid coding contributors.
So in a way, Hudson is the new Benson.
You can actually see this manifestation taking place right now. I guess you could simplify this to mean that Sonatype are now merging back the development they made in Benson. What the community is wondering, is why they didn't offer to do so before the fork (see the discussion in the comments), but that doesn't really matter anymore. Sonatype came in at exactly the right time, and did what was best for their company and customers. Nothing wrong with that.
My two biggest questions of this are:
- Will Oracle put up with Sonatype's strategy over time?
- Will Sonatype put up with Oracle's inherent bureaucratic inertia?
This is a Good Thing
I think Sonatype is one of those rare companies that are able to work the open-source ecosystem, making a profit while at the same time donating a huge amount of great tooling back to the community. Some times they have to make unpopular compromises in order to stay profitable, and this is what happened with Hudson/Jenkins.
Nexus is an awesome product. It shares many of Hudson's qualities: It *just works*, it looks nice, it's easy to upgrade and maintain. I hope Hudson will retain these qualities. I'm sure Jenkins will.
What path will you take?
Personally, I think I'll go with Jenkins for now. I'm tempted to go with Sonatype/Hudson because we extensively use Nexus and Maven, and we're not paying Sonatype-customers. At the same time, I have only moderate needs for stability, and from experience I'm very happy with the features vs stability rating of the Koshuke crew.
I think (but might be wrong), that Jenkins will outrace Hudson in terms of features and usability.
I fear, that Hudson will get tangled down with Oracle stuff (register here to download, etc).
I hope both will continue to exist and fulfill two different needs in the market. Best of luck to both of them!
I think (but might be wrong), that Jenkins will outrace Hudson in terms of features and usability.
I fear, that Hudson will get tangled down with Oracle stuff (register here to download, etc).
I hope both will continue to exist and fulfill two different needs in the market. Best of luck to both of them!
This comment has been removed by the author.
ReplyDeleteThings came out "too good to be true" for Sonatype as if the whole "fork" story was planned in advance and original Hudson developers together with Koshuke were provoked to fork and hmm .. just go away.
ReplyDelete"Nexus is an awesome product. It didn't get where it is today based on happy chirpy volunteer work done in the evenings"
ReplyDeleteBit of back-handed insult to those of us happy chirpy volunteers who create awesome products in the evening.
Hi Ricardo, thanks for your comment.
ReplyDeleteI didn't intend it as an insult. The two sentences are separated by a period, but perhaps it should've been a paragraph break.
Happy chirpy was a poor choice of words, I'll admit. I'll edit them away.
This comment has been removed by the author.
ReplyDeleteHello Thomas,
ReplyDeletethanks for this article with some real useful insights ;-)
See also my blogpost about the same "issue".
I agree for the most part but I really can't understand how one can describe any product using ExtJS as awesome. Not only does ExtJS suck hairy donkey balls from a technical POV, it's also fugly from an asthetic POV, not to mention the licensing debacle which is reason enough for me not to use *any* product based on ExtJS. The same goes for Sonatype and van Zyl. I really like maven (probably for lack of better alternative...) but Nexus and everything else sucks and van Zyl especially sucks.
ReplyDeleteHi Anon. I happen to like the Nexus UI a lot actually. I also trust Sonatype have their licenses in order, as I suspect JvZ is one of the most knowledgeable persons on software licensing out there.
ReplyDelete