startDockerImage.sh 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261
  1. #!/bin/bash
  2. # 本脚本用于修改mysql安装配置文件信息
  3. # 获取脚本运行所在路径
  4. SCRIPT_DIR=$(cd $(dirname ${BASH_SOURCE[0]}); pwd)
  5. echo -e "\033[33m
  6. ---------------
  7. -----SZHFY-----
  8. ----GB28181----
  9. ---------------
  10. \033[0m";
  11. echo -e "\033[33m 欢迎使用深圳合方圆科技一键部署国标平台安装程序 \033[0m";
  12. # 读取配置文件
  13. source ./config.cfg
  14. # 检查必要启动参数是否存在
  15. #sql_host="0.0.0.0"
  16. #sql_port=3306
  17. #sql_user="hfygb"
  18. #sql_passwd="hfygb28181"
  19. #sql_db="gb_db"
  20. #sql_path="sqlRuning"
  21. #redis_host="0.0.0.0"
  22. #redis_port=7654
  23. #redis_db=6
  24. #redis_passwd="hfyredis28181"
  25. echo "检查基础参数中,,,,,,"
  26. if [ ! -n "$sql_host" ]; then
  27. echo "sql_host 未设置"
  28. exit 1
  29. fi
  30. if [ ! -n "$sql_user" ]; then
  31. echo "sql_user 未设置"
  32. exit 1
  33. fi
  34. if [ ! -n "$sql_passwd" ]; then
  35. echo "sql_passwd 未设置"
  36. exit 1
  37. fi
  38. if [ ! -n "$sql_db" ]; then
  39. echo "sql_db 未设置"
  40. exit 1
  41. fi
  42. echo "开始启动mysql"
  43. #检查是否启用docker安装 enable_sql 为1时启用 为0时不启用
  44. if [ "$enable_sql" == "1" ];then
  45. # 判断是否存在mysql目录,没有则创建
  46. if [ ! -d "$SCRIPT_DIR/sql" ]; then
  47. mkdir -p /data/mysql
  48. fi
  49. # 导入mysql镜像
  50. docker load -i ./hfysql.tar
  51. # 检查容器是否已经启动,如果已经启动则尝试导出数据库
  52. docker ps -a | grep hfysql
  53. if [ $? -eq 0 ]; then
  54. # 导出数据库
  55. docker exec -it hfysql mysqldump -uroot -p"$sql_root_passwd" --all-databases > /data/mysql/hfysqlSave.sql
  56. # 停止容器
  57. docker stop hfysql
  58. # 删除容器
  59. docker rm hfysql
  60. # 移除容器占用的mysql目录
  61. echo "移除容器占用的mysql目录"
  62. rm -rf ./mysql/*
  63. fi
  64. # 修改mysql配置文件
  65. sed -i \
  66. -e "s/^port=.*/port=$sql_port/g" \
  67. "$SCRIPT_DIR/mysqlConf/my.cnf";
  68. # sed -i 's/^port=.* /port=1234/g' ./mysqlConf/my.cnf
  69. # 启动mysql容器,使用三目语句判断sql_enable_host为1时设置网络模式为host
  70. if [ "$sql_enable_host" == "1" ];then
  71. docker run -d --name hfysql \
  72. --net=host \
  73. -v "$SCRIPT_DIR/mysql":/var/lib/mysql \
  74. -v "$SCRIPT_DIR/sqlBack":/data/sqlBack \
  75. --mount type=bind,src="$SCRIPT_DIR/mysqlConf/my.cnf",dst=/etc/mysql/my.cnf \
  76. -e MYSQL_ROOT_PASSWORD="$sql_root_passwd"\
  77. hfysql:latest
  78. else
  79. docker run -d --name hfysql \
  80. -p "$sql_port":3306 \
  81. -v "$SCRIPT_DIR/mysql":/var/lib/mysql \
  82. -v "$SCRIPT_DIR/sqlBack":/data/sqlBack \
  83. -e MYSQL_ROOT_PASSWORD="$sql_root_passwd" \
  84. hfysql:latest
  85. fi
  86. if [ $? -ne 0 ]; then
  87. echo "run mysql docker failed";
  88. fi
  89. # 等待mysql启动
  90. sleep 5
  91. fi
  92. echo "开始启动redis"
  93. sleep 2
  94. # 检查是否启用redis安装 enable_redis 为1时启用 为0时不启用
  95. if [ "$enable_redis" == "1" ];then
  96. #
  97. # 修改配置redis配置文件
  98. sed -i \
  99. -e "s/^port.*$/port $redis_port/g" \
  100. -e "s/^requirepass.*$/requirepass $redis_passwd/g" \
  101. "$SCRIPT_DIR/redis/redis.conf";
  102. # 导入redis镜像
  103. docker load -i ./hfyredis.tar
  104. # 检查容器是否已经启动,如果已经启动则关闭并且删除容器
  105. docker ps -a | grep hfy_redis
  106. if [ $? -eq 0 ]; then
  107. # 停止容器
  108. docker stop hfy_redis
  109. # 删除容器
  110. docker rm hfy_redis
  111. fi
  112. # 启动redis容器 host 模式启动,端口映射到宿主机
  113. docker run -it -p "$redis_port":"$redis_port" \
  114. --net=host \
  115. -v /data/redis:/data/redis \
  116. -v /data/redis/logs:/data/redis/logs \
  117. -v "$SCRIPT_DIR/redis/redis.conf":/etc/redis/redis.conf \
  118. --name hfy_redis -itd hfyredis:latest
  119. fi
  120. echo "检查是否需要配置sql"
  121. sleep 2
  122. if [ "$enable_sql" == "1" ];then
  123. echo "等待尝试修改数据库参数"
  124. isTrue=1
  125. reConnect=0
  126. while [[ $isTrue == 1 ]]
  127. do
  128. # 尝试连接数据库
  129. docker exec -it hfysql mysql \
  130. -uroot -p"$sql_root_passwd" \
  131. -e "show databases;"
  132. if [ $? -eq 0 ]; then
  133. isTrue=0
  134. else
  135. echo "数据库连接失败,等待3秒后重试"
  136. reConnect=$(($reConnect+1))
  137. if(($reConnect>150));then
  138. echo "数据库连接失败失败次数$reConnect,退出程序"
  139. exit 1
  140. fi
  141. sleep 3
  142. fi
  143. done
  144. docker ps -a | grep hfysql
  145. if [ $? -eq 0 ]; then
  146. # 导出数据库
  147. echo "mysql 数据库已经启动"
  148. else
  149. echo "mysql 数据库启动失败"
  150. docker logs hfysql
  151. exit 1
  152. fi
  153. # 修改数据库名,无法修改数据库名,拒绝操作
  154. # docker exec -it hfysql mysql \
  155. # -uroot -p"hfy$sql_passwd" \
  156. # -e "ALTER DATABASE gb_db TO $sql_db;"
  157. # 创建单独用户
  158. docker exec -it hfysql mysql \
  159. -uroot -p"$sql_root_passwd" \
  160. -e "CREATE USER '$sql_user'@'%' IDENTIFIED BY '$sql_passwd';"
  161. # 不限制ip访问
  162. docker exec -it hfysql mysql \
  163. -uroot -p"$sql_root_passwd" \
  164. -e "GRANT ALL PRIVILEGES ON $sql_db.* TO '$sql_user'@'%';"
  165. # 刷新权限
  166. docker exec -it hfysql mysql \
  167. -uroot -p"$sql_root_passwd" \
  168. -e "FLUSH PRIVILEGES;"
  169. echo "等待sql重启,等待15秒"
  170. sleep 15
  171. reConnect=0
  172. isTrue=1
  173. while [[ $isTrue == 1 ]]
  174. do
  175. # 尝试连接数据库
  176. docker exec -it hfysql mysql \
  177. -uroot -p"$sql_root_passwd" \
  178. -e "show databases;"
  179. if [ $? -eq 0 ]; then
  180. isTrue=0
  181. else
  182. echo "数据库连接失败,等待3秒后重试"
  183. reConnect=$(($reConnect+1))
  184. if(($reConnect>150));then
  185. echo "数据库连接失败失败次数$reConnect,退出程序"
  186. exit 1
  187. fi
  188. sleep 3
  189. fi
  190. done
  191. sleep 10
  192. if [ $? -ne 0 ]; then
  193. echo "run gb docker failed";
  194. fi
  195. fi
  196. echo "开始启动国标平台"
  197. # 根据参数生成国标平台配置文件
  198. gb_certName=""
  199. gb_keyName=""
  200. # 判断是否有证书地址 gb_certPath 与 gb_keyPath
  201. if [ "$gb_certPath" != "" ] && [ "$gb_keyPath" != "" ];then
  202. # 判断证书是否存在
  203. if [ ! -f "$gb_certPath" ];then
  204. echo "证书文件不存在,请检查证书路径是否正确"
  205. exit 1
  206. fi
  207. if [ ! -f "$gb_keyPath" ];then
  208. echo "证书文件不存在,请检查证书路径是否正确"
  209. exit 1
  210. fi
  211. # 获取证书文件名
  212. gb_certName=$(basename "$gb_certPath")
  213. gb_keyName=$(basename "$gb_keyPath")
  214. # 拷贝证书到容器中
  215. cp "$gb_certPath" "$SCRIPT_DIR/gbRunning/keys"
  216. cp "$gb_keyPath" "$SCRIPT_DIR/gbRunning/keys"
  217. fi
  218. source ./gbRunning/createConfig.sh
  219. echo "$gb_WebPort"
  220. echo "$gb_sipPort"
  221. # 导入国标平台镜像
  222. docker load -i ./hfygb.tar
  223. # 检查容器是否已经启动,如果已经启动则关闭并且删除容器 hfy_gb
  224. docker ps -a | grep hfy_gp
  225. if [ $? -eq 0 ]; then
  226. # 停止容器
  227. docker stop hfy_gp
  228. # 删除容器
  229. docker rm hfy_gp
  230. fi
  231. echo -e "\033[33m自动按照sql与redis配置已经自动关闭\033[0m"
  232. sudo docker run -it --net=host \
  233. -v /data/gb:/data/gb -e LANG=C.UTF-8 \
  234. -v $SCRIPT_DIR"/gbRunning/logs":/data/hfygb/logs \
  235. -v $SCRIPT_DIR"/gbRunning/mFile":/data/hfygb/mFile \
  236. -v $SCRIPT_DIR"/gbRunning/libImages":/data/hfygb/libImages \
  237. -v $SCRIPT_DIR"/gbRunning/keys":/data/hfygb/keys \
  238. -v $SCRIPT_DIR"/gbRunning/application_product.yml":/data/hfygb/config/application_product.yml --name hfy_gp -it hfygb:latest
  239. if [ $? -ne 0 ]; then
  240. echo "run gb docker failed";
  241. fi
  242. # 修改国标平台配置文件,将 enable_redis 与 enable_sql 修改为 0 防止sql数据异常
  243. sed -i "s/enable_redis=1/enable_redis=0/g" "$SCRIPT_DIR/config.cfg"
  244. sed -i "s/enable_sql=1/enable_sql=0/g" "$SCRIPT_DIR/config.cfg"
  245. echo -e "\033[33m国标平台以全部启动,请使用浏览器访问 http://$gb_host:$gb_WebPort\033[0m";