MySQL中用户权限迁移

453 阅读1分钟

近期需要对两台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_users.txt

2、获取用户权限信息

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

3、修改导出的 mysql_users_sql.sql

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

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

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

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

二、导入用户权限

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

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

2、导入到mysql库中

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

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

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