I’m checking out how postgres works.
I installed it to 32-bit ubuntu version 12.04. Googling lead to multiple places for the appropriate apt-get commands.
The install created a user, postgres, that runs the postgres binaries. However, root owns the binary files.
A default instance got created. I haven’t learned yet if people often run multiple postgres instances per host.
The following processes run with the default installation:
/usr/lib/postgresql/9.1/bin/postgres
postgres: writer process
postgres: WAL process
postgres: autovacuum launcher
postgres: stats collector process
The first process is the main postgres process, and it was launched with the -D parameter pointing to a specific directory and the -c parameter pointing to the full path of the postgres.conf file.
The writer process I’m surmising must write to data files, and the WAL process I’ve read elsewhere is the Write Ahead Log, similar to redo log writer in Oracle. Autovacuum launcher governs the ability to automatically run the VACUUM command, which is needed in Postgres periodically. And I’m sure the stats collector updates query optimization stats, but I’ll have to check.
There’s a command psql that is the equal of sqlplus. I’ll explore psql in a follow up post.
Documentation for postgres can be found at postgresql.org.
Having worked as a SQL Server and Oracle DBA, keeping track of database storage is important. Documentation for those two products describes early on how each system places all objects into datafiles. A datafile can contain tables, indexes, stored procedures, views and everything else.
Postgres on the other hand relegates discussion of physical storage to a location fairly deep in the documentation. Each table gets its own datafile. A master directory tree contains all the object in the postgres database, with most objects getting their own separate file. And postgres dictates the directory structure, although perhaps in more advanced deployments users can control some aspects. The filenames have a number which is automatically generated by postgres. My instance installed to /var/lib/postgresql/9.1/main. There are multiple sub-directories below that.
Done writing for now, but I’m going to create some tables, bang around with psql and try out the gui admin tool pgadmin III.