在MySQL跨版本升级时,建议使用mysqldump方式导出用户权限和用户数据,即使是小版本升级,导出过程中也应忽略系统数据库,避免系统表不兼容。

导出用户数据库脚本和用户创建脚本

##====================================================================##
# MySQL Dump导出数据和权限脚本
# 如果在主库上备份使用--master-data=2参数
# 如果在从库上备份使用--dump-slave=2参数
##====================================================================##
mysql_exe="/export/servers/mysql/bin/mysql"
mysqldump_exe="/export/servers/mysql/bin/mysqldump"
mysql_host="127.0.0.1"
mysql_port=3306
mysql_user="root"
mysql_password="root_psw"
working_dir="/export/mysql_update/"
data_file="${working_dir}/data_script.sql"
user_file="${working_dir}/user_script.sql"
log_file="${working_dir}/mysql_dump_log.txt"
err_file="${working_dir}/mysql_dump_err.txt"
master_slave_data="--master-data=2"
mysql_version="mysql57" ##====================================================##
## 1. create folder and file for mysql dump
##====================================================##
function crete_dump_file()
{
if [ -d ${data_file} ]
then
echo 'data file is exists, please check and remove it'.
exit 1
fi /bin/mkdir -p ${working_dir}
> ${data_file}
> ${user_file}
> ${log_file}
> ${err_file}
} ##====================================================##
## 1. get mysql version
##====================================================##
function get_mysql_version()
{
master_version_tmp=`${mysql_exe} \
--host="${mysql_host}" --port=${mysql_port} \
--user="${mysql_user}" --password="${mysql_password}" \
-e "select @@version;"`
if [[ master_version_tmp == 5.5.* ]]
then
mysql_version="mysql55"
elif [[ master_version_tmp == 5.6.* ]]
then
mysql_version="mysql56"
else
mysql_version="mysql57"
fi
} ##====================================================##
## 1. change global long_query_time=100
## 2、change session sql_log_bin=0
## 3. change global sync_binlog=0
## 4. change global innodb_flush_log_at_trx_commit=0
##====================================================##
function write_load_option()
{
echo "SET SESSION long_query_time=100;" >> ${data_file}
echo "SET GLOBAL sync_binlog=2;" >> ${data_file}
echo "SET GLOBAL innodb_flush_log_at_trx_commit=0;" >> ${data_file}
} ##====================================================##
## 1. if this is master server, user option master-data=2
## 2. if this is slave server, use option dump-slave=2
## 3. if this is slave server, get slave status and change master_host
##====================================================##
function create_master_slave_option()
{
master_host_ip=`${mysql_exe} \
--host="${mysql_host}" --port=${mysql_port} \
--user="${mysql_user}" --password="${mysql_password}" \
-e "show slave status \G" |grep "Master_Host"|head -n 1|awk -F":" '{gsub(" ","",$2);print $2}'` if [[ "$master_host_ip" == "1.1.1.1" ]]
then
echo "This is master server,use --master-data=2" >> ${log_file}
master_slave_data="--master-data=2"
elif [[ "$master_host_ip" == "" ]]
then
echo "This is master server,use --master-data=2" >> ${log_file}
master_slave_data="--master-data=2"
else
echo "This is slave server,use --dump-slave=2" >> ${log_file}
master_slave_data="--dump-slave=2"
get_slave_status
fi
} ##====================================================##
## 1. dump data from user databases.
##====================================================##
function dump_user_data(){
databases=`${mysql_exe} \
--host="${mysql_host}" --port=${mysql_port} \
--user="${mysql_user}" --password="${mysql_password}" \
-Ne "SELECT SCHEMA_NAME
FROM information_schema.SCHEMATA
WHERE SCHEMA_NAME NOT IN ('information_schema','performance_schema','sys','mysql');"` echo "databases:${databases}" >> ${log_file} if [[ mysql_version == "mysql55" ]]
then
gtid_purged_option=""
else
gtid_purged_option="--set-gtid-purged=OFF"
fi ## 导出建表语句和数据
((echo "Start mysqldump data at "`date "+%y-%m-%d %H:%M:%S"`) \
&& ( ${mysqldump_exe} \
--host="${mysql_host}" \
--port=${mysql_port} \
--user="${mysql_user}" \
--password="${mysql_password}" \
--default-character-set=utf8 \
--hex-blob --opt --quick \
--events --routines --triggers \
--single_transaction \
${gtid_purged_option} \
${master_slave_data} \
--databases $databases \
>> ${data_file} ) \
&& (echo "MySQLdump data success at "`date "+%y-%m-%d %H:%M:%S"`)) \
1>>${log_file} \
2>>${err_file}
} ##====================================================##
## 1. dump user script on mysql
## 2. this script only can be used on mysql 5.7
##====================================================##
function dump_user_script_5_7()
{
((echo "start mysqldump user at "`date "+%y-%m-%d %H:%M:%S"`) \
&& (echo "select concat('show create user ''',user,'''@''',host, ''';','show grants for ''',user,'''@''',host, ''';') from mysql.user where user <>'root' and user<>'' and host <> '' " | \
${mysql_exe} --host="${mysql_host}" --port=${mysql_port} \
--user="${mysql_user}" --password="${mysql_password}" -N | \
${mysql_exe} --host="${mysql_host}" --port=${mysql_port} \
--user="${mysql_user}" --password="${mysql_password}" -N | \
sed "s/$/;/" >> ${user_file}) \
&& (echo "MySQLdump user success at "`date "+%y-%m-%d %H:%M:%S"`)) \
1>>${log_file} \
2>>${err_file}
} ##====================================================##
## 1. dump user script on mysql
## 2. this script only can be used on mysql 5.5
##====================================================##
function dump_user_script_5_5()
{
((echo "start mysqldump user at "`date "+%y-%m-%d %H:%M:%S"`) \
&& (echo "select concat('show grants for ''',user,'''@''',host, ''';') from mysql.user where user <>'root' and user<>'' and host <> '' " | \
${mysql_exe} --host="${mysql_host}" --port=${mysql_port} --user="${mysql_user}" --password="${mysql_password}" -N | \
${mysql_exe} --host="${mysql_host}" --port=${mysql_port} --user="${mysql_user}" --password="${mysql_password}" -N | \
sed "s/$/;/" >> ${user_file}) \
&& (echo "MySQLdump user success at "`date "+%y-%m-%d %H:%M:%S"`)) \
1>>${log_file} \
2>>${err_file}
} function dump_user_script()
{
if [[ mysql_version == "mysql55" ]]
then
dump_user_script_5_5
else
dump_user_script_5_7
fi
} echo "check and create folder and file"
crete_dump_file echo "write load option"
write_load_option echo "check mysql version"
get_mysql_version echo "dump user data"
dump_user_data echo "dump user right"
dump_user_script echo "MySQL dump finished"

