mysqldump備份

說明:

    系統:阿里雲的centos 7

    mysql:mysql-5.6.27

    腳本來源:冰狼愛魔


一、備份

    首先創建備份的目標文件夾 

    備份時使用mysqldump進行備份

mysqldump -h localhost -u用戶名 -p 數據庫 > db_20170915.sql  ##db_20170915.sql.gz爲壓縮備份

    如果爲遠程備份則需要把localhost改爲相應的IP地址即可

    當我相把B服務器上的備份到A服務器上時我這裏出現了一個錯誤,好像是版本的問題,錯誤如下:

mysqldump: Couldn't execute 'SET OPTION SQL_QUOTE_SHOW_CREATE=1': You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'OPTION SQL_QUOTE_SHOW_CREATE=1' at line 1 (1064

二、備份恢復

mysqldump -h localhost -u用戶名 -p 數據庫 < db_20170915.sql
這就算是完成了一次數據庫的備份與恢復,需要注意:這是把所有的表都備份到一起

三、添加定時任務進行自動備份

創建sh腳本並賦權限:
創建:touch mysql_back.sh  
賦權限:chmod 755 mysql_back.sh  
腳本內容如下:
# Name:mysql_backup.sh
# 數據庫備份和刪除7天之前的數據
#備份地址
backupdir=/home/mysql
#備份文件後綴時間
time=_` date +%Y_%m_%d_%H_%M_%S `
#需要備份的數據庫名稱
db_name=zbx_db
#mysql 用戶名
#db_user=
#mysql 密碼
#db_pass=
#mysqldump命令使用絕對路徑
/usr/local/mysql/bin/mysqldump $db_name | gzip > $backupdir/$db_name$time.sql.gz
#刪除7天之前的備份文件
find $backupdir -name $db_name"*.sql.gz" -type f -mtime +7 -exec rm -rf {} \; > /dev/null 2>&1
回到系統根目錄 cd ~  cd..
添加定時任務:crontab -e
輸入一下並保存:
00 00 * * * /usr/bin/sh /home/timeShell/mysql_backup.sh >> /home/timeShell/mysql_backup.log
使定時器生效:service crond restart

免密設置

打開my.cnf
cd /etc
vi my.cnf
[mysqldump]
quick
max_allowed_packet = 16M
#在這裏輸入user及password,在執行mysqldump命令就不用輸入用戶名和密碼了
user=root
password=123456

四、設置mysql自啓動

將服務文件拷貝到init.d下,並重命名爲mysql:
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
賦予可執行權限:chmod +x /etc/init.d/mysqld
添加服務:chkconfig --add mysqld
顯示服務列表:chkconfig –list
3,4,5都是on配置成功,如果不是:chkconfig --level 345 mysql on
重啓:reboot
驗證:netstat -na | grep 3306
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章