Tuesday, 3 September 2013

A slightly more in-depth review of Rhapsody 5.4

We recently moved from Rhapsody version 3 to version 5. Here's some tedious info about that.

From what I can tell Rhapsody is made-up of 3 components

  1. The engine that does the message processing - Windows service
  2. The IDE (development environment) - Windows application
  3. The Management Console - web page
The engine is a black box so who knows what improvements have been done there.  It's always been pretty good, so let's just assume it hasn't got worse.

The IDE looks and feels the same, so has continued with the kind-of-clunky-user-interface and random-weird-errors way of working.  This is kind of expected because it's just developers that use this and no one cares about the development experience because:
  1. This stuff is complicated & hard to get right
  2. No one listens to developers as they will generally complain anyway, because they are basically the high tech version of the boy who cried wolf
There is some new functionality here (e.g. webservices communication points) but whatever, this is pretty much the same as version 3.  It's still pretty buggy; in version 3 I have had deployments to production fail and leave components in weird states, and then had the IDE refuse to restore backups (giving random errors). I haven't encountered bugs that big yet but have seen some along the lines of:
  • When changing the value of a variable an error occurs and the new value is not pushed out to the components (restarting the service fixed this)
  • An altered property on a checked out component is forgotten as soon as the component loses focus (restarting the IDE fixed this)
Yep, still looks like crap


The Management Console is where a lot of improvements are noticeable.  
  • When looking at com points/routes you can collapse folders and apply filters - no more scrolling around like an idiot (well, less of that at least).  The state of this (whether a folder is collapsed) is remember when coming back to the page.
  • In the old version the refresh on com point front page was a bit rubbish and would scroll you to the top of the page and make you lose your place etc.  It is now very seamless and continuous (seems to bring in updated data every few seconds via ajax calls).
  • There's a heap of automated (but configurable) warnings and errors that give you a good idea of the current state of the engine.
Makes it easy to see problems so that I can then pretend I haven't seen them and hope my colleagues fix 'em
  • When you log in it never tells you "Your security key session has expired; please log-in again. " and makes you log in again!
  • The component details view is pretty cool now. Mostly the same information but better organised and accessible.

  • When looking at a message, navigating to different messages is a lot easier e.g. you can now do a single click to go to the next or previous message. Yeah that's right. You don't need to mash that back button till you get back to the search then clown around trying to find the message id you were just looking at and then click the one before/after it. 
The expertly placed red triangles indicate where you can click to move to different messages
  • It doesn't look like total pants anymore.

Lessons learnt from migration

  • If you have communication points that are polling a database, when you move them to a new machine they will not remember the last polled value.  This is bad!  This means they basically start from the default value again.  You can update this from the management console under the Database Key Values menu.
  • There will be some small errors generated when moving to the new version (like some directory com points will need the configuration updated - I think additional validation has been added) but all can typically be easily worked through.
  • It will take you eternity to move all your crap because no one knows what it does, how to test it, or how to gain access to the systems that are sending/receiving the messages to change their configuration.
  • You're going to need some training in the new version.  This is kind of a guess, because I haven't had any training yet and there's a whole heap of stuff happening that I don't understand (like com points have input and output queues now) - I am assuming training would fix that.

No comments:

Post a Comment