pg_migrate 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. #!/bin/sh
  2. ##
  3. ## pg_migrate -- PostgreSQL Database Migration Utility
  4. ## Copyright (c) 2000-2007 OpenPKG Foundation e.V. <http://openpkg.net/>
  5. ## Copyright (c) 2000-2007 Ralf S. Engelschall <http://engelschall.com/>
  6. ##
  7. ## Permission to use, copy, modify, and distribute this software for
  8. ## any purpose with or without fee is hereby granted, provided that
  9. ## the above copyright notice and this permission notice appear in all
  10. ## copies.
  11. ##
  12. ## THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
  13. ## WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
  14. ## MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  15. ## IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR
  16. ## CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  17. ## SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  18. ## LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  19. ## USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  20. ## ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  21. ## OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  22. ## OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  23. ## SUCH DAMAGE.
  24. ##
  25. # configuration
  26. l_prefix="@l_prefix@"
  27. l_rusr="@l_rusr@"
  28. l_rgrp="@l_rgrp@"
  29. # load superuser information
  30. l_pgdata=""
  31. l_pguser=""
  32. l_pgpass=""
  33. if [ -r @l_prefix@/var/db/postgresql/pg_superuser.conf ]; then
  34. eval `. @l_prefix@/var/db/postgresql/pg_superuser.conf; \
  35. echo l_pgdata=\"$superuser_database\"; \
  36. echo l_pguser=\"$superuser_username\"; \
  37. echo l_pgpass=\"$superuser_password\"`
  38. fi
  39. # establish sane environment
  40. LC_CTYPE=C
  41. export LC_CTYPE
  42. umask 022
  43. # check command line
  44. if [ $# -ne 1 -a $# -ne 2 ]; then
  45. echo "$0:ERROR: invalid command line" 1>&2
  46. echo "$0:USAGE: $0 dump|restore [<password>]" 1>&2
  47. exit 1
  48. fi
  49. cmd="$1"; shift
  50. if [ $# -eq 1 ]; then
  51. l_pgpass="$1"; shift
  52. fi
  53. # dispatch into commands
  54. case $cmd in
  55. dump )
  56. echo "++ enforcing full-superuser access policy"
  57. cp -p $l_prefix/var/postgresql/db/pg_hba.conf \
  58. $l_prefix/var/postgresql/db/pg_hba.conf.orig
  59. ( echo "local all trust"
  60. echo "host all 127.0.0.1 255.255.255.255 trust"
  61. ) >$l_prefix/var/postgresql/db/pg_hba.conf
  62. if [ ".`$l_prefix/bin/openpkg rc postgresql status 2>&1 | grep 'is running'`" != . ]; then
  63. echo "++ reloading already running database engine"
  64. $l_prefix/bin/openpkg rc postgresql reload
  65. sleep 2
  66. epilog=reload
  67. else
  68. echo "++ temporarily starting database engine"
  69. $l_prefix/bin/openpkg rc postgresql start
  70. sleep 4
  71. epilog=stop
  72. fi
  73. echo "++ rotating dump files $l_prefix/var/postgresql/db.dump*.sql.bz2"
  74. i=9
  75. rm -f $l_prefix/var/postgresql/db.dump.$i.sql.bz2 >/dev/null 2>&1 || true
  76. while [ $i -gt 0 ]; do
  77. j=$i
  78. i=`expr $i - 1`
  79. if [ $i -eq 0 ]; then
  80. prev="$l_prefix/var/postgresql/db.dump.sql.bz2"
  81. next="$l_prefix/var/postgresql/db.dump.$j.sql.bz2"
  82. else
  83. prev="$l_prefix/var/postgresql/db.dump.$i.sql.bz2"
  84. next="$l_prefix/var/postgresql/db.dump.$j.sql.bz2"
  85. fi
  86. if [ -f $prev ]; then
  87. mv $prev $next
  88. fi
  89. done
  90. echo "++ dumping all databases into $l_prefix/var/postgresql/db.dump.sql.bz2"
  91. PGPASSWORD="$l_pgpass" \
  92. $l_prefix/bin/pg_dumpall \
  93. -U $l_pguser -o |\
  94. $l_prefix/lib/openpkg/bzip2 -9 \
  95. >$l_prefix/var/postgresql/db.dump.sql.bz2
  96. chown ${l_rusr}:${l_rgrp} $l_prefix/var/postgresql/db.dump.sql.bz2
  97. chmod 700 $l_prefix/var/postgresql/db.dump.sql.bz2
  98. echo "++ restoring original access policy"
  99. cp -p $l_prefix/var/postgresql/db/pg_hba.conf.orig \
  100. $l_prefix/var/postgresql/db/pg_hba.conf
  101. rm -f $l_prefix/var/postgresql/db/pg_hba.conf.orig
  102. if [ ".$epilog" = .reload ]; then
  103. echo "++ reloading already running database engine (again)"
  104. $l_prefix/bin/openpkg rc postgresql reload
  105. sleep 2
  106. else
  107. echo "++ stopping temporarily started database engine"
  108. $l_prefix/bin/openpkg rc postgresql stop
  109. sleep 4
  110. fi
  111. ;;
  112. restore )
  113. if [ ".`$l_prefix/bin/openpkg rc postgresql status 2>&1 | grep 'is running'`" != . ]; then
  114. echo "++ stopping already running database engine"
  115. $l_prefix/bin/openpkg rc postgresql stop
  116. sleep 2
  117. epilog=start
  118. else
  119. epilog=none
  120. fi
  121. echo "++ rotating database directories $l_prefix/var/postgresql/db.old*/"
  122. i=9
  123. rm -rf $l_prefix/var/postgresql/db.old.$i >/dev/null 2>&1 || true
  124. while [ $i -gt 0 ]; do
  125. j=$i
  126. i=`expr $i - 1`
  127. if [ $i -eq 0 ]; then
  128. prev="$l_prefix/var/postgresql/db"
  129. next="$l_prefix/var/postgresql/db.old.$j"
  130. else
  131. prev="$l_prefix/var/postgresql/db.old.$i"
  132. next="$l_prefix/var/postgresql/db.old.$j"
  133. fi
  134. if [ -d $prev ]; then
  135. mv $prev $next
  136. fi
  137. done
  138. echo "++ creating new database directory $l_prefix/var/postgresql/db/"
  139. mkdir $l_prefix/var/postgresql/db
  140. chown ${l_rusr}:${l_rgrp} $l_prefix/var/postgresql/db
  141. chmod 700 $l_prefix/var/postgresql/db
  142. su - ${l_rusr} -c \
  143. "LC_CTYPE=C; export LC_CTYPE; umask 022; \
  144. echo $l_pgpass >$l_prefix/var/postgresql/run/pw; \
  145. $l_prefix/bin/pg_initdb \
  146. -U $l_pguser --pwfile=$l_prefix/var/postgresql/run/pw \
  147. -D $l_prefix/var/postgresql/db; \
  148. rm -f $l_prefix/var/postgresql/run/pw" 2>&1 |\
  149. $l_prefix/lib/openpkg/shtool prop \
  150. -p "++ creating new database data"
  151. echo "++ restoring database configurations"
  152. for conf in pg_hba.conf pg_ident.conf postgresql.conf; do
  153. cp -p $l_prefix/var/postgresql/db.old.1/$conf \
  154. $l_prefix/var/postgresql/db/
  155. done
  156. echo "++ enforcing full-superuser access policy"
  157. cp -p $l_prefix/var/postgresql/db/pg_hba.conf \
  158. $l_prefix/var/postgresql/db/pg_hba.conf.orig
  159. ( echo "local all trust"
  160. echo "host all 127.0.0.1 255.255.255.255 trust"
  161. ) >$l_prefix/var/postgresql/db/pg_hba.conf
  162. if [ ".$epilog" = .start ]; then
  163. echo "++ starting database engine"
  164. else
  165. echo "++ temporarily starting database engine"
  166. fi
  167. $l_prefix/bin/openpkg rc postgresql start
  168. sleep 4
  169. echo "++ restoring all databases from $l_prefix/var/postgresql/db.dump.sql.bz2"
  170. $l_prefix/lib/openpkg/bzip2 -c -d \
  171. $l_prefix/var/postgresql/db.dump.sql.bz2 |\
  172. $l_prefix/bin/psql -U $l_pguser -d $l_pgdata 2>&1 |\
  173. tee $l_prefix/var/postgresql/db.log |\
  174. $l_prefix/lib/openpkg/shtool prop \
  175. -p "++ restoring data (see $l_prefix/var/postgresql/db.log)"
  176. echo "++ restoring original access policy"
  177. cp -p $l_prefix/var/postgresql/db/pg_hba.conf.orig \
  178. $l_prefix/var/postgresql/db/pg_hba.conf
  179. rm -f $l_prefix/var/postgresql/db/pg_hba.conf.orig
  180. if [ ".$epilog" = .start ]; then
  181. echo "++ reloading already running database engine"
  182. $l_prefix/bin/openpkg rc postgresql reload
  183. sleep 2
  184. else
  185. echo "++ stopping temporarily started database engine"
  186. $l_prefix/bin/openpkg rc postgresql stop
  187. sleep 4
  188. fi
  189. ;;
  190. * )
  191. echo "$0:ERROR: unknown command \"$cmd\"" 1>&2
  192. exit 1
  193. ;;
  194. esac