校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > MySQL如何優雅的備份賬號相關信息

MySQL如何優雅的備份賬號相關信息

熱門標簽:石家莊400電話辦理公司 新鄉智能外呼系統好處 咸陽防封電銷卡 廣東400企業電話申請流程 臨沂做地圖標注 申請400電話電話價格 地圖標注客戶付款 許昌外呼增值業務線路 宜賓全自動外呼系統廠家

前言:

最近遇到實例遷移的問題,數據遷完后還需要將數據庫用戶及權限遷移過去。進行邏輯備份時,我一般習慣將MySQL系統庫排除掉,這樣備份里面就不包含數據庫用戶相關信息了。這時候如果想遷移用戶相關信息 可以采用以下三種方案,類似的 我們也可以采用以下三種方案來備份數據庫賬號相關信息。(本文方案針對MySQL5.7版本,其他版本稍有不同)

1.mysqldump邏輯導出用戶相關信息

我們知道,數據庫用戶密碼及權限相關信息保存在系統庫mysql 里面。采用mysqldump可以將相關表數據導出來 如果有遷移用戶的需求 我們可以按照需求在另外的實例中插入這些數據。下面我們來演示下:

#只導出mysql庫中的user,db,tables_priv表數據 
#如果你有針隊column的賦權 可以再導出columns_priv表數據
#若數據庫開啟了GTID 導出時最好加上 --set-gtid-purged=OFF
mysqldump -uroot -proot mysql user db tables_priv -t --skip-extended-insert > /tmp/user_info.sql

#導出的具體信息
--
-- 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;

#在新的實例插入所需數據 就可以創建出相同的用戶及權限了 

2.自定義腳本導出

首先拼接出創建用戶的語句:

SELECT
	CONCAT(
		'create user \'',
  user,
  ''@\'',
  Host,
  '''
  ' IDENTIFIED BY PASSWORD \'',
  authentication_string,
		'';'
	) AS CreateUserQuery
FROM
	mysql.`user`
WHERE
	`User` NOT IN (
		'mysql.session',
		'mysql.sys'
	);
	
#結果 在新實例執行后可以創建出相同密碼的用戶
mysql> SELECT
  -> CONCAT(
  -> 'create user \'',
  ->   user,
  ->   ''@\'',
  ->   Host,
  ->   '''
  ->   ' IDENTIFIED BY PASSWORD \'',
  ->   authentication_string,
  -> '';'
  -> ) AS CreateUserQuery
  -> FROM
  -> mysql.`user`
  -> WHERE
  -> `User` NOT IN (
  -> 'mysql.session',
  -> 'mysql.sys'
  -> );
+-------------------------------------------------------------------------------------------------+
| CreateUserQuery                                         |
+-------------------------------------------------------------------------------------------------+
| create user 'root'@'%' IDENTIFIED BY PASSWORD '*81F5E21E35407D884A6CD4A731AEBFB6AF209E1B';   |
| create user 'test'@'%' IDENTIFIED BY PASSWORD '*94BDCEBE19083CE2A1F959FD02F964C7AF4CFC29';   |
| create user 'read'@'%' IDENTIFIED BY PASSWORD '*2158DEFBE7B6FC24585930DF63794A2A44F22736';   |
| create user 'test_user'@'%' IDENTIFIED BY PASSWORD '*8A447777509932F0ED07ADB033562027D95A0F17'; |
+-------------------------------------------------------------------------------------------------+
4 rows in set (0.00 sec)

然后通過腳本導出用戶權限:

#導出權限腳本
#!/bin/bash 
#Function export user privileges 
 
pwd=root 
expgrants() 
{ 
 mysql -B -u'root' -p${pwd} -N $@ -e "SELECT CONCAT( 'SHOW GRANTS FOR ''', user, '''@''', host, ''';' ) AS query FROM mysql.user" | \

 mysql -u'root' -p${pwd} $@ | \

 sed 's/\(GRANT .*\)/\1;/;s/^\(Grants for .*\)/-- \1 /;/--/{x;p;x;}' 
} 
 
expgrants > /tmp/grants.sql
echo "flush privileges;" >> /tmp/grants.sql

#執行腳本后結果
-- Grants for read@% 
GRANT SELECT ON *.* TO 'read'@'%';

