MySQL8.0安装配置与备份还原详解

一、MYSQL下载和安装

1)下载mysql

地址:https://dev.mysql.com/downloads/mysql/

MySQL8.0安装配置与备份还原详解_第1张图片

2)安装

MySQL8.0安装配置与备份还原详解_第2张图片

MySQL8.0安装配置与备份还原详解_第3张图片

3)安装目录 

安装完成后,可以再服务里,看到MYSQL服务已经启动,bin目录(默认为:C:\Program Files\MySQL\MySQL Server 8.0\bin)

MySQL8.0安装配置与备份还原详解_第4张图片

4)mysql在windows后台运行

MySQL8.0安装配置与备份还原详解_第5张图片

5)Mysql workbench客户端工具

MySQL8.0安装配置与备份还原详解_第6张图片

MySQL8.0安装配置与备份还原详解_第7张图片

6)创建数据库和表 

MySQL8.0安装配置与备份还原详解_第8张图片

MySQL8.0安装配置与备份还原详解_第9张图片

7)库和表检查

MySQL8.0安装配置与备份还原详解_第10张图片

二、配置环境变量

1)windows环境变量设置

MySQL8.0安装配置与备份还原详解_第11张图片

MySQL8.0安装配置与备份还原详解_第12张图片

MySQL8.0安装配置与备份还原详解_第13张图片

 2)手动连接mysql数据库

在命令行上输入:mysql -uroot -p进行mysql登录

MySQL8.0安装配置与备份还原详解_第14张图片

通过mysql DDL DML DQL命令操作数据库,详见:https://blog.csdn.net/openbox2008/article/details/84580899

MySQL8.0安装配置与备份还原详解_第15张图片

 MySQL8.0安装配置与备份还原详解_第16张图片

三、MYSQL配置

1)配置文件

文件存放位置:C:\ProgramData\MySQL\MySQL Server 8.0\my.ini

MySQL8.0安装配置与备份还原详解_第17张图片

 配置文件说明

[mysqld]
# 设置3306端口
port=3306
# 设置mysql的安装目录
# basedir="C:/Program Files/MySQL/MySQL Server 8.0/"   
# 设置mysql数据库的数据的存放目录
datadir=C:/ProgramData/MySQL/MySQL Server 8.0/Data
# 允许最大连接数
max_connections=200
# 允许连接失败的次数。这是为了防止有人从该主机试图攻击数据库系统
max_connect_errors=10
# 服务端使用的字符集默认为UTF8
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 默认使用“mysql_native_password”插件认证
default_authentication_plugin=caching_sha2_password

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8

[client]
# 设置mysql客户端连接服务端时默认使用的端口
port=3306
default-character-set=utf8

2)应用程序存放位置:C:\Program Files\MySQL\MySQL Server 8.0

MySQL8.0安装配置与备份还原详解_第18张图片

 3)数据和配置文件存放位置:C:\ProgramData\MySQL\MySQL Server 8.0

MySQL8.0安装配置与备份还原详解_第19张图片

MySQL8.0安装配置与备份还原详解_第20张图片

MySQL8.0安装配置与备份还原详解_第21张图片

四、MYSQL的备份与还原

 1)直接复制data目录

          该方法是冷备份,必须先将mysql数据库停下来。然后,将数据库文件迁移到另一个文件夹中。可以直接复制C:\ProgramData\MySQL\MySQL Server 8.0\Data文件夹到上述目录中。

           然后,在原默认安装目录C:\ProgramData\MySQL\MySQL Server 8.0中找到名为my.ini的文件。打开它,并将
相应的datadir修改为新的文件夹地址并保存。

MySQL8.0安装配置与备份还原详解_第22张图片

MySQL8.0安装配置与备份还原详解_第23张图片

2)使用mysqldump工具逻辑重做

mysql workbench图形工具

MySQL8.0安装配置与备份还原详解_第24张图片

命令行手动输入命令

 基本语法:mysqldump  -hPup 数据库名字 [表1  [表2 …]] > 备份文件地址

-hPup:ip地址 端口 用户 密码

如:mysqldump -uroot -p bookdb>e:/back.sql

MySQL8.0安装配置与备份还原详解_第25张图片

MySQL8.0安装配置与备份还原详解_第26张图片

Mysqldump在整个备份过程中可以向外提供服务。

MySQLdump对不同类型的存储引擎,内部实现也不一样。主要是针对两种类型的存储引擎:支持事务的存储引擎(如InnoDB)和不支持事务的存储引擎(如MyISAM),下面分别看看这两种存储引擎的实现:

1、对于支持事务的引擎如InnoDB,参数上是在备份的时候加上--single-transaction保证数据一致性

