Project

General

Profile

1 6666 aaronmk
##### Configuration
2
3
src_server ?= jupiter
4
5
6 6522 aaronmk
selfDir_NzrNZp := $(dir $(lastword $(MAKEFILE_LIST)))
7
root := $(selfDir_NzrNZp)..
8
include $(root)/lib/common.Makefile
9 3699 aaronmk
10
11 3393 aaronmk
##### Vars/functions
12
13 3403 aaronmk
# Make
14
SHELL := /bin/bash
15
16 3438 aaronmk
# OS
17
isMac := $(filter Darwin,$(os))
18 3393 aaronmk
19 3438 aaronmk
# System
20
dateFmt := %Y-%m-%d-%H-%M-%S
21
mtime = $(shell $(if $(isMac),stat -f %Sm -t "$(dateFmt)" $(1),date\
22
--reference=$(1) +"$(dateFmt)"))
23
24
# Paths
25 6522 aaronmk
bin := $(root)/bin
26 3438 aaronmk
27 3393 aaronmk
# DB
28
psqlVerbose := $(bin)/psql_script_vegbien --echo-all
29
pg_dump := $(bin)/pg_dump_vegbien
30 3404 aaronmk
backup := "time" env data=1 $(pg_dump)
31
restore := "time" $(bin)/postgres_vegbien pg_restore --exit-on-error
32
restoreBien := $(restore) --dbname=vegbien
33
# pg_restore doesn't support PGDATABASE env var
34 3393 aaronmk
rmSchema = 'DROP SCHEMA IF EXISTS "$(1)" CASCADE;'
35
36 3437 aaronmk
##### Backups
37 3393 aaronmk
38 6526 aaronmk
backups := $(wildcard *.backup)
39
40 6571 aaronmk
#### Checksums
41
42 6526 aaronmk
md5s: _always $(backups:%=%.md5) ;
43
44 6520 aaronmk
%.md5: %
45 6536 aaronmk
	nice -n +5 md5sum $<|cut -d ' ' -f 1 >$@
46 6520 aaronmk
47 6573 aaronmk
%.md5/test: %.md5 % _always
48 6655 aaronmk
	echo '$(shell cat $<)  $*'|nice -n +5 md5sum -$(if $(isMac),v)c /dev/stdin
49 6572 aaronmk
50 6571 aaronmk
#### SQL
51
52 6520 aaronmk
# Must come before %.sql with no prerequisites to be matched first
53 3395 aaronmk
%.sql: %
54 3399 aaronmk
	$(restore) $< >$@
55 3395 aaronmk
56 4751 aaronmk
# Full DB
57
# Must come before %.backup to be matched first
58
vegbien.%.backup:
59
	$(backup) all >$@
60 6648 aaronmk
	$(MAKE) $@.md5
61 4751 aaronmk
62 3544 aaronmk
backup* = $(backup) $* >$@
63
64 3393 aaronmk
# Note: This can't be used for the current (unrotated) public schema because
65
# pg_dump doesn't back up the CREATE SCHEMA statement for it, assuming falsely
66
# that public already exists because it's in template1.
67 3543 aaronmk
%.backup:
68
	$(backup*)
69 6521 aaronmk
	$(MAKE) $@.md5
70 3544 aaronmk
71
# When testing, turn off %.sql so make won't skip `%.sql: %` in favor of it
72
ifeq ($(filter %.backup/test,$(MAKECMDGOALS)),)
73 3543 aaronmk
%.sql:
74
	env plain=1 $(backup*)
75 3544 aaronmk
endif
76 3393 aaronmk
77 3402 aaronmk
%.backup/restore: %.backup _always
78 3399 aaronmk
	$(restoreBien) $<
79 3393 aaronmk
80 3402 aaronmk
%.sql/restore: %.sql _always
81
	$(bin)/psql_script_vegbien <$<
82
# pg_restore only supports "non-plain-text formats"
83
# (http://www.postgresql.org/docs/9.1/static/app-pgrestore.html)
84
85 3409 aaronmk
%.backup/test: %.backup.sql _always
86
	rm $<
87
88 3438 aaronmk
%.backup/rotate: %.backup _always
89
	mv $< $*.$(call mtime,$<).backup
90
91 3437 aaronmk
#### Archived imports
92 3393 aaronmk
93
confirmRm = $(call confirm,WARNING: This will delete the archived import $(1)!)
94
95 6645 aaronmk
public* = $(*:vegbien.%=public.%)
96
97 3393 aaronmk
%.backup/remove: %.backup _always
98 6645 aaronmk
	@$(call confirmRm,$(public*))
99
	echo $(call rmSchema,$(public*))|$(bin)/psql_script_vegbien
100 3393 aaronmk
101
%.backup/rm_indexes: %.backup _always
102
	$(pg_dump) $*|$(bin)/mk_rm_indexes|$(psqlVerbose)
103 3407 aaronmk
104 3701 aaronmk
##### Synchronization
105
106 6890 aaronmk
remote := $(src_user)@$(src_server):/data/dev/aaronmk/bien/backups/
107 6666 aaronmk
108 6469 aaronmk
rsyncBackups := $(rsync) --include="/*.backup" --include="/*.sql"\
109 6595 aaronmk
--include="/*.csv" --include="/*.md5" --exclude="**"
110 3701 aaronmk
111
upload: _always
112
	$(rsyncBackups) $(local) $(remote)
113 6667 aaronmk
114
%/download: _always
115
	$(rsync) $(remote)$* $(local)$*
116 6724 aaronmk
	-$(if $(filter %.md5,$*),,$(MAKE) $*.md5/download)
117
# ignore errors if $*.md5 does not exist