Mysql存儲程序、函數、觸發程序及復制:常見問題

mysql 5.1存儲程序和函數對復制起作用嗎?
是的,在存儲程序和函數中被執行標準行為被從主mysql服務器復制到從服務器。有少數限制,它們在20.4節,“存儲子程序和 觸發程序二進制日志功能”中詳述。
在主服務器上創建的存儲程序和函數可以被復制到從服務器上么?
是的,通過一般ddl語句執行的存儲程序和函數,其在主服務器上的創建被復制到從服務器,所以目標將存在兩個服務器上。對存儲程序和函數的alter 和drop語句也被復制。
行為如何在已復制的存儲程序和函數里發生?
mysql紀錄每個發生在存儲程序和函數里的dml事件,并復制這些單獨的行為到從服務器。執行存儲程序和函數的切實調用不被復制。
對一起使用存儲程序,函數和復制有什么特別的安全要求么?
是的,因為一個從服務器有權限來執行任何讀自主服務器的二進制日志的語句,指定的安全約束因與復制一起使用的存儲程序和函數而存在。如果復制或二進制日志大體上是激活的(為point-in-time恢復的目的),那么mysql dba 有兩個安全選項可選:
任何想創建存儲程序的用戶必須被賦予super權限。
作為選擇,一個dba可以設置log_bin_trust_routine_creators系統變量為1,它將會允許有標準create routine權限的人來創建一個存儲程序和函數。
?
對復制存儲程序和函數的行為有什么限制?
嵌入到存儲程序中的不確定(隨機)或時基行不能適當地復制。隨機產生的結果,僅因其本性,是你可預測的和不能被確實克隆的。因此,復制到從服務器的隨機行為將不會鏡像那些產生在主服務器上的。注意, 聲明存儲程序或函數為deterministic或者在log_bin_trust_routine_creators中設置系統變量為0 將會允許隨即值操作被調用。
此外,時基行為不能在從服務器上重新產生,因為在存儲程序中通過對復制使用的二進制日志來計時這樣的時基行為是不可重新產生的,因為該二進制日志僅紀錄dml事件且不包括計時約束。
最后,在大型dml行為(如大批插入)中非交互表發生錯誤,該非交互表可能經歷復制,在復制版的非交互表中主服務器可以被部分地從dml行為更新。但是因為發生的那個錯誤,對從服務器沒有更新。 對函數的dml行為,工作區將被用ignore關鍵詞來執行,以便于在主服務器上導致錯誤的更新被忽略,并且不會導致錯誤的更新被復制到從服務器。
?
上述的限制會影響mysql作 point-in-time恢復的能力嗎?
影響復制的同一限制會影響point-in-time恢復。
?mysql要做什么來改正前述的限制呢?
將來發行的mysql預期有一個功能去選擇復制該如何被處理:
?基于語句的復制(當前實現)。
行級別復制(它將解決所有早先描述的限制)。
觸發程序對復制起作用么?
mysql 5.1中的觸發程序和復制象在大多數其它數據庫引擎中一樣工作,在那些引擎中,通過觸發程序在主服務器上執行的行為不被復制到從服務器。取而代之的是,位于主mysql服務器的表中的 觸發程序需要在那些存在于任何mysql從服務器上的表內被創建,以便于觸發程序可以也可以在從服務器上被激活。
?
?一個行為如何通過從主服務器上復制到從服務器上的觸發程序來執行呢?
首先,主服務器上的觸發程序必須在從服務器上重建。一旦重建了,復制流程就象其它參與到復制中的標準dml語句一樣工作。例如:考慮一個已經插入觸發程序after的emp表,它位于主mysql服務器上。同樣的emp表和after插入 觸發程序也存在于從服務器上。復制流程可能是:
1.??? 對emp做一個insert語句。
2.?? emp上的after觸發程序激活。
3.??? insert語句被寫進二進制日志。
4.??? 從服務器上的復制拾起insert語句給emp表,并在從服務器上執行它。
5.??? 位于從服務器emp上的after觸發程序激活。

? 版權聲明
THE END
喜歡就支持一下吧
點贊7 分享