-- Grants for root@% 
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;

-- Grants for test@% 
GRANT USAGE ON *.* TO 'test'@'%';
GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, ALTER, EXECUTE, CREATE VIEW, SHOW VIEW ON `test_db`.* TO 'test'@'%';

-- Grants for test_user@% 
GRANT USAGE ON *.* TO 'test_user'@'%';
GRANT SELECT, INSERT, UPDATE, DELETE ON `test_db`.`t1` TO 'test_user'@'%';

-- Grants for mysql.session@localhost 
GRANT SUPER ON *.* TO 'mysql.session'@'localhost';
GRANT SELECT ON `performance_schema`.* TO 'mysql.session'@'localhost';
GRANT SELECT ON `mysql`.`user` TO 'mysql.session'@'localhost';

-- Grants for mysql.sys@localhost 
GRANT USAGE ON *.* TO 'mysql.sys'@'localhost';
GRANT TRIGGER ON `sys`.* TO 'mysql.sys'@'localhost';
GRANT SELECT ON `sys`.`sys_config` TO 'mysql.sys'@'localhost';

3.mysqlpump直接導出用戶

mysqlpump是mysqldump的一個衍生,也是MySQL邏輯備份的工具。mysqlpump可用的選項更多,可以直接導出創建用戶的語句及賦權的語句。下面我們來演示下:

#exclude-databases排除數據庫 --users指定導出用戶 exclude-users排除哪些用戶 
#還可以增加 --add-drop-user 參數 生成drop user語句
#若數據庫開啟了GTID 導出時必須加上 --set-gtid-purged=OFF
mysqlpump -uroot -proot --exclude-databases=% --users --exclude-users=mysql.session,mysql.sys > /tmp/user.sql

#導出的結果
-- Dump created by MySQL pump utility, version: 5.7.23, linux-glibc2.12 (x86_64)
-- Dump start time: Fri Apr 19 15:03:02 2019
-- Server version: 5.7.23

SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
SET @OLD_SQL_MODE=@@SQL_MODE;
SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
SET @@SESSION.SQL_LOG_BIN= 0;
SET @OLD_TIME_ZONE=@@TIME_ZONE;
SET TIME_ZONE='+00:00';
SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT;
SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS;
SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION;
SET NAMES utf8mb4;
CREATE USER 'read'@'%' IDENTIFIED WITH 'mysql_native_password' AS '*2158DEFBE7B6FC24585930DF63794A2A44F22736' REQUIRE NONE PASSWORD EXPIRE DEFAULT ACCOUNT UNLOCK;
GRANT SELECT ON *.* TO 'read'@'%';
CREATE USER 'root'@'%' IDENTIFIED WITH 'mysql_native_password' AS '*81F5E21E35407D884A6CD4A731AEBFB6AF209E1B' REQUIRE NONE PASSWORD EXPIRE DEFAULT ACCOUNT UNLOCK;
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;
CREATE USER 'test'@'%' IDENTIFIED WITH 'mysql_native_password' AS '*94BDCEBE19083CE2A1F959FD02F964C7AF4CFC29' REQUIRE NONE PASSWORD EXPIRE DEFAULT ACCOUNT UNLOCK;
GRANT USAGE ON *.* TO 'test'@'%';
GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, ALTER, EXECUTE, CREATE VIEW, SHOW VIEW ON `test_db`.* TO 'test'@'%';
CREATE USER 'test_user'@'%' IDENTIFIED WITH 'mysql_native_password' AS '*8A447777509932F0ED07ADB033562027D95A0F17' REQUIRE NONE PASSWORD EXPIRE DEFAULT ACCOUNT UNLOCK;
GRANT USAGE ON *.* TO 'test_user'@'%';
GRANT SELECT, INSERT, UPDATE, DELETE ON `test_db`.`t1` TO 'test_user'@'%';
SET TIME_ZONE=@OLD_TIME_ZONE;
SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT;
SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS;
SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION;
SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;
SET SQL_MODE=@OLD_SQL_MODE;
-- Dump end time: Fri Apr 19 15:03:02 2019

