最近遇到實(shí)例遷移的問題,數(shù)據(jù)遷完后還需要將數(shù)據(jù)庫用戶及權(quán)限遷移過去。進(jìn)行邏輯備份時(shí),我一般習(xí)慣將MySQL系統(tǒng)庫排除掉,這樣備份里面就不包含數(shù)據(jù)庫用戶相關(guān)信息了。這時(shí)候如果想遷移用戶相關(guān)信息 可以采用以下三種方案,類似的 我們也可以采用以下三種方案來備份數(shù)據(jù)庫賬號(hào)相關(guān)信息。(本文方案針對(duì)MySQL5.7版本,其他版本稍有不同)
我們知道,數(shù)據(jù)庫用戶密碼及權(quán)限相關(guān)信息保存在系統(tǒng)庫mysql 里面。采用mysqldump可以將相關(guān)表數(shù)據(jù)導(dǎo)出來 如果有遷移用戶的需求 我們可以按照需求在另外的實(shí)例中插入這些數(shù)據(jù)。下面我們來演示下:
#只導(dǎo)出mysql庫中的user,db,tables_priv表數(shù)據(jù)
#如果你有針隊(duì)column的賦權(quán) 可以再導(dǎo)出columns_priv表數(shù)據(jù)
#若數(shù)據(jù)庫開啟了GTID 導(dǎo)出時(shí)最好加上 --set-gtid-purged=OFF
mysqldump -uroot -proot mysql user db tables_priv -t --skip-extended-insert > /tmp/user_info.sql
#導(dǎo)出的具體信息
--
-- Dumping data for table `user`
--
LOCK TABLES `user` WRITE;
/*!40000 ALTER TABLE `user` DISABLE KEYS */;
INSERT INTO `user` VALUES ('%','root','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','',_binary '',_binary '',_binary '',0,0,0,0,'mysql_native_password','*
81F5E21E35407D884A6CD4A731AEBFB6AF209E1B','N','2019-03-06 03:03:15',NULL,'N');
INSERT INTO `user` VALUES ('localhost','mysql.session','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','Y','N','N','N','N','N','N','N','N','N','N','N','N','N','',_binary '',_binary '',_binary '',0,0,0,0,'mysql_na
tive_password','*THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE','N','2019-03-06 02:57:40',NULL,'Y');
INSERT INTO `user` VALUES ('localhost','mysql.sys','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','',_binary '',_binary '',_binary '',0,0,0,0,'mysql_native
_password','*THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE','N','2019-03-06 02:57:40',NULL,'Y');
INSERT INTO `user` VALUES ('%','test','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','',_binary '',_binary '',_binary '',0,0,0,0,'mysql_native_password','*
94BDCEBE19083CE2A1F959FD02F964C7AF4CFC29','N','2019-04-19 06:24:54',NULL,'N');
INSERT INTO `user` VALUES ('%','read','Y','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','',_binary '',_binary '',_binary '',0,0,0,0,'mysql_native_password','*
2158DEFBE7B6FC24585930DF63794A2A44F22736','N','2019-04-19 06:27:45',NULL,'N');
INSERT INTO `user` VALUES ('%','test_user','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','',_binary '',_binary '',_binary '',0,0,0,0,'mysql_native_passwor
d','*8A447777509932F0ED07ADB033562027D95A0F17','N','2019-04-19 06:29:38',NULL,'N');
/*!40000 ALTER TABLE `user` ENABLE KEYS */;
UNLOCK TABLES;
--
-- Dumping data for table `db`
--
LOCK TABLES `db` WRITE;
/*!40000 ALTER TABLE `db` DISABLE KEYS */;
INSERT INTO `db` VALUES ('localhost','performance_schema','mysql.session','Y','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N');
INSERT INTO `db` VALUES ('localhost','sys','mysql.sys','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','N','Y');
INSERT INTO `db` VALUES ('%','test_db','test','Y','Y','Y','Y','Y','Y','N','N','N','Y','N','N','Y','Y','N','N','Y','N','N');
/*!40000 ALTER TABLE `db` ENABLE KEYS */;
UNLOCK TABLES;
--
-- Dumping data for table `tables_priv`
--
LOCK TABLES `tables_priv` WRITE;
/*!40000 ALTER TABLE `tables_priv` DISABLE KEYS */;
INSERT INTO `tables_priv` VALUES ('localhost','mysql','mysql.session','user','boot@connecting host','0000-00-00 00:00:00','Select','');
INSERT INTO `tables_priv` VALUES ('localhost','sys','mysql.sys','sys_config','root@localhost','2019-03-06 02:57:40','Select','');
INSERT INTO `tables_priv` VALUES ('%','test_db','test_user','t1','root@localhost','0000-00-00 00:00:00','Select,Insert,Update,Delete','');
/*!40000 ALTER TABLE `tables_priv` ENABLE KEYS */;
UNLOCK TABLES;
#在新的實(shí)例插入所需數(shù)據(jù) 就可以創(chuàng)建出相同的用戶及權(quán)限了
mysqlpump是mysqldump的一個(gè)衍生,也是MySQL邏輯備份的工具。mysqlpump可用的選項(xiàng)更多,可以直接導(dǎo)出創(chuàng)建用戶的語句及賦權(quán)的語句。下面我們來演示下:
本篇文章介紹了三種導(dǎo)出數(shù)據(jù)庫用戶信息的方案,每種方案都給出了腳本并進(jìn)行演示。同時(shí) 這三種方案稍加以封裝都可以作為備份數(shù)據(jù)庫用戶權(quán)限的腳本??赡苣氵€有其他方案,如:pt-show-grants等,歡迎分享出來哦,也歡迎大家收藏或者改造成更適合自己的腳本,說不定什么時(shí)候就會(huì)用到哦 特別是一個(gè)實(shí)例有好多用戶時(shí),你會(huì)發(fā)現(xiàn)腳本更好用哈。
以上就是MySQL如何優(yōu)雅的備份賬號(hào)相關(guān)信息的詳細(xì)內(nèi)容,更多關(guān)于MySQL 備份賬號(hào)相關(guān)信息的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!