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中用户权限迁移完成。