#可以看出 導出結果只包含創建用戶及賦權的語句 十分好用
#mysqlpump詳細用法可參考:
https://dev.mysql.com/doc/refman/5.7/en/mysqlpump.html

總結:

本篇文章介紹了三種導出數據庫用戶信息的方案,每種方案都給出了腳本并進行演示。同時 這三種方案稍加以封裝都可以作為備份數據庫用戶權限的腳本。可能你還有其他方案,如:pt-show-grants等,歡迎分享出來哦,也歡迎大家收藏或者改造成更適合自己的腳本,說不定什么時候就會用到哦 特別是一個實例有好多用戶時,你會發現腳本更好用哈。

以上就是MySQL如何優雅的備份賬號相關信息的詳細內容,更多關于MySQL 備份賬號相關信息的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • MySQL備份腳本的寫法
  • 淺析MySQL 備份與恢復
  • 詳解mysql的備份與恢復
  • MySQL定時備份方案(利用Linux crontab)
  • 淺析mysql 定時備份任務
  • linux 服務器自動備份腳本的方法(mysql、附件備份)
  • linux定時備份MySQL數據庫并刪除以前的備份文件(推薦)
  • CentOS7下 MySQL定時自動備份的實現方法
  • Mysql備份多個數據庫代碼實例

標簽:鎮江 北京 臺灣 合肥 阜新 貴州 鷹潭 日照