导入用户数据库和用户脚本

##====================================================================##
mysql_exe="/export/servers/mysql/bin/mysql"
mysqldump_exe="/export/servers/mysql/bin/mysqldump"
mysql_host="127.0.0.1"
mysql_port=
mysql_user="root"
mysql_password="root_psw"
working_dir="/export/mysql_update/"
data_file="${working_dir}/data_script.sql"
user_file="${working_dir}/user_script.sql"
log_file="${working_dir}/mysql_load_log.txt"
err_file="${working_dir}/mysql_load_err.txt" ##====================================================##
## . init_env
##====================================================##
function init_env()
{
echo "init env"
echo > ${log_file}
echo > ${err_file}
} ##====================================================##
## . load user data
##====================================================##
function load_user_data()
{
echo "start to load user data" ((echo "Start load data at "`date "+%y-%m-%d %H:%M:%S"`) \
&& ( ${mysql_exe} \
--host="${mysql_host}" --port=${mysql_port} \
--user="${mysql_user}" --password="${mysql_password}" \
--batch < ${data_file} ) \
&& (echo "load data success at "`date "+%y-%m-%d %H:%M:%S"`)) \
>>${log_file} \
>>${err_file} echo "end to load user data" } ##====================================================##
## . load user right
##====================================================##
function load_user_right()
{
echo "start to load user right" ((echo "Start load use right at "`date "+%y-%m-%d %H:%M:%S"`) \
&& ( ${mysql_exe} \
--host="${mysql_host}" --port=${mysql_port} \
--user="${mysql_user}" --password="${mysql_password}" \
--batch < ${user_file} ) \
&& (echo "load user right at "`date "+%y-%m-%d %H:%M:%S"`)) \
>>${log_file} \
>>${err_file} echo "end to load user right" } init_env
load_user_data
load_user_right

