激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Linux|Centos|Ubuntu|系統(tǒng)進(jìn)程|Fedora|注冊(cè)表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

服務(wù)器之家 - 服務(wù)器系統(tǒng) - Linux - PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

2022-01-07 19:35陶士涵 Linux

這篇文章主要為大家詳細(xì)介紹了PHP程序員玩轉(zhuǎn)Linux系列文章,MySQL備份還原教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

PHP程序員玩轉(zhuǎn)Linux系列文章:

1.PHP程序員玩轉(zhuǎn)Linux系列-怎么安裝使用CentOS

2.PHP程序員玩轉(zhuǎn)Linux系列-lnmp環(huán)境的搭建

3.PHP程序員玩轉(zhuǎn)Linux系列-搭建FTP代碼開發(fā)環(huán)境

前幾天有個(gè)新聞,說是gitlab的工程師把數(shù)據(jù)文件給誤刪了,搞了個(gè)大事件,很多人都去圍觀了.備份工作應(yīng)該在最開始的時(shí)候就要做,否則就會(huì)失去最佳時(shí)機(jī),為了保證我的數(shù)據(jù)是安全的,因此我要搞備份了.備份分為邏輯備份和物理備份,邏輯備份是導(dǎo)sql,物理備份是基于文件的,這兩種我都搞一下.

開啟binlog

首先第一件事是打開binlog日志,編輯mysql配置文件開啟一下,默認(rèn)是關(guān)閉的.編輯 /etc/my.cnf ,log-bin=mysqlbinlog =號(hào)后面的是binlog日志的名字,默認(rèn)生成在數(shù)據(jù)目錄里面,重啟一下mysql服務(wù) , service mysqld restart

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

查看mysql的數(shù)據(jù)目錄 , /var/lib/mysql ,mysqlbinlog.000001等文件就是binlog日志文件.

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

添加一些測試數(shù)據(jù)

建數(shù)據(jù)庫,建表和插入一些記錄,用于測試,表的存儲(chǔ)引擎選擇innodb,因?yàn)檫@個(gè)引擎容易測出來問題

#建庫
create database entmail charset=utf8; 
#建表,存儲(chǔ)引擎選用innodb
create table user( id int auto_increment primary key, name varchar(100) not null default '' ) engine=innodb;
#插記錄
insert into user values(null,'shihan');
insert into user values(null,'shihan1');
insert into user values(null,'shihan2');
insert into user values(null,'shihan3');

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

小數(shù)據(jù)量使用mysqldump邏輯備份

第一想到的備份方式是使用mysqldump,導(dǎo)出sql語句,恢復(fù)的時(shí)候就再次導(dǎo)入sql語句.

針對(duì)我的數(shù)據(jù)庫,用戶名root 密碼空,我放sql文件的位置是/home/shihan1/mysql/sqls/ ,備份所有數(shù)據(jù)庫,我的導(dǎo)出命令是下面這句

 

mysqldump -uroot --all-databases > /home/shihan1/mysql/sqls/all.sql 

 

此時(shí),我誤刪了數(shù)據(jù)庫entmail , drop database entmail

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

不著急,馬上進(jìn)行恢復(fù),執(zhí)行以下導(dǎo)入命令,數(shù)據(jù)庫立刻就回來了,注意一個(gè)是mysqldump命令,一個(gè)是mysql命令

 

mysql -uroot < /home/shihan1/mysql/sqls/all.sql 

 

為啥不能用拷貝數(shù)據(jù)目錄的方式備份

有的同學(xué)會(huì)使用直接拷貝數(shù)據(jù)目錄的方式備份,我也測試了一下,實(shí)際證明這種方式是不正確的.我用tar命令把數(shù)據(jù)目錄整個(gè)打包搬走,然后刪除整個(gè)數(shù)據(jù)目錄,再搬回來.

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

因?yàn)槲野裮ysql的那幾張用戶表啥的都刪了,mysql會(huì)進(jìn)行重新初始化

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

我把數(shù)據(jù)文件再搬回來,然后進(jìn)mysql看看,結(jié)果是這樣的,告訴我user表不存在了,這張表是innodb引擎的,所以不能使用這種方式,幸虧我有前面的邏輯備份,從新導(dǎo)一下,數(shù)據(jù)又回來了.

 

mysql -uroot < /home/shihan1/mysql/sqls/all.sql

 

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

使用第三方軟件percona-xtrabackup實(shí)現(xiàn)物理備份

可以實(shí)現(xiàn)物理備份的軟件與很多,mysql也有企業(yè)版?zhèn)浞莨ぞ?但是貌似是收費(fèi)的,percona-xtrabackup這個(gè)開源軟件可以很好的實(shí)現(xiàn)全量備份和增量備份.

