日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:24日期:2023-10-12 12:06:10

前言:

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

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

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

#只導出mysql庫中的user,db,tables_priv表數據 #如果你有針隊column的賦權 可以再導出columns_priv表數據#若數據庫開啟了GTID 導出時最好加上 --set-gtid-purged=OFFmysqldump -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_native_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_password’,’*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.自定義腳本導出

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

SELECTCONCAT(’create user ’’, user, ’’@’’, Host, ’’’ ’ IDENTIFIED BY PASSWORD ’’, authentication_string,’’;’) AS CreateUserQueryFROMmysql.`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.sqlecho '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=OFFmysqlpump -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.23SET @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 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产亚洲一区| 精品一区视频| 狂野欧美性猛交xxxx| 麻豆久久精品| 91九色精品| 精品一区毛片| 鲁大师精品99久久久| 偷拍亚洲精品| 九九综合在线| 三级在线看中文字幕完整版| 国产精品一区二区三区av麻| 爽好久久久欧美精品| 亚洲深夜福利在线观看| 99国内精品| 好吊一区二区三区| 亚洲专区一区| 亚洲欧美日韩在线观看a三区| 今天的高清视频免费播放成人| 亚洲精品成人| 不卡在线一区二区| 激情婷婷久久| 日韩视频一区二区三区在线播放免费观看 | 精品国产亚洲一区二区在线观看| 欧美日韩一区二区三区在线电影| 日韩免费精品| 成人羞羞视频在线看网址| 丝袜美腿一区| 亚洲天堂久久| 天堂成人国产精品一区| 四虎成人精品一区二区免费网站| 亚洲精品乱码| 青青草精品视频| 红杏一区二区三区| av综合电影网站| 成人午夜在线| 亚洲黄页一区| 久久最新视频| 亚洲精品激情| 欧美激情国产在线| 久久久国产精品一区二区中文| 日本不良网站在线观看| 蜜桃tv一区二区三区| 免费视频久久| 88久久精品| 久久狠狠婷婷| 亚洲精品福利| 国产精品免费精品自在线观看| 欧美黑人巨大videos精品| 亚洲综合电影| 亚洲www免费| 91久久黄色| 国产精品www.| 国产在线不卡一区二区三区| 日韩黄色大片网站| 三级一区在线视频先锋| 亚洲人成网站在线在线观看| 国产日韩在线观看视频| 国产成人精品福利| 国模 一区 二区 三区| 国产精品免费看| 国产精品毛片| 麻豆久久一区二区| 久久国产亚洲精品| 视频在线观看91| 亚洲a级精品| 国产精品白浆| 日韩电影免费网站| 美女久久一区| 久久不见久久见免费视频7| 四虎成人av| 天堂成人免费av电影一区| 精品久久久久中文字幕小说| 日韩视频二区| 欧美精品第一区| 巨乳诱惑日韩免费av| 麻豆久久一区| 亚洲在线国产日韩欧美| 亚洲午夜天堂| 日本不卡中文字幕| 欧美日韩视频免费观看| 少妇高潮一区二区三区99| 国产一区二区三区91| 在线观看亚洲精品福利片| 国产欧美88| 国产一区二区三区自拍| 精品国内亚洲2022精品成人| 91高清一区| 国产精品毛片久久久| xxxxx性欧美特大| 日韩精品一区二区三区中文字幕| 精品国产91| 黑丝一区二区三区| 日韩国产一区二区三区| 日韩影片在线观看| 你懂的国产精品| 日韩在线麻豆| 九九久久婷婷| 国产三级一区| 婷婷久久免费视频| 欧美va天堂在线| 久久国产麻豆精品| 一区二区不卡| 欧美日韩在线网站| 久久精品一区| 欧美日韩91| 国产日韩综合| 日韩精品水蜜桃| 日韩在线综合| 麻豆国产一区| 国产+成+人+亚洲欧洲在线| 亚洲精品一二三**| 99精品视频精品精品视频| 国产精品视频一区二区三区四蜜臂| 最新国产精品视频| 亚洲午夜在线| 六月婷婷综合| 欧洲av不卡| 欧美精品aa| 日本不卡高清| 91欧美日韩在线| 亚洲伊人精品酒店| 欧美另类专区| 激情综合自拍| 亚洲永久av| 久久麻豆视频| 国产一区2区| 国产精品中文字幕亚洲欧美| 久久亚洲二区| 中文无码久久精品| 在线亚洲精品| 精品国产一区二| 国产日韩欧美一区| 中文字幕日韩亚洲| 国产专区一区| 中文字幕在线免费观看视频| 国产亚洲一区二区三区啪| 久久国产88| 尤物在线精品| 欧美日韩国产免费观看视频| 亚洲www啪成人一区二区| 国内精品亚洲| 欧美极品中文字幕| 亚洲色诱最新| 国产日韩一区二区三区在线播放| 亚洲狼人精品一区二区三区| 在线亚洲成人| 日韩国产成人精品| 在线看片福利| 99精品在线观看| 亚洲综合五月| 成人日韩av| 成人日韩在线观看| 亚洲精品成人一区| 91精品综合| 欧美aa在线视频| 欧美一区影院| 鲁大师精品99久久久| 日韩国产欧美在线播放| 亚洲一区av| 免费不卡中文字幕在线| 日韩精品一区二区三区中文在线 | 免费看一区二区三区| 中文一区一区三区免费在线观| 日韩免费福利视频| 欧美粗暴jizz性欧美20| 亚洲午夜久久| 亚洲成人二区| 久久激情中文| 欧美亚洲日本精品| 少妇精品久久久一区二区| 日韩三区四区| 国产一区二区精品福利地址| 精品亚洲免a| 精品一区二区三区在线观看视频| 国产精品精品国产一区二区| 一区二区精品| 欧美资源在线| 免费不卡中文字幕在线| 亚洲在线电影| 国产精品.xx视频.xxtv| 成人看片网站| 亚洲综合另类| 7777精品| 亚洲欧美一区在线| 国产探花一区| 欧美日韩国产传媒| 国产精品xxx在线观看| 性欧美69xoxoxoxo| 国产精品久久久久av蜜臀| 亚洲福利精品| 国产乱码精品一区二区三区四区 | 中国字幕a在线看韩国电影| 免播放器亚洲| 美女av在线免费看| 日韩av一级片| 亚洲二区在线| 精品一二三区| 日韩精品一区二区三区中文 | 成人午夜国产| 国产免费久久|