postgres の pg_dump のデータが溜まりすぎて、DAT にバックアップできなくなっていた。
2002-09-11 に書いた Postgres バックアップスクリプトに n 日以前のファイルを消すという処理を追加し、以下のようにした。また、バックアップ対象 DB を psql -l から取得するようにした。
pg_dumpall を使っていないのは、ラージオブジェクトを扱うためと、データベース毎にバックアップファイルを分けたかったから。
動作を確認した環境は PostgreSQL 7.2.1 + TurboLinux 6.5 Server だ。凝ったことはしていないので、バージョンが異なっても動くはずだ。cron に仕込んで夜間バッチなどで動かすときは、postgres 関連コマンドやディレクトリへのパスを設定するのを忘れずに。以下のスクリプトでは、 # Setting の部分で 環境変数を設定している。
私はこのスクリプトを postgres スーパーユーザの crontab に仕込んで毎日実行している。postgres スーパーユーザ以外で動かすこともできるとは思うが、データベースにアクセスするためにパスワードを要求されたりするかもしれず、いろいろ手間がかかりそうな予感。管理者権限を使いたくないという意見もあるかもしれないが、バックアップというのは本来管理者やオペレータが行う作業だし、素直に postgres スーパーユーザで実行してしまった方が楽だ。
「一般ユーザとして全部のデータベースをバックアップする」という状況ってあまり考えられない。どうしても管理者権限を使いたくないなら、以下のオプションを使ってできるんじゃないかと思う。試してないけど。
2002-09-11 に書いた Postgres バックアップスクリプトに n 日以前のファイルを消すという処理を追加し、以下のようにした。また、バックアップ対象 DB を psql -l から取得するようにした。
pg_dumpall を使っていないのは、ラージオブジェクトを扱うためと、データベース毎にバックアップファイルを分けたかったから。
動作を確認した環境は PostgreSQL 7.2.1 + TurboLinux 6.5 Server だ。凝ったことはしていないので、バージョンが異なっても動くはずだ。cron に仕込んで夜間バッチなどで動かすときは、postgres 関連コマンドやディレクトリへのパスを設定するのを忘れずに。以下のスクリプトでは、 # Setting の部分で 環境変数を設定している。
#/bin/sh
# PostgreSQL database backup script
# Version 1.1 [Apr. 17, 2002] Add routine: deleting exipired files.
# Version 1.0 [Sep. 10, 2002] First release.
# Saito Hiroaki <example@example.com>
# * Feature
# Dump to DATABASE_NAME_YYMMDD.pgdmp.
# Delete expired pgdmp file.
# Output log.
# Setting
PATH="$PATH":/usr/local/pgsql/bin
PG=/usr/local/pgsql
export LD_LIBRARY_PATH="$LD_LIBRARY_PATH":$PG/lib
export PGLIB=$PG/lib
export PGDATA=$PG/data
# Get all DB name
TARGET_DB=`psql -l -P format=unaligned -P fieldsep=, -P tuples_only |perl -F, -lane "if (@F[0] ne 'template0') {print @F[0]}"`
DIR=/home/postgres
LOG=$DIR/pgdump.log
BACKUPDIR=$DIR/dbbackup
EXPIRE_DAY=90
# Main routine
echo "pg_dump start." `date` >>$LOG
date=`date +%Y%m%d`
for db_name in $TARGET_DB
do
DUMP_FILE_PATH=$BACKUPDIR/${db_name}_${date}.pgdmp
/usr/local/pgsql/bin/pg_dump $db_name -b -o -Fc > $DUMP_FILE_PATH 2>>$LOG
echo "Database $db_name backup complete." `date` >>$LOG
done
echo "pg_dump complete." `date` >>$LOG
echo "Delete expired pgdmp file start." `date` >>$LOG
find $BACKUPDIR -type f -daystart -mtime +$EXPIRE_DAY |xargs /bin/rm -f
echo "Delete expired pgdmp file complete." `date` >>$LOG
私はこのスクリプトを postgres スーパーユーザの crontab に仕込んで毎日実行している。postgres スーパーユーザ以外で動かすこともできるとは思うが、データベースにアクセスするためにパスワードを要求されたりするかもしれず、いろいろ手間がかかりそうな予感。管理者権限を使いたくないという意見もあるかもしれないが、バックアップというのは本来管理者やオペレータが行う作業だし、素直に postgres スーパーユーザで実行してしまった方が楽だ。
「一般ユーザとして全部のデータベースをバックアップする」という状況ってあまり考えられない。どうしても管理者権限を使いたくないなら、以下のオプションを使ってできるんじゃないかと思う。試してないけど。
-U, --username=NAME connect as specified database user
-W, --password force password prompt (should happen automatically)
- すべての記事の見出し (全1029件)
 
