成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

說說MySQL自動化備份腳本

數據庫 MySQL 自動化
我們用代碼說話,告訴您如何完成一個數據庫的備份,也希望您給一些改進的意見。

今天完成了一個數據庫備份的腳本,主要功能如下,希望大家給一些改進的建議

  1. -a: backup all database #全庫備份 
  2. -e: backup each database#分庫備份 
  3. -d: backup single/multi database#備份指定的一個庫或者多個庫 
  4. -t: backup single/multi table of single database#備份一個庫下面的一個表或者多個表 
  5. -b: backup binlog#備份binlog日志,備份過程,每次記錄***的二進制文件號,將之前范圍內的binlog打包(bz2格式),放在$DIR_BACKUP目錄下 
  6. -r: recover all database(!require password!)#恢復全庫,為保安全,恢復時需要輸入密碼 
  7. -o: recover single database/talbe,you should be designation database name(!require password!)#恢復單庫或單表 
  8. -p: create connect mysql password#創建連接mysql的密碼文件,存放位置$DIR_MySQL/etc目錄下,權限是600 
  9. -s: configuration rsyncd#創建rsyncd服務(需要時,可修改參數創建,因backup機上有rsyncd服務,故不需要在每臺DB server上創建rsyncd服務) 
  10.     If you want ceate a rsyncd, you should enter 'bakrec_mysql.sh -s cet' 
  11.     If you want restart rsyncd, you should enter 'bakrec_mysql.sh -s rst' 
  12. -c: sync to backup center#同步到backup1
  1. #!/bin/bash 
  2. # email: lianjie.ning@qunar.com 
  3. last change time: 2011-08-03 
  4. set -e 
  5. set -u 
  6. TIME=`date +%Y%m%d%H%M%S` 
  7. TIME_7=`date -d '7 days ago' +%Y%m%d%H%M%S` 
  8. TIME_YM=`date +%Y%m` 
  9. DIR_MYSQL='/usr/local/mysql' 
  10. DIR_BACKUP="/tmp/backup" 
  11. DIR_DATA="$DIR_MYSQL/data" 
  12. DIR_PASSWD="$DIR_MYSQL/etc" 
  13. FILE_PASSWD="$DIR_PASSWD/passwordfile" 
  14. BINLOG_NAME='mysql-bin' 
  15. CMD_MYSQLBINLOG="$DIR_MYSQL/bin/mysqlbinlog" 
  16. CMD_MYSQLDUMP="$DIR_MYSQL/bin/mysqldump" 
  17. CMD_MYSQL="$DIR_MYSQL/bin/mysql" 
  18. LIST_EXCLUDE_DB='(test|information_schema|performance_schema)' 
  19. if [ ! -d $DIR_BACKUP/$TIME_YM ]; then 
  20. mkdir -p $DIR_BACKUP/$TIME_YM 
  21. fi 
  22. cd $DIR_BACKUP/$TIME_YM 
  23. function result_status() 
  24. if [ $? -eq 0 ]; then 
  25. echo "[`date +%Y%m%d%H%M%S`] SUCCESS! "|tee -a log.$TIME_YM 
  26. else 
  27. echo "[`date +%Y%m%d%H%M%S`] ERROR! "|mail -s "backup error $HOSTNAME" ning_lianjie@163.com|tee -a log.$TIME_YM 
  28. fi 
  29. function usage_error() 
  30. echo "Usage: $0 RUN ERROR" 
  31. echo " 
  32. -a: backup all database 
  33. -e: backup each database 
  34. -d: backup single/multi database 
  35. -t: backup single/multi table of single database 
  36. -b: backup binlog 
  37. -r: recover all database(!require password!) 
  38. -o: recover single database/talbe,you should be designation database name(!require password!) 
  39. -p: create connect mysql password 
  40. -s: configuration rsyncd 
  41. If you want ceate a rsyncd, you should enter '$0 -s cet' 
  42. If you want restart rsyncd, you should enter '$0 -s rst' 
  43. -c: sync to backup center 
  44. exit 0 
  45. function read_pwd() 
  46. read USER PASSWD < $FILE_PASSWD 
  47. function backup() 
  48. read_pwd 
  49. LOGBIN_STATUS=`$CMD_MYSQL -u$USER -p$PASSWD -N -s -e "SHOW VARIABLES LIKE 'log_bin'" | gawk '{print $2}'
  50. if [ $LOGBIN_STATUS = "ON" ]; then 
  51. MASTER='--master-data=2' 
  52. else 
  53. MASTER=' ' 
  54. fi 
  55. function backup_all() 
  56. backup 
  57. $CMD_MYSQLDUMP -u$USER -p$PASSWD -x -R -A --add-drop-database $MASTER |gzip >$HOSTNAME.all.$TIME.sql.gz 
  58. function backup_each() 
  59. backup 
  60. for db in $($CMD_MYSQL -u$USER -p$PASSWD -N -s -e "SHOW DATABASES"|egrep -v $LIST_EXCLUDE_DB) 
  61. do 
  62. $CMD_MYSQLDUMP -u$USER -p$PASSWD -x -R $MASTER $db --databases |gzip >$HOSTNAME.$db.$TIME.sql.gz 
  63. done 
  64. delete 7 days ago 
  65. for db in $($CMD_MYSQL -u$USER -p$PASSWD -N -s -e "SHOW DATABASES"|egrep -v $LIST_EXCLUDE_DB) 
  66. do 
  67. if [ ! -f $HOSTNAME.$db.$TIME_7.sql.gz ]; then 
  68. echo 
  69. else 
  70. rm $HOSTNAME.$db.$TIME_7.sql.gz -f 
  71. fi 
  72. done 
  73. function backup_db() 
  74. shift 
  75. backup 
  76. $CMD_MYSQLDUMP -u$USER -p$PASSWD -x -R $MASTER --databases $@| gzip>$HOSTNAME.$OPTARG.$TIME.sql.gz 
  77. function backup_dt() 
  78. shift 
  79. if [ $# -ge 2 ]; then 
  80. backup 
  81. $CMD_MYSQLDUMP -u$USER -p$PASSWD -x -R $MASTER $@| gzip>$HOSTNAME.$OPTARG.$TIME.sql.gz 
  82. else 
  83. usage_error 
  84. fi 
  85. function backup_binlog() 
  86. if [ -s $DIR_BACKUP/mysql-bin.queue ]; then 
  87. read POS < $DIR_BACKUP/mysql-bin.queue 
  88. cd $DIR_DATA 
  89. tar -jcvf $DIR_BACKUP/$TIME_YM/$HOSTNAME.$POS.$TIME.bz2 `gawk -F'/' '{print $2}' $BINLOG_NAME.index |sed -n "/$POS/,//p"
  90. cd - 
  91. if [ -f $DIR_BACKUP/$TIME_YM/$HOSTNAME.$POS.$TIME_7.bz2 ]; then 
  92. rm $DIR_BACKUP/$TIME_YM/$HOSTNAME.$POS.$TIME_7.bz2 -f 
  93. fi 
  94. fi 
  95. # write last pos 
  96. gawk -F'/' '{print $2}' $DIR_DATA/$BINLOG_NAME.index | tail -n 1 >$DIR_BACKUP/mysql-bin.queue 
  97. function recover_all() 
  98. read_pwd 
  99. shift 
  100. $CMD_MYSQL -u$USER -p -e "source $@" 
  101. function recover_dt() 
  102. read_pwd 
  103. shift 
  104. if [ $# -eq 2 ]; then 
  105. $CMD_MYSQL -u$USER -p -D $1 -e "source $2" 
  106. else 
  107. usage_error 
  108. fi 
  109. function passwd_create() 
  110. if [ ! -e "$DIR_PASSWD" ]; then 
  111. mkdir -p $DIR_PASSWD 
  112. fi 
  113. echo -n "Please enter MySQL(user=root)'s password:" 
  114. read -s MYSQL_FASSWD 
  115. cat >$FILE_PASSWD <<+ 
  116. root $MYSQL_FASSWD 
  117. chmod 600 $FILE_PASSWD 
  118. function rsyncd() 
  119. shift 
  120. if [ $# -eq 0 ]; then 
  121. usage_error 
  122. else 
  123. DIR_RSYNCD='/usr/local/rsync' 
  124. FILE_RSYNCD_PASSWORD="$DIR_RSYNCD/rsyncd.password" 
  125. case "$1" in 
  126. 'cet'
  127. if [ ! -d $DIR_RSYNCD ]; then 
  128. mkdir -p $DIR_RSYNCD 
  129. fi 
  130. if [ ! -e "$DIR_RSYNCD/rsyncd.conf" ]; then 
  131. touch $DIR_RSYNCD/rsyncd.conf 
  132. fi 
  133. mv $DIR_RSYNCD/rsyncd.conf $DIR_RSYNCD/rsyncd.conf.$TIME.bak 
  134. cat >$DIR_RSYNCD/rsyncd.conf <<+ 
  135. uid = root 
  136. gid = root 
  137. use chroot = no 
  138. max connections = 5 
  139. lock file = $DIR_RSYNCD/rsyncd.lock 
  140. log file = $DIR_RSYNCD/rsyncd.log 
  141. pid file = $DIR_RSYNCD/rsyncd.pid 
  142. hosts allow = 192.168.250.251 
  143. hosts deny = * 
  144. ignore errors 
  145. read only = yes 
  146. list = no 
  147. auth users = backupdbuser 
  148. secrets file = $DIR_RSYNCD/rsyncd.password 
  149. [BINLOG] 
  150. path = $DIR_DATA 
  151. include = $BINLOG_NAME.* 
  152. exclude = * 
  153. [DUMPDB] 
  154. path = $DIR_BACKUP 
  155. cat >$FILE_RSYNCD_PASSWORD <<+ 
  156. username:password 
  157. chmod 600 $FILE_RSYNCD_PASSWORD 
  158. exit 0 
  159. ;; 
  160. 'rst'
  161. if [ -s "$DIR_RSYNCD/rsyncd.pid" ]; then 
  162. rsyncd_pid=`cat "$DIR_RSYNCD/rsyncd.pid"
  163. if (kill -0 $rsyncd_pid 2>/dev/null); then 
  164. echo "Shutting down rsyncd" 
  165. kill $rsyncd_pid 
  166. else 
  167. echo "rsyncd #$rsyncd_pid is not running!" 
  168. rm "$DIR_RSYNCD/rsyncd.pid" 
  169. fi 
  170. fi 
  171. sleep 2 
  172. rsync --daemon --config=$DIR_RSYNCD/rsyncd.conf --port=873 
  173. echo "rsync --daemon --config=$DIR_RSYNCD/rsyncd.conf --port=873" 
  174. echo "netstat -tunlp | grep rsync" 
  175. netstat -tunlp | grep rsync 
  176. ;; 
  177. *) 
  178. usage_error 
  179. ;; 
  180. esac 
  181. fi 
  182. #main 
  183. if [ $# -eq 0 ]; then 
  184. usage_error 
  185. else 
  186. while getopts :aed:t:r:o:bpsc varname 
  187. do 
  188. case $varname in 
  189. a) 
  190. backup_all 
  191. ;; 
  192. e) 
  193. backup_each 
  194. ;; 
  195. d) 
  196. backup_db $@ 
  197. ;; 
  198. t) 
  199. backup_dt $@ 
  200. ;; 
  201. b) 
  202. backup_binlog 
  203. ;; 
  204. r) 
  205. recover_all $@ 
  206. ;; 
  207. o) 
  208. recover_dt $@ 
  209. ;; 
  210. p) 
  211. passwd_create 
  212. ;; 
  213. s) 
  214. rsyncd $@ 
  215. ;; 
  216. c) 
  217. # rsync -czrptgoD --password-file=/tmp/.passwd $HOSTNAME.*.$TIME.sql.gz backupdbuser@192.168.250.251::DUMPDB/$HOSTNAME/$TIME_YM 
  218. rsync -czrpt --password-file=/tmp/.passwd $DIR_BACKUP/$TIME_YM backupdbuser@192.168.250.251::DUMPDB/$HOSTNAME 
  219. result_status 
  220. ;; 
  221. :) 
  222. echo "$varname: 缺少參數" 
  223. usage_error 
  224. ;; 
  225. \?) 
  226. echo "$varname: 非法選項" 
  227. usage_error 
  228. ;; 
  229. esac 
  230. done 
  231. fi 

原文鏈接:http://blog.chinaunix.net/space.php?uid=16844903&do=blog&id=2010853

【編輯推薦】

  1. 教你如何利用MySQL學習MongoDB
  2. Craigslist采用MongoDB替代MySQL
  3. MySQL中的NoSQL插件
  4. SQL與NoSQL——MySQL與NoSQL的融合
  5. 論MySQL何時使用索引,何時不使用索引
責任編輯:艾婧 來源: ning_lianjie的博客
相關推薦

2014-03-11 11:10:10

PowerShell自動化腳本

2023-05-11 08:46:28

MySQL

2015-05-28 10:46:22

shellBackupdatabase

2024-05-13 16:29:56

Python自動化

2017-12-17 21:58:18

2011-05-31 17:35:45

測試自動化QTP

2022-04-08 09:05:53

Arch LinuxLinux

2009-12-15 17:28:11

Ruby自動化腳本框架

2014-03-11 11:03:17

自動化腳本PowerShell

2023-03-07 08:30:09

MCube模板緩存

2016-12-20 16:47:25

Hadoop部署腳本

2016-09-27 23:31:23

2017-03-03 09:10:09

2012-03-30 15:52:51

ibmdw

2024-11-13 13:14:38

2022-03-10 10:12:04

自動化腳本Bash

2022-02-17 13:03:28

Python腳本代碼

2024-08-16 21:51:42

2024-11-11 16:55:54

2024-06-21 10:46:44

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品99久久久久久宅男 | 五月婷婷激情 | 国产日韩欧美中文 | 国产精品美女久久久久aⅴ国产馆 | 国产一区二区影院 | 97碰碰碰 | 色综合天天天天做夜夜夜夜做 | 夜夜摸天天操 | 色婷婷综合久久久中字幕精品久久 | 毛片一级片 | 亚洲精品久久久久久久久久久久久 | 中文字幕在线免费观看 | 成人一区二区视频 | 337p日本欧洲亚洲大胆 | 国产乱码精品1区2区3区 | 日韩一级免费电影 | 日韩在线大片 | 亚洲国产一区二区视频 | 亚洲成人二区 | 一区二区三区亚洲视频 | 超碰免费在线观看 | 成人免费在线网 | 成人精品视频99在线观看免费 | 一区二区三区在线 | 欧 | 欧美日韩在线一区二区三区 | 中文字幕高清在线 | 国产在线一区二区 | 日韩成人高清在线 | 久久久久久国产精品免费免费 | 久久久激情视频 | 精产国产伦理一二三区 | 日韩三区在线 | 欧美亚州综合 | 一区二区日韩 | 一区二区精品 | 久草院线| 亚洲第一网站 | 久久久国产一区二区三区 | 成人在线免费 | 亚洲精品一区二区三区蜜桃久 | xx视频在线 |