app_admin.sh 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. #!/bin/bash
  2. set -e
  3. source /etc/profile
  4. export JAVA_HOME=/usr/java/latest
  5. export PATH=$JAVA_HOME/bin:$PATH
  6. touch /tmp/start.log
  7. chown admin: /tmp/start.log
  8. chown -R admin: /home/admin/canal-admin
  9. host=`hostname -i`
  10. MYSQL_USER_PASSWORD=`perl -le 'print $ENV{"spring.datasource.password"}'`
  11. MYSQL_USER=`perl -le 'print $ENV{"spring.datasource.username"}'`
  12. MYSQL_DATABASE=`perl -le 'print $ENV{"spring.datasource.database"}'`
  13. MYSQL_ADDRESS=`perl -le 'print $ENV{"spring.datasource.address"}'`
  14. if [ -z "${MYSQL_USER_PASSWORD}" ]; then
  15. MYSQL_USER_PASSWORD="canal"
  16. fi
  17. if [ -z "${MYSQL_USER}" ]; then
  18. MYSQL_USER="canal"
  19. fi
  20. if [ -z "${MYSQL_DATABASE}" ]; then
  21. MYSQL_DATABASE="canal_manager"
  22. fi
  23. # waitterm
  24. # wait TERM/INT signal.
  25. # see: http://veithen.github.io/2014/11/16/sigterm-propagation.html
  26. waitterm() {
  27. local PID
  28. # any process to block
  29. tail -f /dev/null &
  30. PID="$!"
  31. # setup trap, could do nothing, or just kill the blocker
  32. trap "kill -TERM ${PID}" TERM INT
  33. # wait for signal, ignore wait exit code
  34. wait "${PID}" || true
  35. # clear trap
  36. trap - TERM INT
  37. # wait blocker, ignore blocker exit code
  38. wait "${PID}" 2>/dev/null || true
  39. }
  40. # waittermpid "${PIDFILE}".
  41. # monitor process by pidfile && wait TERM/INT signal.
  42. # if the process disappeared, return 1, means exit with ERROR.
  43. # if TERM or INT signal received, return 0, means OK to exit.
  44. waittermpid() {
  45. local PIDFILE PID do_run error
  46. PIDFILE="${1?}"
  47. do_run=true
  48. error=0
  49. trap "do_run=false" TERM INT
  50. while "${do_run}" ; do
  51. PID="$(cat "${PIDFILE}")"
  52. if ! ps -p "${PID}" >/dev/null 2>&1 ; then
  53. do_run=false
  54. error=1
  55. else
  56. sleep 1
  57. fi
  58. done
  59. trap - TERM INT
  60. return "${error}"
  61. }
  62. function checkStart() {
  63. local name=$1
  64. local cmd=$2
  65. local timeout=$3
  66. cost=5
  67. while [ $timeout -gt 0 ]; do
  68. ST=`eval $cmd`
  69. if [ "$ST" == "0" ]; then
  70. sleep 1
  71. let timeout=timeout-1
  72. let cost=cost+1
  73. elif [ "$ST" == "" ]; then
  74. sleep 1
  75. let timeout=timeout-1
  76. let cost=cost+1
  77. else
  78. break
  79. fi
  80. done
  81. echo "start $name successful"
  82. }
  83. function start_mysql() {
  84. echo "start mysql ..."
  85. # start mysql
  86. MYSQL_ROOT_PASSWORD=Hello1234
  87. # connect local mysql
  88. if [ -z "$(ls -A /var/lib/mysql)" ]; then
  89. mysql_install_db --user=mysql --datadir=/var/lib/mysql 1>>/tmp/start.log 2>&1
  90. # These statements _must_ be on individual lines, and _must_ end with
  91. # semicolons (no line breaks or comments are permitted).
  92. # TODO proper SQL escaping on ALL the things D:
  93. TEMP_FILE='/tmp/init.sql'
  94. echo "update mysql.user set password=password('${MYSQL_ROOT_PASSWORD}') where user='root';" >> $TEMP_FILE
  95. echo "grant all privileges on *.* to 'root'@'%' WITH GRANT OPTION ;" >> $TEMP_FILE
  96. echo "create database if not exists $MYSQL_DATABASE ;" >> $TEMP_FILE
  97. echo "create user $MYSQL_USER identified by '$MYSQL_USER_PASSWORD' ;" >> $TEMP_FILE
  98. echo "grant all privileges on $MYSQL_DATABASE.* to '$MYSQL_USER'@'%' identified by '$MYSQL_USER_PASSWORD' ;" >> $TEMP_FILE
  99. echo "grant all privileges on $MYSQL_DATABASE.* to '$MYSQL_USER'@'localhost' identified by '$MYSQL_USER_PASSWORD' ;" >> $TEMP_FILE
  100. echo "flush privileges;" >> $TEMP_FILE
  101. service mysqld start
  102. checkStart "mysql" "echo 'show status' | mysql -s -h127.0.0.1 -P3306 -uroot | grep -c Uptime" 30
  103. mysql -h127.0.0.1 -uroot -e "source $TEMP_FILE" 1>>/tmp/start.log 2>&1
  104. cmd="mysql -h127.0.0.1 -u$MYSQL_USER -p$MYSQL_USER_PASSWORD $MYSQL_DATABASE -e 'source /home/admin/canal-admin/conf/canal_manager.sql' 1>>/tmp/start.log 2>&1"
  105. eval $cmd
  106. /bin/rm -f /home/admin/canal-admin/conf/canal_manager.sql
  107. else
  108. chown -R mysql:mysql /var/lib/mysql
  109. service mysqld start
  110. #check start
  111. checkStart "mysql" "echo 'show status' | mysql -b -s -h127.0.0.1 -P3306 -uroot -p$MYSQL_ROOT_PASSWORD | grep -c Uptime" 30
  112. fi
  113. }
  114. function stop_mysql() {
  115. echo "stop mysql ..."
  116. # stop mysql
  117. service mysqld stop
  118. echo "stop mysql successful ..."
  119. }
  120. function start_admin() {
  121. echo "start admin ..."
  122. serverPort=`perl -le 'print $ENV{"server.port"}'`
  123. if [ -z "$serverPort" ] ; then
  124. serverPort=8089
  125. fi
  126. su admin -c 'cd /home/admin/canal-admin/bin/ && sh restart.sh 1>>/tmp/start.log 2>&1'
  127. sleep 5
  128. #check start
  129. checkStart "canal" "nc 127.0.0.1 $serverPort -w 1 -z | wc -l" 30
  130. }
  131. function stop_admin() {
  132. echo "stop admin"
  133. su admin -c 'cd /home/admin/canal-admin/bin/ && sh stop.sh 1>>/tmp/start.log 2>&1'
  134. echo "stop admin successful ..."
  135. }
  136. echo "==> START ..."
  137. if [ -z "${MYSQL_ADDRESS}" ]; then
  138. start_mysql
  139. fi
  140. start_admin
  141. echo "==> START SUCCESSFUL ..."
  142. tail -f /dev/null &
  143. # wait TERM signal
  144. waitterm
  145. echo "==> STOP"
  146. if [ -z "${MYSQL_ADDRESS}" ]; then
  147. stop_admin
  148. fi
  149. stop_mysql
  150. echo "==> STOP SUCCESSFUL ..."