- 全カテゴリの一覧と記事の数
 - カテゴリごとに記事をまとめ読みできます。記事の表題だけを見たい場合は、すべての記事の見出し (カテゴリ別表示) へ。
- .net (57件)
 - 2ch (19件)
 - amazon (5件)
 - Apache (22件)
 - bash (13件)
 - Bookmarklet (9件)
 - C# (45件)
 - chalow (18件)
 - ChangeLog メモ (20件)
 - coLinux (2件)
 - CSS (5件)
 - Delphi (5件)
 - DVD (6件)
 - Excel (1件)
 - F-ZERO (4件)
 - FF12 (31件)
 - ftp (8件)
 - Google (21件)
 - gpg (7件)
 - HTML (19件)
 - http (19件)
 - IE (10件)
 - IIS (4件)
 - iPod (2件)
 - JavaScript (14件)
 - Linux (63件)
 - MCP (6件)
 - Mozilla (14件)
 - MS SQL Server (30件)
 - MySQL (4件)
 - Namazu (3件)
 - PC (48件)
 - Perl (58件)
 - PHP (2件)
 - Postgres (36件)
 - proftpd (2件)
 - qmail (1件)
 - RFC (4件)
 - RSS (33件)
 - Ruby (15件)
 - samba (3件)
 - sonic64.com (6件)
 - SQL (15件)
 - Squid (3件)
 - ssh (7件)
 - Subversion (3件)
 - unix (31件)
 - VSS (2件)
 - Windows (34件)
 - winny (9件)
 - XML (9件)
 - xyzzy (17件)
 - おいでよ どうぶつの森 (19件)
 - お菓子 (5件)
 - アスキーアート (13件)
 - アニメ (9件)
 - クレジットカード (2件)
 - ゲーム (120件)
 - シェルスクリプト (18件)
 - シレン2 (8件)
 - セキュリティ (9件)
 - ソフトウェア (21件)
 - デザインパターン (2件)
 - ネットワーク (30件)
 - バックアップ (17件)
 - プログラミング (14件)
 - マリオカートDS (3件)
 - メール (26件)
 - メモ (116件)
 - ラーメン (11件)
 - 音楽 (59件)
 - 給油 (3件)
 - 三国志大戦 (13件)
 - 車 (7件)
 - 書斎 (4件)
 - 食 (30件)
 - 買い物 (17件)
 - 簿記 (8件)
 - 本 (32件)
 - 漫画 (9件)
 
 
- 2007-04-23 (Mon)
 - 2007-03-07 (Wed)
 - 2007-02-27 (Tue)
 - 2007-01-17 (Wed)
 - 2007-01-15 (Mon)
 - 2007-01-14 (Sun)
 - 2007-01-08 (Mon)
 - 2006-12-01 (Fri)
 - 2006-11-22 (Wed)
 - 2006-11-20 (Mon)
 - 2006-11-19 (Sun)
 - 2006-09-30 (Sat)
 - 2006-08-29 (Tue)
 - 2006-08-04 (Fri)
 - 2006-07-27 (Thu)
 - 2006-07-23 (Sun)
 - 2006-07-17 (Mon)
 - 2006-07-10 (Mon)
 - 2006-07-06 (Thu)
 - 2006-07-03 (Mon)
 - 2006-06-29 (Thu)
 - 2006-06-28 (Wed)
 - 2006-06-27 (Tue)
 - 2006-06-25 (Sun)
 - 2006-06-19 (Mon)
 - 2006-06-18 (Sun)
 - 2006-06-15 (Thu)
 - 2006-06-11 (Sun)
 - 2006-06-01 (Thu)
 - 2006-05-30 (Tue)
 
- プロファイル
 - 斎藤 宏明。エンジニアです。宇都宮市に住んでいます。
 - リンク
 - RSS
 - スポンサードリンク
 - Powered by
 - 
☆さくらインターネット☆