--single-transaction实际上通过做了下面两个操作:

    ①、在开始的时候把该session的事务隔离级别设置成repeatable read;
    ②、然后启动一个事务(执行bigin),备份结束的时候结束该事务(执行commit)
    有了这两个操作,在备份过程中,该session读到的数据都是启动备份时的数据(同一个点)。可以理解为对于innodb引擎来说加了该参数,备份开始时就已经把要备份的数据定下来了,备份过程中的提交的事务时是看不到的,也不会备份进去。

2、对于不支持事务的引擎如MyISAM,只能通过锁表来保证数据一致性,这里分三种情况:
①、导出全库:加--lock-all-tables参数,这会在备份开始的时候启动一个全局读锁(执行flush tables with read lock),其他session可以读取但不能更新数据,备份过程中数据没有变化,所以最终得到的数据肯定是完全一致的;
②、导出单个库:加--lock-tables参数,这会在备份开始的时候锁该库的所有表,其他session可以读但不能更新该库的所有表,该库的数据一致;
③、导出单个表:加--lock-tables参数,这会在备份开始的时候锁该表,其他表不受影响,该表数据一致。

上面只是展示了对不同引擎来讲加的参数只是为了让数据保持一致性,但在备份中业务并没有停止,时刻可能有新的数据进行写入,为了让我们知道备份时是备份了哪些数据,或者截止到那个指针(二进制日志),我们可以再加入 --master-data参数,备份好的sql文件就会记录从备份截至到哪个指针,指针之后的数据更新我们可以通过二进制日志进行恢复。
# MySQLdump -u root -p --single-transaction --master-data --flush-log --database test > test.sql     

Mysqldump备份的数据中没有关于数据库本身的操作,都是针对表级别的操作,当进行数据(SQL还原),必须指定数据库。

3、还原 mysql -uroot -p bookdb

MySQL8.0安装配置与备份还原详解_第27张图片

3)使用第三方备份工具

目前主流的有两个工具可以实现物理热备:ibbackup和xtrabackup ;ibbackup是需要授权价格昂贵,而xtrabackup功能比ibbackup强大而且是开源的
Xtrabackup提供了两种命令行工具:
xtrabackup:专用于备份InnoDB和XtraDB引擎的数据;
innobackupex:这是一个perl脚本,在执行过程中会调用xtrabackup命令可以实现备份InnoDB,也可以备份MyISAM引擎的对象
Xtrabackup是由percona提供的mysql数据库备份工具,特点:
(1)备份过程快速、可靠;
(2)备份过程不会打断正在执行的事务;
(3)能够基于压缩等功能节约磁盘空间和流量;
(4)自动实现备份检验;
(5)还原速度快。

Xtrabackup备份恢复,进行热备。优点是备份过程中可继续提供服务。

1)安装Xtrabackup

详见:https://blog.51cto.com/bigboss/2095153

2)linux下使用脚本备份

   1.备份脚本

此备份脚本的策略是每周日和周三进去全备 其余每天增量备份。

# 备份脚本XtraBackup.sh:

#!/bin/bash
# filename      : XtraBackup.sh

day=`date +%w`
dt=`date +%Y%m%d`
lastday=`date -d '1 days ago' +%Y%m%d`
user=root
pwd='xxxxx'
log=backuplog.`date +%Y%m%d`

case $day in  
    0)  
        # Sunday Full backup
        find /backup/ -name "xtra_*" -mtime +6 -exec rm -rf {} \;
        innobackupex --defaults-file=/etc/my.cnf  --user=$user --password=$pwd --no-timestamp /backup/xtra_base_$dt > /tmp/$log 2>&1
        ;;  
    1)  
        # Monday Relatively Sunday's incremental backup  
        innobackupex --defaults-file=/etc/my.cnf  --user=$user --password=$pwd  --no-timestamp  --incremental  /backup/xtra_inc_$dt --incremental-basedir=/backup/xtra_base_$lastday > /tmp/$log 2>&1  
        ;;  
    2)  
        # Tuesday Compared with Monday's incremental backup  
        innobackupex --defaults-file=/etc/my.cnf  --user=$user --password=$pwd  --no-timestamp  --incremental  /backup/xtra_inc_$dt --incremental-basedir=/backup/xtra_inc_$lastday > /tmp/$log 2>&1     
        ;;  
    3)  
        # Wednesday Full backup
        find /backup/ -name "xtra_*" -mtime +6 -exec rm -rf {} \;
        innobackupex --defaults-file=/etc/my.cnf  --user=$user --password=$pwd --no-timestamp /backup/xtra_base_$dt > /tmp/$log 2>&1   
        ;;  
    4)  
        # Thursday  Relatively Wednesday's incremental backup  
        innobackupex --defaults-file=/etc/my.cnf  --user=$user --password=$pwd  --no-timestamp  --incremental  /backup/xtra_inc_$dt --incremental-basedir=/backup/xtra_base_$lastday > /tmp/$log 2>&1    
        ;;  
    5)  
        # Friday Compared with Thursday's incremental backup  
        innobackupex --defaults-file=/etc/my.cnf  --user=$user --password=$pwd  --no-timestamp  --incremental  /backup/xtra_inc_$dt --incremental-basedir=/backup/xtra_inc_$lastday > /tmp/$log 2>&1    
        ;;  
    6)  
        # Saturday Compared with Friday's incremental backup  
        innobackupex --defaults-file=/etc/my.cnf  --user=$user --password=$pwd  --no-timestamp  --incremental  /backup/xtra_inc_$dt --incremental-basedir=/backup/xtra_inc_$lastday > /tmp/$log 2>&1   
        ;;  
