Pending Fatherhood

So, we’re past the risky first bit, so safe to say – I’m going to be a Dad, early in the new year! Woo-hoo! My own little mini-me (& Andrea, of course)! Its going to be a very special spring-time for us.

To my little one who may come and read my random blog posts in years to come – hi xxx ;)!

To Andrea; I love you completely. We go into this together, forever.  xxx

Phidgets RFID Reader

I’ve been looking for a simple way of reading an RFID tag from the Oyster card an its equivalents elsewhere. Prices seem to vary, as do the ways of interfacing. I think I am settling on USB across the whole board for my home security devices; its pretty ubiquitous, and devices are generally reasonably well priced.

Now I have seen the RFID reader I think I want: the Phidgets RFID Reader. Looking around to purchase one shows some major variation in price:

So, looking at today’s exchange rate of US$ to UK£ of 1.6518, the Active Robots price is US$113.33. That’s US$60.69 more than Robot Shop, or a mark-up of 115.29%. Over double!

Time to order via the US.

PS: Now I have the unit, I realised the difference between 135 kHz RFID tags (like the Phidget unit) and the 13 MHz ones (like the Mi-Fare Oyster)…. you can’t read an Oyster Card with a Phidget. *sigh*

MySQL Query Cache: still waiting for duplicate query checking

Way, way back in 2005 (4 years and counting) I finally reported a bug into the then MySQL 5.0 about an issue I was seeing (often) on high volume sites where a single query, if not in the query cache, but spawned from two (or more) simultaneous threads would both be executed in full; this is instead of one execution, and then the query cache being populated.

Reference: Bug 15044, and WorkLog 1293.

I had been seeing this for… well, years before hand, but considered it to be “just me”. Since I filed that bug, others have come forward and said they have seen the same issue.

Now, with the Oracle/Sun merge, and Sun having shelled out to “purchase” MySQL, we see a miraculous MySQL 5.4 being drafted together. Its good; but it appears to be a simple crowd pleaser that should have happened years ago – integrate in some very popular performance improvements (notably from Google’s code repository). If code is being contributed, and it works, why wasn’t this done earlier? And if not earlier, why now? Smokescreen? Last ditch effort before the project is canned by its new owner? Of course, this has been circulating for a while; I’m not posting this later after that’s been in the news for a few weeks now.

What is interesting is the “Refactoring MySQL” project being discussed. Where does this leave MySQL 6 – a little abandoned from here. And then with MariaDB and Drizzle now forked and picking up attention (external to MySQL/Sun/Oracle), it seems the entire thing is just becoming a mess. Drizzel is supposed to be the performance version – but with the google patches being integrated, perhaps the core MySQL branded project is catching up?

What’s looking clearer is: Postgres. From my perspective, its worse for MySQL in Debian. Lenny (stable now) has MySQL 5.0. The Experimental repo has 5.1 (5.1.34), but this hasn’t even transitioned to Unstable yet!

Here’s what I’d like to see:

  1. Someone picks up Bug 15044/WorkLog 1293.
  2. 5.4 goes STABLE from MySQL/Sun/Oracle real soon now, with or without my pet qcache bug/feature – it’s a big enough win for multi-core systems as it stands
  3. Debian moves MySQl 5.1 from experimental straight to Unstable – can the mysql-server-5.1 package can coexist with mysql-server-5.0?
  4. Debian also adds, along side the MySQl 5.0 and 5.1 servers, the 5.4 into Unstable, and 6.0 into Experimental.