Monday, June 28, 2010

SCOM is really starting to piss me off...

So, I've created a custom alert view in my Mgmt Pack. It relies on rules to determine what's populated in the view, and the rules apply to alerts that have been generated off of a custom Windows Event Log (which I've created).

Everything works fine...so long as you are on a machine where that Windows Event Log exists. If you are on another console, tough. The alerts will never load.

I thought it would be safe to assume that the rule I created earlier would comb the custom log (via the agent), populate alerts into the database, and then allow ALL consoles to view them. Silly me.

Saturday, June 12, 2010

Emerald Isle / Bogue Banks Golf Courses

Today, with some friends, played the course at Country Club of the Crystal Coast. It's by far my favorite course in the Emerald Isle area...check it out if you're in the area:



Thursday, June 10, 2010

Powershell: Bringing Sexy Back

Stumbled across this neat little "Intro to Powershell" page and wanted to archive it for my (and now your) future reading pleasure...



Nifty editor

I've been writing code recently and doing a lot of on-the-fly debugging, so manipulating both log files (output) and structured input files for testing. All have different formats so I'd been using an IDE and two bash windows to accommodate my needs.

Until a co-worker turned me on to Notepad++ (yes, I'm developing on Windows). This is a slick little download from SourceForge (Free as in Beer and Speech) and does just about everything I've ever wanted an editor to do but either a) it couldn't or b) I couldn't remember how to make vi do it.

Monday, June 7, 2010

Displaying a Percent Sign (%) in a SCOM Event Description

I googled around a bit and discovered that the SCOM's "Description" field in the "Details" pane is actually rendered in HTML. Handy info, that, but it didn't help me get a percent sign rendered.

I ended up trying every contrivance you can imagine to try to make it happen -- all to no avail.

Ultimately, the magic that worked: "%%". Go figure.

Microsoft OpsMgr 2007 SDK Severity Levels

Documented here as much for my future reference as yours...

If you're using the SDK and are instantiating a CustomMonitoringEvent class, it comes with a LevelID property which holds an int. The value of that property determines the severity level the event is assigned, with the following mapping:
  • 1-Error
  • 2-Warning
  • 4-Information
  • 8-Success Audit
  • 16-Failure Audit
I found this via Google on the MSDN SDK web site, embedded in sample code. I didn't want to have to try to do that again.

Curious, see the original site here: http://msdn.microsoft.com/en-us/library/bb437567.aspx

And just like that, Bing becomes irrelevant

Got a note from Bing today saying that they are discontinuing their cash back program...

Dear valued cashback customer:

We are writing to notify you that the Bing cashback program will be discontinued, and the last day to earn cash back on your Bing Shopping purchases will be July 30, 2010.

Until July 30, 2010 9:00 pm PST, it's business as usual so continue to take advantage of great offers from your favorite merchants. You can redeem all of your earned cashback savings consistent with the cashback terms and conditions and access the Bing cashback customer support system through July 30, 2011. We encourage you to redeem your cashback savings and to further support redemption, we are waiving the $5 minimum payout effective July 31, 2010. To assist with prompt delivery of your cashback earnings, please visit http://cashbackaccount.bing.com to ensure your account information is current. For more details and answers to your questions, please visit our frequently asked questions page.

Thank you very much for being a loyal cashback user. We remain committed to delivering great value to our customers, and we are currently working on an exciting new program which you will hear more about from us later this summer.

Sincerely,

Bing cashback team


And just like that, I'm back to being an exclusive Google user.

Sunday, June 6, 2010

Drum Stick Sizes

I've recently started playing drums again after a roughly 20-year hiatus. It's fun, but the percussion industry has come a long way in the past two decades.

When I last played, I owned a Ludwig Octo-Plus kit (double bass, 8 mounted concert toms) and played with Pro-Mark 747 sticks with nylon tips. When getting back into it, I bought a new set of 747s, but then decided to look around a little bit and try out some others.

I started off by checking out the technical specs of the 747s and seeing what was close. Since most sticks are hickory, I decided not to try varying that part of the equation.

Pro-Mark lists their 747s as:
  • Length: 16.25"
  • Diameter: .551"
Then came the deluge of details...

Most drummers know that there are a few common sizes and uses:
  • 7A - a thin, light stick. Generally used for jazz in small combo settings
  • 5A - a medium stick. This is probably the most common size.
  • 5B and 2B - thicker, heavier sticks. These are most typically used in heavy rock situations, to get a heavier sound, as well as to prevent breakage.
All manufacturers offer a WIDE variety of size options. Below, I compare some of the common ones across their lines. Note: With the advent of stick endorsement deals, every vendor also has their "signature" sticks which are made to the specifications of the endorser. The complexity continues ad nauseam...

Pro-Mark lists key sizes (Size/Diameter in Inches/Length in Inches):
  • 7A - .512" - 15.375"
  • 727 - .531" - 16"
  • 5A - .551" - 16"
  • 747 - .551" - 16.25"
  • 5B - .590" - 16"
  • 2B - .630" - 16"
Vic Firth lists their sizes a bit differently:
  • 7A - .540" - 15.5"
  • 5A - .565" - 16"
  • 5B - .595 - 16"
  • 2B - .630" - 16.25"
  • Rock - .630" - 16.625"
  • 7A - .540" - 15.5"
  • Pro Rock - .555" - 16.25"
  • Los Angeles 5A - .570" - 16"
  • Fusion - .580" - 16"
  • 5B - .605" - 16"
  • Rock - .630" - 16.625"
  • 2B - .635" - 16.25"
Regal is different, too:
  • 7A - .510" - 15"
  • Rock - .555" - 16.25"
  • 5A - .580" - 16"
  • 5B - .600" - 16"
  • 2B - .655 - 16"
Zildjian weighs in as well:
  • 7A - .525 - 15.5"
  • Jazz - .540" - 16"
  • 5A - .560" - 16"
  • 5B - .600" - 16"
  • 2B - .625" - 16"
  • Rock - .625" - 16.625"
I stumbled across a deal to buy some Vater-manufactured "Sam Ash Specials" (5 pair for $10), so I decided I'd give it a try. They are 5As and I think I'm a convert. The other notable change for me is that I'd historically only played nylon tip sticks and these "Specials" are wood tip. Well, I'm a convert on that front as well. I used to like the bright "ping" on the ride cymbal and hi-hat, especially when playing surf rock. Now that I'm playing more classic rock/southern rock, I don't need the brightness -- and in fact, don't want it.

So for now, I'm a cheap-stick fan, especially of the wood-tip 5As. But I prefer a smaller 5A...for what it's worth.

Saturday, June 5, 2010

Powershell, Versions, Modules & Snap-ins

I've been working on a Powershell script that will soon ship as part of a product. As such, it has requirements that it must meet, and I started development on the wrong end of that spectrum.


I mean, Powershell is Powershell, right? Well, yes. But Powershell v1.0 is not Powershell v2.0 and the differences are both subtle and important. Especially when it comes to using Modules (DLLs) and Snap-ins.


My first problem was that I started development on my Windows 7 64-bit laptop with Powershell 2.0. The first important takeaway from this experience:


1. Developing in Powershell 2.0 is better than Powershell 1.0.


And the second:


2. The Powershell ISE (Integrated Scripting Environment) may be the best tool I've used for developing scripts.


It's no Eclipse, but it's very handy and the price is right.


Anyway, the script I'm writing integrates with System Center Operations Manager 2007 (aka SCOM and OpsMgr). SCOM delivers an SDK that's available both on the management server and the console, so my script will be running in one of those two locations and relying on several different OpsMgr assemblies, including:

  • Microsoft.EnterpriseManagement.OperationsManager.dll
  • Microsoft.EnterpriseManagement.OperationsManager.Common.dll
  • Microsoft.EnterpriseManagement.OperationsManager.ClientShell.dll
and one system assembly:
  • System.Security
My troubles were heavily rooted in a combination of me not knowing Powershell, trying to cobble things together from snippets of code found on the web and in books, and starting off in the wrong version of Powershell running on the wrong "bitness" OS.


I needed to build this script so it would run in Powershell v1.0 and it needs to run on both 32-bit and 64-bit platforms. Finally, I got it working on v2.0 and 64-bit, but then started down a path of misery trying to make it backwards compatible. Along the way I learned a few things:

  • Modules/DLLs can get loaded in several ways.
  • Snap-ins need two key steps to work in your script -- they need to be registered with this system, which is the first step, then added to the script context you're working on.

Loading Modules/DLLs:

VERSION 2 ONLY: import-module "C:\Program Files\System Center Operations Manager 2007\Microsoft.EnterpriseManagement.OperationsManager.ClientShell.dll"
VERSION 1 & 2: [System.Reflection.Assembly]::LoadWithPartialName("Microsoft.
EnterpriseManagement.OperationsManager")


Register your Snap-ins with the OS:

So this was an odd concept for me to finally get my head around. When you register your snap-in with the system, you're creating an entry in the system registry that describes the snap-in. This does NOT make the cmdlets available to your script. I didn't really grasp this until I understood the difference between Get-PSSnapins and Get-PSSnapins -Registered. More on this in a moment...


First, to get your Snap-in recognized by the system, you need to use the InstallUtil.exe utility. This is located in C:\Windows\Microsoft.NET\Framework\v2.0.50727\installutil.exe. Unfortunately, the actual path will vary with the bitness of your OS (Framework becomes Framework64 on 64-bit OSes) and with the version of .NET Framework embedded in the path, you will also have versioning of the framework to deal with.


In order to determine if your Snap-in registration was successful, you can either go check in the registry (A Registry key with SnapinName, which was defined in the PSSnapIn class, will be created under HKLM\Software\Microsoft\PowerShell\1\PowerShellSnapIns) or you can run Get-PSSnapins -Registered. Remember, this does NOT make the cmdlets available to your script...yet.


To make the cmdlets available to your script, you need to add them with Add-PSSnapins. At this point, the Get-PSSnapins command (no -Registered option) should tell you that your snap-in is loaded into the script context. And depending on the snap-in, you may need to source another script (.ps1) that includes the cmdlet function names, as was true in this case: &"C:\Program Files\System Center Operations Manager 2007\Microsoft.EnterpriseManagement.OperationsManager.ClientShell.Functions.ps1"

I don't know if this is enough information or even presented clearly enough to help, but here's hoping. Also, you should check out the page that ultimately helped me decode this riddle (with thanks to Arul Kuramavel and the good people at Wrox): http://www.wrox.com/WileyCDA/Section/Extending-Windows-Powershell-with-Snap-ins.id-320555.html

Blog Post #1 -- FIRST POST!!!

So...this is blog post #1. I've tried blogging in the past, but never really had enough to say to keep it up. This time, it might be different.

Maybe...

Actually, I'm motivated this time by something other than sheer ego. This time, it's out of frustration that I've had to dig and dig and dig to find some technical information that should have been documented somewhere--PROMINENTLY. Instead, I had to scrap all the product docs and scour the web and, after over a week of looking, I found a post that got me headed in the right direction and finally figured out my problem. So I was thinking that a blog would be a handy place to capture this sort of information so the next idiot doesn't have to work so hard...

But more on that in a post with actual content.