pg_migrate 7.5 KB

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