項(xiàng)目上 MySQL?還原 SQL 備份經(jīng)常會(huì)碰到一個(gè)錯(cuò)誤如下,且通常出現(xiàn)在導(dǎo)入視圖、函數(shù)、存儲(chǔ)過(guò)程、事件等對(duì)象時(shí),其根本原因就是因?yàn)閷?dǎo)入時(shí)所用賬號(hào)并不具有SUPER 權(quán)限,所以無(wú)法創(chuàng)建其他賬號(hào)的所屬對(duì)象。ERROR 1227 (42000) : Access denied; you need (at least one of) the SUPER privilege(s) for this operation常見(jiàn)場(chǎng)景:1. 還原 RDS 時(shí)經(jīng)常出現(xiàn),因?yàn)?RDS 不提供 SUPER 權(quán)限;2. 由開(kāi)發(fā)庫(kù)還原到項(xiàng)目現(xiàn)場(chǎng),賬號(hào)權(quán)限等有所不同。
公司主營(yíng)業(yè)務(wù):成都網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)建站是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。創(chuàng)新互聯(lián)建站推出東方免費(fèi)做網(wǎng)站回饋大家。
處理方式:
1. 在原庫(kù)中批量修改對(duì)象所有者為導(dǎo)入賬號(hào)或修改?SQL SECURITY?為?Invoker;2. 使用 mysqldump 導(dǎo)出備份,然后將 SQL 文件中的對(duì)象所有者替換為導(dǎo)入賬號(hào)。
二、問(wèn)題原因我們先來(lái)看下為啥會(huì)出現(xiàn)這個(gè)報(bào)錯(cuò),那就得說(shuō)下 MySQL 中一個(gè)很特別的權(quán)限控制機(jī)制,像視圖、函數(shù)、存儲(chǔ)過(guò)程、觸發(fā)器等這些數(shù)據(jù)對(duì)象會(huì)存在一個(gè)?DEFINER?和一個(gè)?SQL SECURITY?的屬性,如下所示:
--視圖定義CREATE?ALGORITHM?=?UNDEFINED?DEFINER?=?`root`@`%`?SQL?SECURITY?DEFINER?VIEW?v_test
--函數(shù)定義CREATE?DEFINER=`root`@`%`?FUNCTION?`f_test()`?RETURNS?varchar(100)?SQL?SECURITY?DEFINER
--存儲(chǔ)過(guò)程定義CREATE?DEFINER=`root`@`%`?PROCEDURE?`p_test`()?SQL?SECURITY?DEFINER
--觸發(fā)器定義CREATE DEFINER=`root`@`%` trigger t_test
--事件定義CREATE DEFINER=`root`@`%` EVENT `e_test`
DEFINER:對(duì)象定義者,在創(chuàng)建對(duì)象時(shí)可以手動(dòng)指定用戶,不指定的話默認(rèn)為當(dāng)前連接用戶;
SQL SECURITY:指明以誰(shuí)的權(quán)限來(lái)執(zhí)行該對(duì)象,有兩個(gè)選項(xiàng),一個(gè)為?DEFINER,一個(gè)為?INVOKER,默認(rèn)情況下系統(tǒng)指定為 DEFINER;DEFINER:表示按定義者的權(quán)限來(lái)執(zhí)行;?INVOKER:表示按調(diào)用者的權(quán)限來(lái)執(zhí)行。
如果導(dǎo)入賬號(hào)具有 SUPER 權(quán)限,即使對(duì)象的所有者賬號(hào)不存在,也可以導(dǎo)入成功,但是在查詢對(duì)象時(shí),如果對(duì)象的?SQL SECURITY?為?DEFINER,則會(huì)報(bào)賬號(hào)不存在的報(bào)錯(cuò)。ERROR 1449 (HY000): The user specified as a definer ('root'@'%') does not exist
改寫好處:1. 可以避免還原時(shí)遇到 DEFINER 報(bào)錯(cuò)相關(guān)問(wèn)題;2. 根據(jù)輸出信息知道備份是否正常進(jìn)行,防止備份中遇到元數(shù)據(jù)鎖無(wú)法獲取然后一直卡住的情況。
我google了一下大概有一下幾個(gè)方法,
1.復(fù)制表結(jié)構(gòu)及數(shù)據(jù)到新表
CREATE TABLE 新表 SELECT * FROM 舊表
2.只復(fù)制表結(jié)構(gòu)到新表
CREATE TABLE 新表 SELECT * FROM 舊表 WHERE 1=2
即:讓W(xué)HERE條件不成立.
3.復(fù)制舊表的數(shù)據(jù)到新表(假設(shè)兩個(gè)表結(jié)構(gòu)一樣)
INSERT INTO 新表 SELECT * FROM 舊表
4.復(fù)制舊表的數(shù)據(jù)到新表(假設(shè)兩個(gè)表結(jié)構(gòu)不一樣)
INSERT INTO 新表(字段1,字段2,.......) SELECT 字段1,字段2,...... FROM 舊表
這種架構(gòu)一般用在以下三類場(chǎng)景
1. 備份多臺(tái) Server 的數(shù)據(jù)到一臺(tái)如果按照數(shù)據(jù)切分方向來(lái)講,那就是垂直切分。比如圖 2,業(yè)務(wù) A、B、C、D 是之前拆分好的業(yè)務(wù),現(xiàn)在需要把這些拆分好的業(yè)務(wù)匯總起來(lái)備份,那這種需求也很適用于多源復(fù)制架構(gòu)。實(shí)現(xiàn)方法我大概描述下:業(yè)務(wù) A、B、C、D 分別位于 4 臺(tái) Server,每臺(tái) Server 分別有一個(gè)數(shù)據(jù)庫(kù)來(lái)隔離前端的業(yè)務(wù)數(shù)據(jù),那這樣,在從庫(kù)就能把四臺(tái)業(yè)務(wù)的數(shù)據(jù)全部匯總起來(lái),而不需要做額外的操作。那沒(méi)有多源復(fù)制之前,要實(shí)現(xiàn)這類需求,只能在匯總機(jī)器上搭建多個(gè) MySQL 實(shí)例,那這樣勢(shì)必會(huì)涉及到跨庫(kù)關(guān)聯(lián)的問(wèn)題,不但性能急劇下降,管理多個(gè)實(shí)例也沒(méi)有單臺(tái)來(lái)的容易。
2. 用來(lái)聚合前端多個(gè) Server 的分片數(shù)據(jù)。
同樣,按照數(shù)據(jù)切分方向來(lái)講,屬于水平切分。比如圖 3,按照年份拆分好的數(shù)據(jù),要做一個(gè)匯總數(shù)據(jù)展現(xiàn),那這種架構(gòu)也非常合適。實(shí)現(xiàn)方法稍微復(fù)雜些:比如所有 Server 共享同一數(shù)據(jù)庫(kù)和表,一般為了開(kāi)發(fā)極端透明,前端配置有分庫(kù)分表的中間件,比如愛(ài)可生的 DBLE。
3. 匯總并合并多個(gè) Server 的數(shù)據(jù)
第三類和第一種場(chǎng)景類似。不一樣的是不僅僅是數(shù)據(jù)需要匯總到目標(biāo)端,還得合并這些數(shù)據(jù),這就比第一種來(lái)的相對(duì)復(fù)雜些。比如圖 4,那這樣的需求,是不是也適合多源復(fù)制呢?答案是 YES。那具體怎么做呢?
流程如下:
1. 主:binlog線程——記錄下所有改變了數(shù)據(jù)庫(kù)數(shù)據(jù)的語(yǔ)句,放進(jìn)master上的binlog中;
2. 從:io線程——在使用start slave 之后,負(fù)責(zé)從master上拉取 binlog 內(nèi)容,放進(jìn)自己的relay log中;
3. 從:sql執(zhí)行線程——執(zhí)行relay log中的語(yǔ)句;
這是黑馬程序員講師的講義,你可以動(dòng)手操作一下下。
當(dāng)前名稱:mysql是怎么復(fù)制的 mysql如何復(fù)制粘貼
網(wǎng)頁(yè)地址:http://jinyejixie.com/article36/hepjpg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、搜索引擎優(yōu)化、微信小程序、網(wǎng)頁(yè)設(shè)計(jì)公司、網(wǎng)站設(shè)計(jì)、品牌網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)