婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > MySQL如何優(yōu)雅的備份賬號(hào)相關(guān)信息

MySQL如何優(yōu)雅的備份賬號(hào)相關(guān)信息

熱門標(biāo)簽:石家莊400電話辦理公司 新鄉(xiāng)智能外呼系統(tǒng)好處 咸陽(yáng)防封電銷卡 廣東400企業(yè)電話申請(qǐng)流程 臨沂做地圖標(biāo)注 申請(qǐng)400電話電話價(jià)格 地圖標(biāo)注客戶付款 許昌外呼增值業(yè)務(wù)線路 宜賓全自動(dòng)外呼系統(tǒng)廠家

前言:

最近遇到實(shí)例遷移的問(wèn)題,數(shù)據(jù)遷完后還需要將數(shù)據(jù)庫(kù)用戶及權(quán)限遷移過(guò)去。進(jìn)行邏輯備份時(shí),我一般習(xí)慣將MySQL系統(tǒng)庫(kù)排除掉,這樣備份里面就不包含數(shù)據(jù)庫(kù)用戶相關(guān)信息了。這時(shí)候如果想遷移用戶相關(guān)信息 可以采用以下三種方案,類似的 我們也可以采用以下三種方案來(lái)備份數(shù)據(jù)庫(kù)賬號(hào)相關(guān)信息。(本文方案針對(duì)MySQL5.7版本,其他版本稍有不同)

1.mysqldump邏輯導(dǎo)出用戶相關(guān)信息

我們知道,數(shù)據(jù)庫(kù)用戶密碼及權(quán)限相關(guān)信息保存在系統(tǒng)庫(kù)mysql 里面。采用mysqldump可以將相關(guān)表數(shù)據(jù)導(dǎo)出來(lái) 如果有遷移用戶的需求 我們可以按照需求在另外的實(shí)例中插入這些數(shù)據(jù)。下面我們來(lái)演示下:

#只導(dǎo)出mysql庫(kù)中的user,db,tables_priv表數(shù)據(jù) 
#如果你有針隊(duì)column的賦權(quán) 可以再導(dǎo)出columns_priv表數(shù)據(jù)
#若數(shù)據(jù)庫(kù)開(kāi)啟了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)限了 

2.自定義腳本導(dǎo)出

首先拼接出創(chuàng)建用戶的語(yǔ)句:

