{{ Template:message/note | There's a known bug in !TurboGears that causes MySQL clients not to automatically reconnect when lost. Typically a restart of the !TurboGears application will correct this issue.

+

{{admon/note|There's a known bug in !TurboGears that causes MySQL clients not to automatically reconnect when lost. Typically a restart of the !TurboGears application will correct this issue.}}

Database - SOP

Contact Information

Owner: Fedora Infrastructure Team

Contact: #fedora-admin, sysadmin-main, sysadmin-dba group

Location: Phoenix

Servers: db1, db2

Purpose: Provides database connection to many of our apps.

Description

db1 and db2 are our primary database servers. db1 contains the MySQL instance, db2 contains postgresql. Each database server replicates to itself and the other through a dump style backup. In a normal situation, db1 runs only MySQL, not postgresql. While db2 runs only postgresql not MySQL. Which is running on which is defined in the puppet configs, specifically the node manifest for each server (nodes/db1.fedora.phx.redhat.com.pp and nodes/db2.fedora.phx.redhat.com.pp)

Troubleshooting and Resolution

Connection issues

There are no known outstanding issues with the database itself. Remember that every time either database is restarted, services will have to be restarted (see below).

Some useful queries

What queries are running

This can help you find out what queries are cuurently running on the server::

This can help you find how many connections to the db server are for each individual database::

select datname, count(datname) from pg_stat_activity group by datname
order by count desc;

Seeing how "dirty" a table is

We've added a function from postgres's contrib directory to tell how dirty a table is. By dirty we mean, how many tuples are active, how many have been marked as having old data (and therefore "dead") and how much free space is allocated to the table but not used.

Vacuum should clear out dead_tuples. Only a vacuum full, which will lock the table and therefore should be avoided, will clear out free space.

XID Wraparound

Find out how close we are to having to perform a vacuum of a database (as opposed to individual tables of the db). We should schedule a vacuum when about 50% of the transaction ids have been used (approximately 530,000,000 xids):

Restart Procedure

If the database server needs to be restarted it should come back on it's own. Otherwise each service on it can be restarted:

service mysqld restart
service postgresql restart

Koji

Any time postgreql is restarted, koji needs to be restarted. Please also see Restarting Koji

Mirror Manager

Anytime postgresql is restarted Mirror Manager will need to be restarted, no SOP currently exists for this

Vacuuming Mirror Manager

Occasionally our vacuum cron jobs may not keep up with the writes to the mirrormanager database. If this happens, we need to do a vacuum full of mirrormanager's db. (See the dirty table section for a query to tell if this is necessary). The trick with this is making sure the mirrorlist cache
isn't updated while we're doing the vacuum. To disable that we can turn off the mirrormanager management interface: