twittering on 2009-02-15
- coraline was amazing! would like to see it again! thanks laika. #
- watching scooter play with his new G1. #
- RT @planetpostgres: Magnus Hagander: Summary: Prague PostgreSQL Developers Day http://tr.im/gcl4 #
- @markwkm do you have a graph of before/after performance for that? #
- headed out to get waffle fixins. #
twittering on 2009-02-14
- @aboutus thanks so much! 🙂 #
- @brampitoyo just signed up for the session.. scott even wanted to come! hope that’s ok… #
- @Crad good to know. we’re getting ext4 to fail consistently on some read-write tests :/ so we need to try an updated patch set, i think. #
- @Crad interesting. we’re just using fio for these tests. #
- @hideshione thank you so much for the session! learned a lot, and my husband and i have a couple diagrams to share 🙂 #
- @brampitoyo YES!! very much so. #
- @brampitoyo would love to! idea/model tweetups! #
- @msamye i mentioned to @brampitoyo that TravelPortland is da bomb. if you aren’t already talking to them, they would be very helpful. #
- @brampitoyo hahaha. maybe it can be a lunch tweetup in NE somewhere. tuesday? #
- @brampitoyo yes! the next week would be good. #
- had delish v-day breakfast with scoots – is it weird that i had oatmeal *and* strawberries in champagne? headed out for more fun. #
- @AE3nn haha the former 😉 now, for some exciting valentine’s day action at powells! #
- http://flickr.com/photos/selenamarie/3279825398 #
twittering on 2009-02-13
- ? @pdxpug: P5 #2 is tonight: http://pugs.postgresql.org/node/504 #
- booked flight & rooms for SCALE 7x 🙂 #
- at #p5 dbt-2 testing meeting #
- #p5 determining database row size – http://tinyurl.com/dh6ajb #
- @fuzzychef thanks for plugging #osbridgepdx #
- @ravenme you are so wholesome! #
- @hideshione hope you feel better 🙂 #
- Here is what @rjfm did to get his masters #p5 http://flickr.com/photos/selenamarie/3275278653 #
- @arjenvrielink ugh. selfishness is not the highest virtue. just don’t become an objectivist 🙂 in reply to arjenvrielink #
- fail harder: http://tinyurl.com/2sc6yb (sorry to whoever tweeted that, already lost it in the stream…) #
- @Crad did you ever blog about the ext4 FAIL? #
- OH: “buce” is teh new “teh” #
- ? @hideshione: today…. embrace the artist in you! http://tinyurl.com/c47y4g #
- @ev glad to hear that people think twitter is worth investing money, not just time #
- ? @turnstep: Loving session_replication_role – thanks Jan! #
- (that was some #postgres-specific love there, people) #
- @gaberivera http://coolepochcountdown.com/ #
- (i guess once again i should attribute that to @murwiz) #
- @niczak TACOOOOS!!!! #
- @karichisholm can I get a feed of just a single contributor? I love you all, but i love Karol the most and don’t want to miss her posts. #
twittering on 2009-02-13
- ? @pdxpug: P5 #2 is tonight: http://pugs.postgresql.org/node/504 #
- booked flight & rooms for SCALE 7x 🙂 #
- at #p5 dbt-2 testing meeting #
- #p5 determining database row size – http://tinyurl.com/dh6ajb #
- @fuzzychef thanks for plugging #osbridgepdx #
- @ravenme you are so wholesome! #
- @hideshione hope you feel better 🙂 #
- Here is what @rjfm did to get his masters #p5 http://flickr.com/photos/selenamarie/3275278653 #
- @arjenvrielink ugh. selfishness is not the highest virtue. just don’t become an objectivist 🙂 in reply to arjenvrielink #
- fail harder: http://tinyurl.com/2sc6yb (sorry to whoever tweeted that, already lost it in the stream…) #
- @Crad did you ever blog about the ext4 FAIL? #
- OH: “buce” is teh new “teh” #
- ? @hideshione: today…. embrace the artist in you! http://tinyurl.com/c47y4g #
- @ev glad to hear that people think twitter is worth investing money, not just time #
- ? @turnstep: Loving session_replication_role – thanks Jan! #
- (that was some #postgres-specific love there, people) #
- @gaberivera http://coolepochcountdown.com/ #
- (i guess once again i should attribute that to @murwiz) #
- @niczak TACOOOOS!!!! #
- @karichisholm can I get a feed of just a single contributor? I love you all, but i love Karol the most and don’t want to miss her posts. #
twittering on 2009-02-12
- thank you @gorthx for awesome 4 mi run #
- @karolcooks 🙂 i mean it. #
- @EvaCatHerder happy bday 🙂 #
- mmmm. coffee. #
- excited to have a waffle-meetup at my house this weekend to work on #osbridge conference ware #
- Varnish in action: http://perbu.livejournal.com/6895.html #
- happy to see coworkers @axisofentropy and @murwiz in my tweetstream 🙂 #
- @magnushagander well, i’m following @perbu now if its any consolation. #
- ‘caller’ perl function FTW! #
- @kcomandich if you’re interested – in the app or the waffles – you should come too 🙂 #
- what’s cheaper than therapy? @methneighbor #
- (disclaimer: not my neighbor) #
- @ljbanks gives you hope for humanity, eh? #
- @sumwan 🙁 #
- not sure how I feel about @methneighbor following me. will he move in next door next? #
- and what kind of DMs will I get? #
- waffle-induced development http://tr.im/fzy8 #
- @AaronThul have a great time!! 🙂 #
- @spinnerin i know someone who did that, and has gotten 3 years worth of funding out of it 🙂 #
- @spinnerin the trick is often making sure that the work is accepted back by the main development community #
- @spinnerin yes, definitely. i think it would be harder if the company was a corp, and dev didn’t have a formal agreement ahead of time #
- @spinnerin have also seen that model work with devs register and have a “dev license” agreement with commercial company #
Waffle-induced development
My waffles will probably not look as good as this.
People often ask me for advice on how to motivate and get people excited about coming to meetings, participating in user groups and contributing to projects. I’m going to try to blog more about the things I do that work.
Friends in Portland know that I often use food (and sometimes alcohol) bribes to get them to come over to my house to hang out, and then do work that is best done with a group (recall a major weeding project in my front yard).
We needed a few good folks to help out with the next phase of our Open Conference Ware application, and so I decided to reuse this “get house chores done” trick to hopefully motivate a few hungry developers to work with us on the next phase of the project.
When I sent out the message, I got both an enthusiastic “Hell yes, I’ll come for waffles”, and an “Oh man, I already had plans — which, if they fall through, I will totally be there for the waffles.”
I’m sure that the good people who stepped up to help us would have done so anyway. But, if I can provide a warm breakfast while we hack away on wireframes, why not? And, after I tweeted what we were up to, I got another volunteer!
Image courtesy of rizkapb, Creative Commons 2.0 generic license.
twittering on 2009-02-11
- @nentis @stevelle awesome! will keep you posted on user group developments. #
- ? @jonobacon: Har. http://tinyurl.com/46ehpm #
- @jdub moar cuteness! #
- @karolcooks maybe we should have our own v-day party. and make delicious pastries and walk around our neighborhood giving them away. #
- excited by the #configmgmt/#puppet user group interest! will likely have a meetup next friday after beer&blog. stay posted! #
- @ramereth probably 2/27 … will post dates soon, and it’ll be on calagator. #
- @ramereth cool! probably 6ish. getting together to meet and plan for the future of the group. there’s been SO much interest. #
- @muckp +1 #
- @cscotta was a textbook for C++ that I got for school. still reference it when i’ve got C++ stuff to do. after that, perl in 21 days 😀 #
- http://flickr.com/photos/selenamarie/3272861534 #
- http://flickr.com/photos/selenamarie/3272053227 #
- @skinny i heard @donpdonp got it at THE MALL! and there’s supposedly video #
- @ahockley I missed having nametags this time at lunch2.0. NOT THAT I AM COMPLAINING ABOUT A FREE LUNCH. #
twittering on 2009-02-10
- home, and just rounding up the last bits of blogging and email before trying to re-adjust to PST. #
- oh cool, slideshare featured the leading without being in charge slides from #fosdem 🙂 http://tr.im/fjbl #
- ugh. timesheet fail. lost a very long entry. 🙁 #
- whoa, scappoose is out for the day! #pdxst #
- today’s coffee: stumptown house blend roasted on 2/8 #
- @PINguAR ugh. that sucks. #
- Puppet (the configuration management system) users? raise your hands please. would like a meetup in portland, w/sponsored beer. pls @ or dm #
- @sheltren i promise not to tell anyone your little secret. so, yes. #
- @jshirley thanks for the tip! #
- having a “cat at basement window” FAIL. #
- @erth64net awesome! will keep you posted. #
FSM, visibility map and new VACUUM awesomeness
Heikki Linnakangas, listening as Simon Riggs sketches on the chalkboard.
Update: Heikki’s slides are here!
Heikki Linnakangas gave a presentation this past Sunday at FOSDEM about the improved free space map (FSM), which tracks unused space inside the database, and new visibility map, a bitmap which will indicate which data pages can be skipped during a partial VACUUM. This performance enhancement will affect all users of the upcoming 8.4 software release. You can see what the new FSM implementation looked like back in October from depesz’s blog.
Despite Heikki’s modest claim during the talk that the performance tests were inconclusive, the consensus among Postgres contributors is that this feature will result a substantial improvement in the performance of VACUUM for tables that are large, but have few UPDATEs.
The new free space map and Visibility map (in 8.4) and autovacuum (enabled by default starting in version 8.2) are huge administrative usability improvements to version 8 of Postgres. Prior to version 8.1, VACUUM had to be scheduled outside of database system. Autovacuum has been part of the core Postgres distribution for over two years, and is tunable via several global configuration parameters.
The visibility map enables partial VACUUMs — meaning that VACUUM no longer has to examine every tuple to update the FSM. The new FSM implementation eliminates two configuration parameters, effectively automating a formerly manual configuration process.
The new FSM is stored on disk in seperate files inside of $PGDATA/base/, and is cached in shared_buffers. The result is that the max_fsm_* configuration parameters are no longer in 8.4 — Postgres is able to track and adjust this data structure without user intervention.
A few critical features of the new FSM are:
* Now a binary tree structure
* Constructed using 1 byte per heap page
* The top level shows the maximum amount of contiguous space available
* The data structure is auto-repairing and can be reconstructed from the bottom
Previously, every time that VACUUM was run, the free space map had to be reconstructed from scratch. Now, individual nodes in the map may be updated (aka “retail” updates).
Visibility map is a bitmap of heap pages which tracks which tuples on pages are visible to transactions, and therefore not available for VACUUMing.
Previously, when VACUUM ran, it *had* to look at every tuple in a table, because there was no information about which pages may not have been updated since the last VACUUM. With the visibility map, VACUUM will now be able to perform partial scans of table data, skipping pages which are marked as fully visible. Partial scans means fewer I/O operations for VACUUM, and happier database administrators.