MySQL--使用mysqldump进行数据库版本升级的更多相关文章

  1. MySQL之 Mysqldump导出数据库

    参数大全 参数说明 --all-databases , -A 导出全部数据库. mysqldump -uroot -p --all-databases --all-tablespaces , -Y 导 ...

  2. MySQL 使用 MySQLDump 复制数据库

    1.导出整个数据库  mysqldump -u 用户名 -p 数据库名 > 导出的文件名      mysqldump -u wcnc -p smgp_apps_wcnc > wcnc.s ...

  3. MySQL使用mysqldump+binlog完整恢复被删除的数据库

    (一)概述 在日常的MySQL数据库运维过程中,可能会遇到用户误删除数据,常见的误删除数据操作有: 用户执行delete,因为条件不对,删除了不应该删除的数据(DML操作): 用户执行update,因 ...

  4. PHP定时备份MySQL,mysqldump语法大全

    几个常用操作: 1.备份 # 只导出表结构 d:/PHP/xampp/mysql/bin/mysqldump -h127.0.0.1 -P3306 -uroot -p123456 snsgou_sns ...

  5. MySQL命令行导出数据库

    MySQL命令行导出数据库:1,进入MySQL目录下的bin文件夹:cd MySQL中到bin文件夹的目录如我输入的命令行:cd C:\Program Files\MySQL\MySQL Server ...

  6. Mysql使用mysqldump按时间导出时的一个注意事项

    在使用Mysql的mysqldump命令按时间进行数据导出时,我们可能会遇到导出数据与原库中不符或者导出数据和我们期望的数据不同的情况. 我们知道Mysql数据库导出可以使用命令mysqldump,使 ...

  7. MYSQL使用mysqldump导出某个表的部分数据

    命令格式如下: mysqldump -u用户名 -p密码 数据库名 表名 --where="筛选条件" > 导出文件路径 例子: 从meteo数据库的sdata表中导出sen ...

  8. MySQL的mysqldump工具的基本用法

    导出要用到MySQL的mysqldump工具,基本用法是:    shell> mysqldump [OPTIONS] database [tables]    如果你不给定任何表,整个数据库将 ...

  9. MySQL 同主机不同数据库之间的复制

    MySQL同主机不同数据库的复制命令:注意运行在Terminal中,不运行在MySQL命令行中. mysqldump Portal_DEV -u root -ppassword1 --add-drop ...

随机推荐

  1. 006-nginx.conf详解-error_page 使用

    一.概述 nginx指令error_page的作用是当发生错误的时候能够显示一个预定义的uri 1.1.使用步骤 更改nginx.conf在http定义区域加入: proxy_intercept_er ...

  2. 【454】ML-DL相关链接

    GD(梯度下降)和SGD(随机梯度下降) 机器学习中的Bias和Variance 机器学习之判别式模型和生成式模型 笔记 | 什么是Cross Entropy

  3. 【451】python 同一行打印进度条

    参考:Python3 Print 同一行打印显示进度条效果 参考:\r\n, \r and \n what is the difference between them? [duplicate] 参考 ...

  4. nvarchar, varchar, nchar, char的差別

    1. var,意思是可變動的,因為欄位長度可變動,所以會額外花費2Byte去儲存地址2. n,支援UNICODE UCS-2字元,因為萬國編碼(支援中文字),所以1字儲存2Byte nvarchar: ...

  5. 深入Nginx之《常用参数配置技巧》

    常见参配置实战技巧 下面会讲解实战中应该怎么配置更为合理. 1.user 默认是nobody,如果使用nobody,Nginx在运行过程中会出现很多操作没有权限,比如写硬盘.一般都是用低于root级别 ...

  6. C# .net 提升 asp.net mvc, asp.net core mvc 并发量

    1.提升System.Net.ServicePointManager.DefaultConnectionLimit 2.提升最小工作线程数 ------ DefaultConnectionLimit在 ...

  7. POJ 2386 DFS深搜入门

    题目链接 Time Limit: 1000MS Memory Limit: 65536K Description Due to recent rains, water has pooled in va ...

  8. fineui 实现下拉框模糊查询

    官网下拉框模糊查询只能实现首字母模糊匹配,如果实现类似这样的 like '%'+关键字+'%',却没有. 今天群里的没想好同学分享了,前后模糊匹配代码.   代码示例: <body>   ...

  9. SQL Server 数据库启动过程(用户数据库加载过程的疑难杂症)

    前言 本篇主要是上一篇文章的补充篇,上一篇我们介绍了SQL Server服务启动过程所遇到的一些问题和解决方法,可点击查看,我们此篇主要介绍的是SQL Server启动过程中关于用户数据库加载的流程, ...

  10. [BZOJ4382][POI2015]Podział naszyjnika (神奇HASH)

    [问题描述]    长度为n 的一串项链,每颗珠子是K 种颜色之一.第i 颗与第i-1,i+1 颗珠子相邻,第n 颗与第1 颗也相邻.    切两刀,把项链断成两条链.要求每种颜色的珠子只能出现在其中 ...