首頁  >  文章  >  資料庫  >  悲傷的故事,當不小心刪了線上的資料庫

悲傷的故事,當不小心刪了線上的資料庫

coldplay.xixi
coldplay.xixi轉載
2020-09-12 17:59:013483瀏覽

悲傷的故事,當不小心刪了線上的資料庫

相關學習推薦:mysql教學

#前言

  由於最近開學季,我司又做的是高校相關的業務,所以比較忙,都沒有什麼時間來寫文章,人一旦太忙的話就容易忙中出錯。我呢就在前幾天,不是,是我有個朋友在前幾天去操作線上的資料庫時,差點表演了一波刪庫跑路。

悲傷的故事,當不小心刪了線上的資料庫

  提前說明:真的是我朋友,不是我。真的是我朋友,不是我。真的是我朋友,不是我。不過為了敘事方便,以下把「我朋友」簡稱為「我」。

  事情是這樣的,我在比較部分錶結構時發現這個函式庫和其他函式庫的表結構差的比較多,所以以為這個環境是沒有在使用的環境,就直接對這幾張表進行了一個覆蓋操作,剛好這幾張表還是和學生錢包相關的,然後到晚上10點多公司的前方駐校人員在群組裡反饋說是為什麼錢包裡錢變成0.0了,我一看到這個就直接嚇尿了,想著是不是該跑路了。

悲傷的故事,當不小心刪了線上的資料庫

  不過幸好看過一些資料庫復原的方案,還是略知一二。

資料恢復

1.開啟binlog日誌

我使用的binlog日誌來恢復數據,要用binlog肯定首先得確保binlog日誌是開啟狀態的,可以用命令來查看。

show variables like 'log_%';复制代码
悲傷的故事,當不小心刪了線上的資料庫

可以看到它是ON狀態的,表示已開啟,如果它是OFF狀態的話,在my.cnf中 [mysqld]後來新增配置後重新啟動mysql服務來開啟。

# my.cnf文件
[mysqld]
log-bin=mysql-bin
server-id=1复制代码

2.查看binlog日誌

確保開啟binlog日之後,可以透過指令來查看binlog日誌狀態。

# 查看binlog日志的目录show master status;复制代码
悲傷的故事,當不小心刪了線上的資料庫
# 查看binlog日志内容show binlog events IN 'mysql-bin.000002';复制代码
悲傷的故事,當不小心刪了線上的資料庫
  • Log_name 表示binlog日誌名稱
  • Pos 表示pos起始點
  • #Event_type 表示此動作的類型
  • Server_id 表示機器id,由my.cnf中設定指定
  • End_log_pos 表示pos結束點
  • Info 表示具體語句
悲傷的故事,當不小心刪了線上的資料庫
# 进入存储binlog日志的文件木了,可以通过这条命令查看详情
 mysqlbinlog --base64-output=decode-rows -v mysql-bin.000002;复制代码
悲傷的故事,當不小心刪了線上的資料庫
# 将binlog日志转为txt导出
mysqlbinlog --base64-output=decode-rows -v mysql-bin.000002 > sql.txt复制代码

3.恢復資料

binlog日誌恢復資料的話,常用的有命令列恢復,或者是把binlog日誌拷貝出來,用讀取binlog的工具來轉成.sql文件,然後把裡面的需要用到的sql都複製出來然後再跑一遍,這裡主要講的是命令列恢復的方法。

命令列復原主要是透過排查binlog日誌,確認要復原的起始點和結束點後,輸入指令進行復原。或者是預估一下自己誤操作失誤的時間,透過一個時間段來恢復資料。

# 通过起始点和结束点恢复    
mysqlbinlog --start-position="582" --stop-position="9414" mysql-bin.000002 | mysql -uroot -proot;复制代码
# 通过起始时间和结束时间来恢复,传入的时间可以是一个yyyy-MM-dd HH:mm:ss 的时间格式,也可以是一个时间戳
mysqlbinlog --start-datetime="2020-9-1 8:25:04" --stop-datetime="2020-9-1 20:00:00" mysql-bin.000002 | mysql -uroot -proot复制代码
悲傷的故事,當不小心刪了線上的資料庫
悲傷的故事,當不小心刪了線上的資料庫

#可以看到,在輸入復原指令後,我清空的資料庫資料又回來了。

4.問題

binlog日誌雖然可以恢復數據,但是也存在問題,當binlog日誌在不斷增大後,會進行自動刪除,那就導致已經刪除的那部分日誌的資料就恢復不了了。

不過binlog日誌的大小和保存時間都是在可以在mysql中進行設定的。不過還是推薦做好每日的備份,這樣可保萬無一失。

# 设置文件大小,单位是字节,下面换算是100Mset global max_binlog_size=104857600;

# 设置文件保存天数,下面是保存7天,默认值为0,表示"没有自动删除"set global expire_logs_days = 7;复制代码

每日备份

对于线上环境来说,做好每日备份和binlog一起用才是王道。线上一般都是部署在linux上的,所以这里就简单列一下linux的定时备份方法。

1.检查是否安装定时任务,安装crontab

yum install crontabs复制代码

2.设置定时任务

/var/spool/cron/root  此文件为crontab定时任务,可通过crontab -e或者直接修改此文件修改.

crontab -l查看定时任务.

3.创建一个shell脚本

touch xxx.sh

mysqldump -uroot -p"密码" 数据库名 > /mysql/person_`date +%Y%m%d`.sql复制代码

4.修改文件权限

chmod 777 xxx.sh

5.打开定时任务文件

crontab -e

每天凌晨2点执行
00 2 * * * /xxx.sh复制代码

完结!

想了解更多编程学习,敬请关注php培训栏目!

以上是悲傷的故事,當不小心刪了線上的資料庫的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:juejin.im。如有侵權,請聯絡admin@php.cn刪除