巨人網絡通訊聲明:本文標題《MySQL如何優雅的備份賬號相關信息》,本文關鍵詞  MySQL,如何,優雅,的,備份,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL如何優雅的備份賬號相關信息》相關的同類信息!
  • 本頁收集關于MySQL如何優雅的備份賬號相關信息的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    欧美色图激情小说| 伊人色综合久久天天人手人婷| 日韩黄色免费电影| 欧美mv日韩mv| 色偷偷成人一区二区三区91| 久久99在线观看| 亚洲男女一区二区三区| 日韩一级片在线播放| 成人福利视频在线| 美女视频黄a大片欧美| 亚洲欧美一区二区久久| 欧美成人性福生活免费看| 成人美女视频在线看| 另类小说色综合网站| 午夜精彩视频在线观看不卡| 久久久亚洲精品一区二区三区| 欧美午夜宅男影院| 91视频观看视频| 717成人午夜免费福利电影| 亚洲欧美综合色| 亚洲人成在线播放网站岛国| 亚洲一级二级三级| 日韩精品综合一本久道在线视频| 国产91精品在线观看| 日韩中文字幕一区二区三区| 久久这里只精品最新地址| 91丨九色丨黑人外教| 国产一区二区三区在线观看免费 | 日韩精品一区二区三区老鸭窝| 91在线视频播放| 91麻豆成人久久精品二区三区| 国内不卡的二区三区中文字幕| 国产一区二区精品久久| 国产裸体歌舞团一区二区| 国产xxx精品视频大全| 男人的天堂久久精品| 一区二区三区四区不卡在线| 国产在线精品一区二区不卡了| 色天使久久综合网天天| 51精品视频一区二区三区| 亚洲国产精品ⅴa在线观看| 亚洲色欲色欲www| 日韩电影免费一区| 国产福利不卡视频| 欧美日韩国产影片| 中文字幕一区二区三区蜜月| 舔着乳尖日韩一区| 美女一区二区视频| 国产精品羞羞答答xxdd| 国产一区二区不卡| 欧美日韩一区在线| 精品国产麻豆免费人成网站| 成人国产精品免费网站| 亚洲二区在线观看| 中文字幕欧美区| 久久影视一区二区| 在线欧美日韩精品| 波多野结衣亚洲一区| 一本色道a无线码一区v| 91官网在线免费观看| 欧美伊人久久大香线蕉综合69| 欧美精品精品一区| 95精品视频在线| 福利一区福利二区| a级精品国产片在线观看| 国产成人在线电影| 99精品视频在线观看免费| 成人黄色一级视频| 色综合天天综合狠狠| 欧美日韩精品福利| 欧美成人国产一区二区| 久久色在线视频| 一区二区三区四区国产精品| 一区二区三区四区蜜桃| 丝袜亚洲另类丝袜在线| 黄色日韩三级电影| 99久久久精品| 欧美二区三区的天堂| 91超碰这里只有精品国产| 久久久国产午夜精品| 亚洲欧洲成人自拍| 久久成人免费电影| 色综合久久久久网| 26uuu欧美| 亚欧色一区w666天堂| 国产盗摄一区二区| 日韩欧美成人午夜| 亚洲国产精品麻豆| 北条麻妃一区二区三区| 精品国产网站在线观看| 亚洲综合视频网| proumb性欧美在线观看| 日韩精品一区二区三区在线播放 | 紧缚奴在线一区二区三区| 91在线观看免费视频| 国产日韩欧美在线一区| 日韩精品亚洲一区二区三区免费| 成人91在线观看| 国产人久久人人人人爽| 久久精品国产77777蜜臀| 欧美日韩精品一区视频| 亚洲一区二区三区中文字幕| 99久久99久久精品免费看蜜桃| 久久夜色精品国产噜噜av| 紧缚捆绑精品一区二区| 亚洲精品一区二区三区蜜桃下载 | 91免费观看视频在线| 亚洲黄色免费网站| 91国产视频在线观看| 亚洲国产中文字幕在线视频综合 | 久久99精品久久久久久| 精品久久久久久最新网址| 国产精品影音先锋| 亚洲欧洲www| 日韩网站在线看片你懂的| 国产乱码字幕精品高清av| 国产精品剧情在线亚洲| 欧美日韩一区视频| 国产一区二区免费看| 中文字幕一区二区三区精华液 | 亚洲另类一区二区| 欧美精品一区二区三区很污很色的| 免费黄网站欧美| 亚洲精品视频一区| 久久麻豆一区二区| 在线视频国产一区| 成人动漫一区二区三区| 捆绑变态av一区二区三区| 亚洲欧洲制服丝袜| 精品久久久久久久久久久久包黑料| 91网上在线视频| 国产一区二区三区免费看| 日韩在线一区二区三区| 亚洲国产成人91porn| 国产精品视频一二三| 久久久久久久久久久电影| 日韩一区二区三区在线视频| 欧美制服丝袜第一页| 欧美性色欧美a在线播放| 97久久精品人人做人人爽50路| 国产在线精品免费| 国内精品久久久久影院一蜜桃| 亚洲精品高清在线观看| 亚洲美女屁股眼交| 亚洲精品国产第一综合99久久 | 国产精品白丝jk白祙喷水网站| 美女网站视频久久| 国产九九视频一区二区三区| 国产激情精品久久久第一区二区| 国产在线精品一区二区三区不卡| 蜜桃一区二区三区在线观看| 成人毛片视频在线观看| 在线亚洲人成电影网站色www| 99精品国产一区二区三区不卡| 在线国产亚洲欧美| 欧美一区二区三区在线电影| 精品国产一区二区三区忘忧草| 国产亚洲一区二区在线观看| 中文字幕亚洲电影| 久久99国产精品免费网站| av在线播放成人| 精品日韩av一区二区| 亚洲美女免费在线| 国产高清精品网站| 欧美一区二区三区电影| 国产精品日日摸夜夜摸av| 亚洲国产综合人成综合网站| 国产精品亚洲午夜一区二区三区| 91麻豆国产自产在线观看| 国产精品网曝门| 国产成人亚洲精品狼色在线| 欧美日韩精品专区| 国产女主播一区| 成人午夜激情在线| 国产日产欧美精品一区二区三区| 日韩av一区二区三区四区| 欧美午夜视频网站| 一区二区在线免费| 色妹子一区二区| 亚洲精品国产一区二区三区四区在线| 国产在线一区二区| 国产日产欧美精品一区二区三区| 久久成人综合网| 日本一区二区免费在线| 国产成人高清在线| 18涩涩午夜精品.www| 欧美视频一区二区| 久久91精品国产91久久小草| 91精品久久久久久久91蜜桃| 美女一区二区视频| 亚洲欧洲精品一区二区三区不卡 | 日韩三级中文字幕| 激情亚洲综合在线| 中文字幕一区二区三| 欧美男男青年gay1069videost| 麻豆精品蜜桃视频网站| 亚洲天堂成人在线观看| 欧美精品久久天天躁| 国产毛片精品一区| 亚洲狠狠丁香婷婷综合久久久|