SELECT
	CONCAT(
		'create user \'',
  user,
  ''@\'',
  Host,
  '''
  ' IDENTIFIED BY PASSWORD \'',
  authentication_string,
		'';'
	) AS CreateUserQuery
FROM
	mysql.`user`
WHERE
	`User` NOT IN (
		'mysql.session',
		'mysql.sys'
	);
	
#結(jié)果 在新實(shí)例執(zhí)行后可以創(chuàng)建出相同密碼的用戶
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)

然后通過(guò)腳本導(dǎo)出用戶權(quán)限:

#導(dǎo)出權(quán)限腳本
#!/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

#執(zhí)行腳本后結(jié)果
-- 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直接導(dǎo)出用戶

mysqlpump是mysqldump的一個(gè)衍生,也是MySQL邏輯備份的工具。mysqlpump可用的選項(xiàng)更多,可以直接導(dǎo)出創(chuàng)建用戶的語(yǔ)句及賦權(quán)的語(yǔ)句。下面我們來(lái)演示下:

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

#導(dǎo)出的結(jié)果
-- 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

#可以看出 導(dǎo)出結(jié)果只包含創(chuàng)建用戶及賦權(quán)的語(yǔ)句 十分好用
#mysqlpump詳細(xì)用法可參考:
https://dev.mysql.com/doc/refman/5.7/en/mysqlpump.html

總結(jié):

本篇文章介紹了三種導(dǎo)出數(shù)據(jù)庫(kù)用戶信息的方案,每種方案都給出了腳本并進(jìn)行演示。同時(shí) 這三種方案稍加以封裝都可以作為備份數(shù)據(jù)庫(kù)用戶權(quán)限的腳本。可能你還有其他方案,如:pt-show-grants等,歡迎分享出來(lái)哦,也歡迎大家收藏或者改造成更適合自己的腳本,說(shuō)不定什么時(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)文章!

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

標(biāo)簽:鎮(zhèn)江 北京 臺(tái)灣 合肥 阜新 貴州 鷹潭 日照

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL如何優(yōu)雅的備份賬號(hào)相關(guān)信息》,本文關(guān)鍵詞  MySQL,如何,優(yōu)雅,的,備份,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL如何優(yōu)雅的備份賬號(hào)相關(guān)信息》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于MySQL如何優(yōu)雅的備份賬號(hào)相關(guān)信息的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美一区二区大片| 国产成人精品亚洲日本在线桃色| 亚洲v中文字幕| 337p亚洲精品色噜噜狠狠| 男女视频一区二区| 欧美激情一区二区三区不卡| 色综合中文字幕| 久久影院午夜论| 风间由美一区二区av101| 午夜私人影院久久久久| 亚洲天堂2016| 欧美国产日韩一二三区| www日韩大片| 精品欧美一区二区久久| 欧美一区二区三区在线视频| 欧美三级中文字| 欧美日韩在线不卡| 亚洲日本中文字幕区| 色综合一区二区| 99久久婷婷国产| 99久久99久久精品免费看蜜桃| 成人av网址在线观看| 99精品桃花视频在线观看| 成人精品gif动图一区| 五月天网站亚洲| 日韩精品乱码免费| 一色屋精品亚洲香蕉网站| 国产亚洲欧美在线| 国产午夜精品久久久久久久 | 综合久久综合久久| 亚洲第一福利一区| 亚洲成年人网站在线观看| 亚洲一区二区三区不卡国产欧美| 亚洲国产精品人人做人人爽| 亚洲一线二线三线视频| 亚洲成a人片在线不卡一二三区 | 偷拍日韩校园综合在线| 免费人成在线不卡| 国产乱码精品一区二区三区av| 日韩欧美激情一区| 91麻豆国产福利精品| 欧美理论片在线| 精品国产第一区二区三区观看体验| 日韩女优av电影| 国产欧美1区2区3区| 亚洲另类在线一区| 国产91在线看| 久久青草欧美一区二区三区| 视频一区中文字幕| 国产伦精品一区二区三区在线观看| 亚洲国产视频一区二区| 亚洲自拍偷拍网站| 国产成人啪午夜精品网站男同| 九九精品一区二区| 国产精品日日摸夜夜摸av| 国产精品久久久久久久久果冻传媒 | 17c精品麻豆一区二区免费| 一卡二卡三卡日韩欧美| 久久66热re国产| 国产精品卡一卡二| av在线播放成人| 岛国av在线一区| 精品视频在线免费看| 欧美xxxx老人做受| 亚洲一区二区视频在线| 国产成人aaaa| 日韩一级精品视频在线观看| 亚洲同性gay激情无套| 99久久精品国产观看| 欧美曰成人黄网| 欧美国产丝袜视频| 精品一区二区精品| 欧美剧在线免费观看网站| 亚洲色大成网站www久久九九| 亚洲蜜臀av乱码久久精品蜜桃| 欧美日韩精品免费| 欧美亚洲一区二区在线| 美女精品自拍一二三四| 国产精品情趣视频| 欧美一区二区日韩| 韩国一区二区三区| 一区二区高清视频在线观看| 精品成人一区二区| 欧美日韩夫妻久久| 欧美一区三区二区| 国产精品自拍在线| 日韩欧美一二三| 视频一区在线播放| 欧美在线播放高清精品| 99久精品国产| 91成人免费在线| 99久久精品费精品国产一区二区| 免费在线观看不卡| 在线看国产日韩| 久久婷婷国产综合国色天香| 日韩不卡手机在线v区| 色综合天天综合给合国产| 久久色中文字幕| 久久精品国产亚洲5555| 欧美日韩国产精品自在自线| 一区二区在线电影| 色中色一区二区| 亚洲视频网在线直播| 北条麻妃一区二区三区| 国产精品乱码久久久久久| 国产精品亚洲人在线观看| 精品福利一区二区三区免费视频| 视频一区在线视频| 日韩一区二区三区高清免费看看| 亚洲一区二区在线播放相泽| 岛国一区二区三区| 日日夜夜精品视频免费 | 伊人一区二区三区| 色哟哟在线观看一区二区三区| 中文字幕第一区第二区| 成人精品一区二区三区中文字幕| 免费成人在线观看| 亚洲成av人片| 99久久免费国产| 成人开心网精品视频| hitomi一区二区三区精品| 99精品视频中文字幕| 在线看一区二区| 国产精品亚洲一区二区三区妖精| 青青草视频一区| 亚洲欧美日韩国产一区二区三区| 国产一区视频导航| 日本大香伊一区二区三区| 亚洲一区二区三区四区在线免费观看| 欧美色精品在线视频| 日本中文在线一区| 欧美一区二区三区思思人| 国产一区三区三区| 亚洲精品欧美激情| 精品伦理精品一区| 亚洲国产欧美在线| 日本麻豆一区二区三区视频| 亚洲天堂2014| 欧美亚男人的天堂| 男男视频亚洲欧美| 国产欧美一区二区精品忘忧草| 色欧美日韩亚洲| 久久国产麻豆精品| 一区二区三区日韩精品视频| 欧美一个色资源| 色综合网站在线| 国产中文字幕精品| 亚洲国产精品一区二区www| 久久免费精品国产久精品久久久久| 在线中文字幕一区二区| 国产成人午夜视频| 美女视频黄a大片欧美| 亚洲激情男女视频| 欧美国产1区2区| 日韩欧美成人一区二区| 欧美无砖砖区免费| 91美女在线观看| 成人一级片网址| 国产·精品毛片| 国产一区福利在线| 亚洲一区二区三区国产| 色伊人久久综合中文字幕| 国产一区福利在线| 中文字幕在线不卡一区| 99久久久久久| 日本不卡一区二区三区| 欧美成人性战久久| 琪琪久久久久日韩精品| 久久综合一区二区| 91网站黄www| 丝袜美腿一区二区三区| 日韩欧美国产一区二区三区| 6080yy午夜一二三区久久| 国产日韩欧美制服另类| 国产精品乡下勾搭老头1| 中文字幕一区二区三区不卡| 久久久亚洲高清| 日日夜夜精品视频天天综合网| 中文字幕色av一区二区三区| 日本一区二区三区视频视频| 精品成人在线观看| 日韩欧美在线1卡| 欧美一区二区三区成人| 欧美精品在线视频| 在线电影院国产精品| 欧美精品亚洲一区二区在线播放| 在线欧美日韩国产| 欧美性猛片aaaaaaa做受| 欧美性三三影院| 午夜成人免费电影| 亚洲mv大片欧洲mv大片精品| 一区二区三区产品免费精品久久75| 亚洲欧洲精品一区二区三区不卡| 亚洲欧美日韩久久精品| 亚洲激情图片小说视频| 一区二区在线观看视频| 亚洲国产综合91精品麻豆| 一区二区三区资源| 天堂在线一区二区| 久久精工是国产品牌吗|