Sunday, May 29, 2011

Great read over at networkingnerd.net entitled "9.@ Must Die!" Yes! Agreed!

Tom Hollingsworth wrote an excellent post about ditching the 9.@ route pattern and the subsequent route filters.  Love it.  Cisco needs to remove this from the SRND and let it quietly fade from view. http://networkingnerd.net/2011/05/26/9-must-die/

UC Keep It Simple Stupid #1 - Dial-plan, smial-plan


Overcomplicating is a very common issue amongst engineers, in just about every discipline.  Unified Communications is no exception, with Cisco leading the vendor pack (wolfpack?) in the way of confusing their customers.  Yes, I know that complexity breeds flexibility, but for my customers it equals an insanely steep learning curve that can be difficult to surmount.  The first of my "Keep it Simple Stupid" posts will address one of the more complex elements of Cisco's Unified Communications Manager, the dial-plan. 

There's a very common occurrence whenever I start talking about partitions and calling search spaces with customers; eyes start to glaze over, beads of sweat start swelling up on foreheads, and the inevitable question: "What training classes are available for this??"  "Relax," I tell them, "we'll go over all this before I leave."  I spend a few hours slowly beating them to death with my powerpoint presentation on CUCM administration, and normally the situation doesn't get any better.  Nine times out of ten, their biggest lack of understanding is around the use of partitions and calling search spaces.

A long time ago, in elder versions of CUCM (read CallManager), You created a single set of route patterns, and single set of partitions, and single set of calling search spaces for each site.  This was easy to understand (relatively speaking), but it didn't scale well.  

Then Cisco started recommending the Line/Device calling search space model, which did greatly decrease the number of route patterns and partitions in use.  Since we decreased the number of things to configure, this made the dial-plan easier to understand, right?  Not so much.  The Line/Device method (to put it simply) uses calling search space concatenation to merge two layers of partitions together.  The top layer consists of the gates that a call must pass through in order to get to the bottom layer of partitions, which actually contain route patterns that will connect your call.  If the top layer contains a match for a particular type of call that isn't allowed, say an international pattern, the call is blocked.  Make sense?  Right.   Below is a visual representation of this concept.  In this particular example, the only allowed calls would be local, because international and long distance patterns are targeted for being blocked.



I'm writing to recommend a different approach, one that captures some of the glory of the ol' easily understood days.  There's a really handy feature that was introduced in 7.x called Local Route Group.  This feature allows you to dynamically assign a route group (gateway) to a shared route pattern based on whatever phone is dialing the pattern.  The Local Route Group is configured in the Device Pool of the phone.  If I have a gateway at my New York location, and the phones in the New York location dial the standard long distance route pattern (9.1[2-9]XX[2-9]XXXXXX is what I use), the logic in the Local Route Group will evaluate the phones' device pool setting for route group and choose the first gateway in that list.  Magic?  Almost.

So how do you get there from here?  First, create a new route list, called something like Standard Local Route List.  This list will have the same settings as your normal route list, but it's route group will be a special one in the drop down menu called Standard Local Route Group.  That's the secret sauce that marries any given route pattern to the phone's configured gateway.  The route pattern will point to whatever gateway (route group) is assigned to the device pool of the phone that dialed the pattern, thus leaving you with a common set of route patterns that will scale to all devices.  

Back to partitions and calling search spaces.  We will still use the concatenation of the line and device calling search spaces, but no more of this silly blocking business.  Your device calling search space will have all your internal partitions, plus something to stick your 911 route pattern in (we don't want to toss that one up to user error).  Create one calling search space per type of class of service.  I usually have International, Long Distance, and Local.  Your International CSS will include an international partition, a long distance partition, and a local partition.  Your Long Distance CSS will have a long distance partition and a local partition.  I'm sure you can see where I'm going with this.  These partitions should contain the route patterns for each respective type of number, all tied to the Standard Local Route List that will allow that dynamic allocation of gateway to dialing phone.  Here's what this might look like:


No more reverse logic, and fewer route patterns and partitions to boot.  This will NOT APPLY TO ALL SITUATIONS.  Your mileage may vary, and I definitely recommend the use of a lab to test this configuration out before you start making changes willy-nilly. Happy configuring!

Friday, May 27, 2011

Video for the Voice engineer

Having done Cisco voice over IP for the last 10 or so years, this video thing is really cramping my style.  First and foremost, change is difficult.  I was comfortable with voice, why go and add a whole new set of things to learn?  It's a CCIE Voice #forgoodnesssakes, not a CCIE Video.  Now who moved my cheese.

Secondly, the wave of new products added by the Tandberg acquisition are all VASTLY different than what we're use to.  Why is that you might ask?  Because these products are all easy to use, with very limited tweaking available for any type of complex solution.  In a nutshell, these products haven't been convoluted by Cisco just yet (you mean the licensing from Tandberg is easy? Yes, crazy talk.), and it's odd to login to an intuitive interface and actually accomplish what you set out to.

Obviously I'm being harsh (read bitter) here, but I see a lot of promise in the Tandberg products.  Over the next few months, I'll be learning lots more about the Video Communication Server (VCS), TelePresence Management Suite (TMS), Codian MCU's, and of course all the wonderful variety of endpoints.  In all seriousness, I'm excited about the direction that the collaboration engine is moving, and definitely look forward to being one of the guys riding this train.