This blog is updated more than the home page might imply,
but only the most intersting stuff gets posted on the home page.
Compiling and installing PostgreSQL 17.2
03 Jan 2025
Another year, another version of Postgres to compile! This year, I added
compiling in ssl support, because as more and more stuff moves to the cloud,
and more and more clients connect to databases over insecure networks, the
more compiling in ssh is a neccesity.
Here are my notes.
Printer Madness in Ubuntu 22.04
19 Aug 2024
With Ubunu 22.04, getting a printer working suddenly seemed like it was
the early 2000s again.
Here are my notes.
Compiling and installing PostgreSQL 16.1
07 Dec 2023
I generally don't link this to the home page, but every time
a new version of PostgreSQL comes out, I compile and install it
on my Linux laptop and make notes about the process. Turns out
I've been doing this since version 9.3!
Here are my notes.
Version 5 of the excellent pgx
library for Go pulls in a number of useful functions from jackc's
own pgxutil library.
This is very nice, because one can basically almost always use
the Query() method of a pgx.Conn,
pgxpool.Pool, pgx.Tx, or pgxpool.Tx,
and then just hand the resulting pgx.Rows
into collectors such as pgx.CollectRows() and pgx.CollectOneRow(),
and into scanners such as pgx.RowTo(), pgx.RowToAddrOf(),
pgx.RowToMap(), etc.
This inspired me to write my own helper functions, because there were some
needs I had that are not currently covered by pgx 5. These helper functions
now live in a Go module named pgextras!
pgxtras allows one to select one row and not get an error from pgx
when nothing is found: the same way one does not get an error when
no rows are returned at a psql prompt.
pgxtras also has a more lenient version of a row scanner where
snake case column names are more easily/automatically mapped to
camel case Go struct field names.
This explores writing
fizzbuzz in Intel 64-bit assembler.
Multiline copy commands in psql!
13 Nov 2021
This explores a tip
I saw on another blog about how to do multiline copy commands
in psql.
Fun with tmux
2 Aug 2021
I finally got around to using tmux because I had a particular use-case
where I figured it would shine. Details
here.
Intro to assembler!
5 Jul 2021
I thought it would be a fun to try to write a very basic intro to assembler.
I didn't get very far, but I figured my
first few chapters
might make a nice blog entry.
Reading PostgreSQL Files with Go
21 Dec 2020
I thought it would be a fun learning exercise to try to parse a PostgreSQL
table file with Go.
I definitely learned a lot. :-)
AWS and aws
13 Dec 2020
Everybody's using AWS these days. I've started keeping notes on the more intersting
bits. In particular, the aws command-line utility is
very handy for us command-line junkies.
The book Hacker's Delight has a pretty neat way of counting
the 1-bits in an integer. But my exploration shows that modern Intel CPUs
have an instruction that do that for you, and that Go's math/bits library
takes advantage of that instruction. Nonetheless, I leave notes
that spell out the Hacker's Delight solution as obvoiusly as I can.
I've been reading parts of Katherine Cox-Buday's Concurrency in Go,
and I think this incomplete list of facts about channels and select statements
is useful. A full table of channel operation/state/result is on page 75;
these notes are just for me and whoever else may find them useful
Channels
a write to a full channel blocks until the channel is read from
a read from an empty channel blocks until the channel is writen to
a closed channel can be read from an infinite number of times
a write to a closed channel panics
Select Statements
all reads/writes are considered simultaneously for readiness
when no channels are ready, the entire select statement blocks
when more than one channel is ready, one will be chosen at random
defualt, if present, is run when all channels are blocked