pg_migrate 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. #!/bin/sh
  2. ##
  3. ## pg_migrate -- PostgreSQL Database Migration Utility
  4. ## Copyright (c) 2000-2003 Cable & Wireless Deutschland GmbH
  5. ## Copyright (c) 2000-2003 The OpenPKG Project <http://www.openpkg.org/>
  6. ## Copyright (c) 2000-2003 Ralf S. Engelschall <rse@engelschall.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. # establish sane environment
  31. LC_CTYPE=C
  32. export LC_CTYPE
  33. umask 022
  34. cmd="$1"
  35. shift
  36. case $cmd in
  37. dump )
  38. echo "++ enforcing full-superuser access policy"
  39. cp -p $l_prefix/var/postgresql/db/pg_hba.conf \
  40. $l_prefix/var/postgresql/db/pg_hba.conf.orig
  41. ( echo "local all trust"
  42. echo "host all 127.0.0.1 255.255.255.255 trust"
  43. ) >$l_prefix/var/postgresql/db/pg_hba.conf
  44. if [ ".`$l_prefix/etc/rc postgresql status 2>&1 | grep 'is running'`" != . ]; then
  45. echo "++ reloading already running database engine"
  46. $l_prefix/etc/rc postgresql reload
  47. sleep 2
  48. epilog=reload
  49. else
  50. echo "++ temporarily starting database engine"
  51. $l_prefix/etc/rc postgresql start
  52. sleep 4
  53. epilog=stop
  54. fi
  55. echo "++ rotating dump files $l_prefix/var/postgresql/db.dump*.sql.bz2"
  56. i=9
  57. rm -f $l_prefix/var/postgresql/db.dump.$i.sql.bz2 >/dev/null 2>&1 || true
  58. while [ $i -gt 0 ]; do
  59. j=$i
  60. i=`expr $i - 1`
  61. if [ $i -eq 0 ]; then
  62. prev="$l_prefix/var/postgresql/db.dump.sql.bz2"
  63. next="$l_prefix/var/postgresql/db.dump.$j.sql.bz2"
  64. else
  65. prev="$l_prefix/var/postgresql/db.dump.$i.sql.bz2"
  66. next="$l_prefix/var/postgresql/db.dump.$j.sql.bz2"
  67. fi
  68. if [ -f $prev ]; then
  69. mv $prev $next
  70. fi
  71. done
  72. echo "++ dumping all databases into $l_prefix/var/postgresql/db.dump.sql.bz2"
  73. $l_prefix/bin/pg_dumpall \
  74. -U postgresql -Spostgresql -o -Xuse-set-session-authorization |\
  75. $l_prefix/lib/openpkg/bzip2 -9 \
  76. >$l_prefix/var/postgresql/db.dump.sql.bz2
  77. chown ${l_rusr}:${l_rgrp} $l_prefix/var/postgresql/db.dump.sql.bz2
  78. chmod 700 $l_prefix/var/postgresql/db.dump.sql.bz2
  79. echo "++ restoring original access policy"
  80. cp -p $l_prefix/var/postgresql/db/pg_hba.conf.orig \
  81. $l_prefix/var/postgresql/db/pg_hba.conf
  82. rm -f $l_prefix/var/postgresql/db/pg_hba.conf.orig
  83. if [ ".$epilog" = .reload ]; then
  84. echo "++ reloading already running database engine (again)"
  85. $l_prefix/etc/rc postgresql reload
  86. sleep 2
  87. else
  88. echo "++ stopping temporarily started database engine"
  89. $l_prefix/etc/rc postgresql stop
  90. sleep 4
  91. fi
  92. ;;
  93. restore )
  94. if [ ".`$l_prefix/etc/rc postgresql status 2>&1 | grep 'is running'`" != . ]; then
  95. echo "++ stopping already running database engine"
  96. $l_prefix/etc/rc postgresql stop
  97. sleep 2
  98. epilog=start
  99. else
  100. epilog=none
  101. fi
  102. echo "++ rotating database directories $l_prefix/var/postgresql/db.old*/"
  103. i=9
  104. rm -rf $l_prefix/var/postgresql/db.old.$i >/dev/null 2>&1 || true
  105. while [ $i -gt 0 ]; do
  106. j=$i
  107. i=`expr $i - 1`
  108. if [ $i -eq 0 ]; then
  109. prev="$l_prefix/var/postgresql/db"
  110. next="$l_prefix/var/postgresql/db.old.$j"
  111. else
  112. prev="$l_prefix/var/postgresql/db.old.$i"
  113. next="$l_prefix/var/postgresql/db.old.$j"
  114. fi
  115. if [ -d $prev ]; then
  116. mv $prev $next
  117. fi
  118. done
  119. echo "++ creating new database directory $l_prefix/var/postgresql/db/"
  120. mkdir $l_prefix/var/postgresql/db
  121. chown ${l_rusr}:${l_rgrp} $l_prefix/var/postgresql/db
  122. chmod 700 $l_prefix/var/postgresql/db
  123. su - ${l_rusr} -c \
  124. "LC_CTYPE=C; export LC_CTYPE; umask 022; \
  125. (echo 'postgresql'; echo 'postgresql') |\
  126. $l_prefix/bin/pg_initdb -U postgresql -W -D $l_prefix/var/postgresql/db" 2>&1 |\
  127. $l_prefix/lib/openpkg/shtool prop \
  128. -p "++ creating new database data"
  129. echo "++ restoring database configurations"
  130. for conf in pg_hba.conf pg_ident.conf postgresql.conf; do
  131. cp -p $l_prefix/var/postgresql/db.old.1/$conf \
  132. $l_prefix/var/postgresql/db/
  133. done
  134. echo "++ enforcing full-superuser access policy"
  135. cp -p $l_prefix/var/postgresql/db/pg_hba.conf \
  136. $l_prefix/var/postgresql/db/pg_hba.conf.orig
  137. ( echo "local all trust"
  138. echo "host all 127.0.0.1 255.255.255.255 trust"
  139. ) >$l_prefix/var/postgresql/db/pg_hba.conf
  140. if [ ".$epilog" = .start ]; then
  141. echo "++ starting database engine"
  142. else
  143. echo "++ temporarily starting database engine"
  144. fi
  145. $l_prefix/etc/rc postgresql start
  146. sleep 4
  147. echo "++ restoring all databases from $l_prefix/var/postgresql/db.dump.sql.bz2"
  148. $l_prefix/lib/openpkg/bzip2 -c -d \
  149. $l_prefix/var/postgresql/db.dump.sql.bz2 |\
  150. $l_prefix/bin/psql -U postgresql -d template1 2>&1 |\
  151. tee $l_prefix/var/postgresql/db.log |\
  152. $l_prefix/lib/openpkg/shtool prop \
  153. -p "++ restoring data (see $l_prefix/var/postgresql/db.log)"
  154. echo "++ restoring original access policy"
  155. cp -p $l_prefix/var/postgresql/db/pg_hba.conf.orig \
  156. $l_prefix/var/postgresql/db/pg_hba.conf
  157. rm -f $l_prefix/var/postgresql/db/pg_hba.conf.orig
  158. if [ ".$epilog" = .start ]; then
  159. echo "++ reloading already running database engine"
  160. $l_prefix/etc/rc postgresql reload
  161. sleep 2
  162. else
  163. echo "++ stopping temporarily started database engine"
  164. $l_prefix/etc/rc postgresql stop
  165. sleep 4
  166. fi
  167. ;;
  168. esac