esac 
find /tmp -mtime +6 -type f -name 'backuplog.*' -exec rm -rf {} \;

   2.还原脚本

# 全库恢复脚本 xtrabackup_recover.sh:

#!/bin/bash
# filename      : xtrabackup_recover.sh

day=`date +%w`
dt=`date +%Y%m%d`
lastday=`date -d '1 days ago' +%Y%m%d`
lasttwoday=`date -d '2 days ago' +%Y%m%d`
lastthreeday=`date -d '3 days ago' +%Y%m%d`
user=root
pwd='xxxxxxx'
log=recoverlog.`date +%Y%m%d`
datefile=/mysqldata

case $day in  
    0)  
        # Sunday Recover Database 
        innobackupex --apply-log  /backup/xtra_base_$dt > /tmp/$log 2>&1
        service mysqld stop
        rm -rf $datefile/*
        innobackupex --defaults-file=/etc/my.cnf --copy-back /backup/xtra_base_$dt >> /tmp/$log 2>&1
        chown -R mysql:mysql $datefile
        service mysqld start
        binlog=`cat /backup/xtra_base_$dt/xtrabackup_binlog_info|awk '{print $1}'`
        pos=`cat /backup/xtra_base_$dt/xtrabackup_binlog_info|awk '{print $2}'`
        mysqlbinlog --no-defaults --start-position=$pos /mysqllog/$binlog | mysql -u$user -p$pwd
        ;;  
    1)  
        # Monday Recover Database 
        innobackupex --apply-log --redo-only /backup/xtra_base_$lastday > /tmp/$log 2>&1
        innobackupex --apply-log  /backup/xtra_base_$lastday/ --incremental-dir=/backup/xtra_inc_$dt/ >> /tmp/$log 2>&1
        innobackupex --apply-log  /backup/xtra_base_$lastday >> /tmp/$log 2>&1
        service mysqld stop
        rm -rf $datefile/*
        innobackupex --defaults-file=/etc/my.cnf --copy-back /backup/xtra_base_$lastday >> /tmp/$log 2>&1
        chown -R mysql:mysql $datefile
        service mysqld start
        binlog=`cat /backup/xtra_base_$lastday/xtrabackup_binlog_info|awk '{print $1}'`
        pos=`cat /backup/xtra_base_$lastday/xtrabackup_binlog_info|awk '{print $2}'`
        mysqlbinlog --no-defaults --start-position=$pos /mysqllog/$binlog | mysql -u$user -p$pwd
        ;;  
    2)  
        # Tuesday Recover Database
        innobackupex --apply-log --redo-only /backup/xtra_base_$lasttwoday > /tmp/$log 2>&1
        innobackupex --apply-log --redo-only /backup/xtra_base_$lasttwoday/ --incremental-dir=/backup/xtra_inc_$lastday/ >> /tmp/$log 2>&innobackupex --apply-log  /backup/xtra_base_$lasttwoday/ --incremental-dir=/backup/xtra_inc_$dt/ >> /tmp/$log 2>&1
        innobackupex --apply-log  /backup/xtra_base_$lasttwoday >> /tmp/$log 2>&1
        service mysqld stop
        rm -rf $datefile/*
        innobackupex --defaults-file=/etc/my.cnf --copy-back /backup/xtra_base_$lasttwoday >> /tmp/$log 2>&1
        chown -R mysql:mysql $datefile
        service mysqld start
        binlog=`cat /backup/xtra_base_$lasttwoday/xtrabackup_binlog_info|awk '{print $1}'`
        pos=`cat /backup/xtra_base_$lasttwoday/xtrabackup_binlog_info|awk '{print $2}'`
        mysqlbinlog --no-defaults --start-position=$pos /mysqllog/$binlog | mysql -u$user -p$pwd
        ;;  
    3)  
        # Wednesday Recover Database 
        innobackupex --apply-log  /backup/xtra_base_$dt > /tmp/$log 2>&1
        service mysqld stop
        rm -rf $datefile/*
        innobackupex --defaults-file=/etc/my.cnf --copy-back /backup/xtra_base_$dt >> /tmp/$log 2>&1
        chown -R mysql:mysql $datefile
        service mysqld start 
        binlog=`cat /backup/xtra_base_$dt/xtrabackup_binlog_info|awk '{print $1}'`
        pos=`cat /backup/xtra_base_$dt/xtrabackup_binlog_info|awk '{print $2}'`
        mysqlbinlog --no-defaults --start-position=$pos /mysqllog/$binlog | mysql -u$user -p$pwd
        ;;  
    4)  
        # Thursday  Recover Database 
        innobackupex --apply-log --redo-only /backup/xtra_base_$lastday > /tmp/$log 2>&1
        innobackupex --apply-log  /backup/xtra_base_$lastday/ --incremental-dir=/backup/xtra_inc_$dt/ >> /tmp/$log 2>&1
        innobackupex --apply-log  /backup/xtra_base_$lastday >> /tmp/$log 2>&1
        service mysqld stop
        rm -rf $datefile/*
        innobackupex --defaults-file=/etc/my.cnf --copy-back /backup/xtra_base_$lastday >> /tmp/$log 2>&1
        chown -R mysql:mysql $datefile
        service mysqld start 
        binlog=`cat /backup/xtra_base_$lastday/xtrabackup_binlog_info|awk '{print $1}'`
        pos=`cat /backup/xtra_base_$lastday/xtrabackup_binlog_info|awk '{print $2}'`
        mysqlbinlog --no-defaults --start-position=$pos /mysqllog/$binlog | mysql -u$user -p$pwd
        ;;  
    5)  
        # Friday Recover Database  
        innobackupex --apply-log --redo-only /backup/xtra_base_$lasttwoday > /tmp/$log 2>&1
        innobackupex --apply-log --redo-only /backup/xtra_base_$lasttwoday/ --incremental-dir=/backup/xtra_inc_$lastday/ >> /tmp/$log 2>&innobackupex --apply-log  /backup/xtra_base_$lasttwoday/ --incremental-dir=/backup/xtra_inc_$dt/ >> /tmp/$log 2>&1
        innobackupex --apply-log  /backup/xtra_base_$lasttwoday >> /tmp/$log 2>&1
        service mysqld stop
        rm -rf $datefile/*
        innobackupex --defaults-file=/etc/my.cnf --copy-back /backup/xtra_base_$lasttwoday >> /tmp/$log 2>&1
        chown -R mysql:mysql $datefile
        service mysqld start
        binlog=`cat /backup/xtra_base_$lasttwoday/xtrabackup_binlog_info|awk '{print $1}'`
        pos=`cat /backup/xtra_base_$lasttwoday/xtrabackup_binlog_info|awk '{print $2}'`
        mysqlbinlog --no-defaults --start-position=$pos /mysqllog/$binlog | mysql -u$user -p$pwd
        ;;  
    6)  
        # Saturday Recover Database  
        innobackupex --apply-log --redo-only /backup/xtra_base_$lastthreeday > /tmp/$log 2>&1
        innobackupex --apply-log --redo-only /backup/xtra_base_$lastthreeday/ --incremental-dir=/backup/xtra_inc_$lasttwoday/ >> /tmp/$log 2>&1
        innobackupex --apply-log --redo-only /backup/xtra_base_$lastthreeday/ --incremental-dir=/backup/xtra_inc_$lastday/ >> /tmp/$log 2>&1
        innobackupex --apply-log  /backup/xtra_base_$lastthreeday/ --incremental-dir=/backup/xtra_inc_$dt/ >> /tmp/$log 2>&1
        innobackupex --apply-log  /backup/xtra_base_$lastthreeday >> /tmp/$log 2>&1
        service mysqld stop
        rm -rf $datefile/*
        innobackupex --defaults-file=/etc/my.cnf --copy-back /backup/xtra_base_$lastthreeday >> /tmp/$log 2>&1
        chown -R mysql:mysql $datefile
        service mysqld start
        binlog=`cat /backup/xtra_base_$lastthreeday/xtrabackup_binlog_info|awk '{print $1}'`
        pos=`cat /backup/xtra_base_$lastthreeday/xtrabackup_binlog_info|awk '{print $2}'`
        mysqlbinlog --no-defaults --start-position=$pos /mysqllog/$binlog | mysql -u$user -p$pwd
        ;;  
esac 
find /tmp -mtime +6 -type f -name 'recoverlog.*' -exec rm -rf {} \;

 

你可能感兴趣的:(Java,MySQL)