前往這個(gè)地址下載rpm包,里面可以選擇版本,我最開始選的最新版2.4.6,結(jié)果報(bào)這個(gè)錯(cuò)誤:Error: Built-in InnoDB in MySQL 5.1 is not supported in this release. You can either use Percona XtraBackup 2.0, or upgrade to InnoDB plugin.然后從新下了個(gè)2.0.0版是可以的.

https://www.percona.com/downloads/XtraBackup/

#下載rpm
wget https://www.percona.com/downloads/XtraBackup/XtraBackup-2.0.0/RPM/rhel6/x86_64/percona-xtrabackup-2.0.0-417.rhel6.x86_64.rpm
#安裝rpm
rpm -i percona-xtrabackup-2.0.0-417.rhel6.x86_64.rpm
#安裝需要的依賴
yum -y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL perl-MD5 rsync libev numactl

開始備份了

當(dāng)前數(shù)據(jù):

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

1. 我先把所有數(shù)據(jù)全量備份一次,后面那個(gè)目錄是備份保存的目錄,執(zhí)行完成后出現(xiàn)innobackupex: completed OK!代表成功,生成的備份文件2017-02-24_17-47-55

 

innobackupex --user=root /home/shihan1/mysql/backups/

 

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

2. 添加幾條新數(shù)據(jù)進(jìn)去,現(xiàn)在的數(shù)據(jù)情況

insert into user values(null,'shihan4');
insert into user values(null,'shihan5');

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

3. 增量備份一次,就多了一個(gè)參數(shù)--incremental , 增量備份生成的文件是 2017-02-24_17-51-32 , 數(shù)據(jù)的大小也是不一樣的

 

innobackupex --user=root --incremental /home/shihan1/mysql/backups/

 

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

4. 此時(shí)發(fā)生災(zāi)變,我把數(shù)據(jù)目錄給刪了!rm -rf /var/lib/mysql/* ,mysql已經(jīng)連不上了

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

5. 抓緊恢復(fù)數(shù)據(jù) , 準(zhǔn)備全量備份文件 , 合并增量備份文件 , 執(zhí)行恢復(fù)

#準(zhǔn)備全量備份文件
innobackupex --apply-log --redo-only /home/shihan1/mysql/backups/2017-02-24_17-47-55/
#合并增量備份文件,注意看目錄名
#如果有多次增量備份,就多次執(zhí)行 innobackupex --apply-log --redo-only 增量目錄 --incremental-dir 增量目錄
innobackupex --apply-log --redo-only /home/shihan1/mysql/backups/2017-02-24_17-47-55/ --incremental-dir /home/shihan1/
mysql/backups/2017-02-24_17-51-32/
#執(zhí)行恢復(fù)
innobackupex --copy-back /home/shihan1/mysql/backups/2017-02-24_17-47-55

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

6. 數(shù)據(jù)已經(jīng)回來了,重新修改一下數(shù)據(jù)文件的屬組和屬主chown mysql:mysql -R /var/lib/mysql/* , 重啟一下mysql ,數(shù)據(jù)全部恢復(fù)

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

PHP程序員玩轉(zhuǎn)Linux系列 備份還原MySQL

下一篇定時(shí)執(zhí)行備份腳本

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:http://www.cnblogs.com/taoshihan/p/6437468.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲va久久久噜噜噜久久男同 | 久久久一区二区 | 国产精品久久久久久久久久久天堂 | 中文日韩欧美 | 欧美成人精品一区二区男人小说 | 亚洲天堂成人在线观看 | 欧美xxxwww | 国产精品久久久久久久四虎电影 | 成人做爰www免费看 成人午夜视频免费看 | 九九热精品视频在线播放 | 91精彩在线 | 免费看一级视频 | javhdfreejaⅴhd | 国产亚洲欧美一区久久久在 | 姑娘第四集免费看视频 | 亚洲成人第一区 | 91精品一区二区综合在线 | 精国产品一区二区三区 | 国产精品久久久免费看 | 成人三级电影在线 | 最新欧美精品一区二区三区 | 久久久久免费精品国产小说色大师 | 日本中文字幕电影在线观看 | 欧美一级爱爱 | 天天碰天天操 | 欧美性生活视频免费看 | 欧美日韩精品不卡一区二区三区 | 午夜影视一区二区 | 操碰97| 九色激情网| 二区三区在线观看 | av在线一区二区三区四区 | 国产一区在线观看视频 | 欧美一区二区片 | 国产一区影院 | 中国精品久久 | 成人三级电影网站 | 天天夜天天操 | 欧美视频一二三区 | 依依成人综合 | 久久久视频免费观看 |