MySQL中用户权限迁移

MySQL中用户权限迁移

近期需要对两台mysql进行合并,涉及到用户权限问题,特将需要合并的mysql中的用户权限进行一次迁移,并记录如下

一、导出用户权限

1、获取mysql库中应用用户的列表信息

mysql -B -N -uroot -p'你的密码' -S /tmp/mysql3306.sock -e "SELECT CONCAT('\'', user,'\'@\'', host, '\'') FROM user WHERE user NOT IN('replication','root','','mysql.session','mysql.sys')" mysql > /tmp/mysql_all_users.txt

2、获取用户权限信息

while read line; do mysql -B -N -uroot -p'你的密码' -S /tmp/mysql3306.sock -e "SHOW GRANTS FOR $line"; done < /tmp/mysql_all_users.txt > /tmp/mysql_all_users_sql.sql

3、修改导出的 mysql_all_users_sql.sql

    在每行的结尾增加“;”,做为结束符

sed -i 's/$/;/' /tmp/mysql_all_users_sql.sql

 在最后一行增加 “flush privileges;” 更新权限,使其生效

echo "flush privileges;" >> /tmp/mysql_all_users_sql.sql

 

二、导入用户权限

1、copy 导出的mysql_all_users_sql.sql到新的mysql服务器上

scp /tmp/mysql_all_users_sql.sql user@192.168.1.123:/tmp/
回车,输入user的密码

2、导入到mysql库中

mysql -u root -p"你的密码" -S /tmp/mysql3306.sock < /tmp/mysql_all_users_sql.sql

3、使用导进来的用户测试登录和验证权限

 

至此,mysql中用户权限迁移完成。

 

posted @ 2021-08-12 11:00  MR__Wang  阅读(1224)  评论(0编辑  收藏  举报