大多情況下,需要可靠而有效地克隆 MySQL 實(shí)例數(shù)據(jù)。這包括 MySQL 高可用的解決方案,其中需要在將實(shí)例加入組復(fù)制集群之前配置實(shí)例,或者在經(jīng)典復(fù)制模型中將其添加為 Slave。
成都創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括汝陽網(wǎng)站建設(shè)、汝陽網(wǎng)站制作、汝陽網(wǎng)頁制作以及汝陽網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,汝陽網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到汝陽省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
為復(fù)制拓?fù)涠鴦?chuàng)建 MySQL 副本一直很麻煩。涉及的步驟很多,首先要備份 MySQL 服務(wù)器,通過網(wǎng)絡(luò)將備份傳輸?shù)轿覀兿胍砑拥綇?fù)制集的新 MySQL 節(jié)點(diǎn),然后在該節(jié)點(diǎn)上恢復(fù)備份并手動(dòng)啟動(dòng) MySQL 服務(wù)器。為了高可用,最好還要將其正確設(shè)置備份的 GTID,并啟動(dòng)并運(yùn)行群集。涉及的手動(dòng)步驟數(shù)量過多不利于高可用。CLONE 插件解決了這個(gè)問題并簡化了副本配置。使您可以使用 MySQL 客戶端(和 SQL 命令)來配置新節(jié)點(diǎn)并在發(fā)生時(shí)觀察克隆進(jìn)度。無需手動(dòng)處理多個(gè)步驟并維護(hù)自己的基礎(chǔ)架構(gòu)來配置新的 MySQL 節(jié)點(diǎn)。
MySQL 8.0.17 引入了 CLONE SQL 語句,使當(dāng)前的 MySQL 服務(wù)器成為另一個(gè)運(yùn)行在不同節(jié)點(diǎn)的 MySQL 服務(wù)器的“克隆”。我們將執(zhí)行 clone 語句的服務(wù)器實(shí)例稱為“受體”??寺〉脑捶?wù)器實(shí)例稱為“供體”。供體克隆以一致的快照存儲(chǔ)在 InnoDB 存儲(chǔ)引擎中的所有數(shù)據(jù)和元數(shù)據(jù),以替換受體中的數(shù)據(jù)。
成功執(zhí)行 CLONE SQL 語句后,將自動(dòng)重新啟動(dòng)受體服務(wù)器。重新啟動(dòng)涉及恢復(fù)克隆的快照數(shù)據(jù),就像用老方法復(fù)制數(shù)據(jù)一樣?;謴?fù)完成后,受體就是供體的克隆版,隨時(shí)可以使用!
這里有一些關(guān)于克隆過程的重要注意事項(xiàng)。
不克隆 MySQL 配置參數(shù),并且受體保留所有原始配置參數(shù),如克隆之前。這樣做是因?yàn)樵S多配置可能特定于節(jié)點(diǎn)(例如 PORT),因此保留它們似乎是一個(gè)不錯(cuò)的選擇。另一方面,一些存儲(chǔ)配置確實(shí)需要在供體和受體之間匹配(例如 innodbpagesize),如果這樣的配置參數(shù)不匹配,CLONE 將報(bào)告錯(cuò)誤。
CLONE?插件不會(huì)克隆二進(jìn)制日志。
CLONE?插件目前僅支持 InnoDB 存儲(chǔ)引擎。在其他存儲(chǔ)引擎(如 MyISAM 和 CSV)中創(chuàng)建的表將被克隆為空表??寺』A(chǔ)架構(gòu)的設(shè)計(jì)允許克隆 MySQL 支持的任何存儲(chǔ)引擎。但是,只有 InnoDB 序列化和反序列化方法已經(jīng)實(shí)現(xiàn)并經(jīng)過測試。
克隆會(huì)阻止供體中的所有并發(fā) DDL。
需要注意的事實(shí)是受體放棄所有數(shù)據(jù)以及任何二進(jìn)制日志,以便成為供體實(shí)例的克隆。在執(zhí)行 CLONE 之前,如果認(rèn)為有必要,需要備份當(dāng)前受體數(shù)據(jù)。
mysql的多實(shí)例有兩種方式可以實(shí)現(xiàn),兩種方式各有利弊。第一種是使用多個(gè)配置文件啟動(dòng)不同的進(jìn)程來實(shí)現(xiàn)多實(shí)例,這種方式的優(yōu)勢邏輯簡單,配置簡單,缺點(diǎn)是管理起來不太方便。第二種是通過官方自帶的mysqld_multi使用單獨(dú)的配置文件來實(shí)現(xiàn)多實(shí)例,這種方式定制每個(gè)實(shí)例的配置不太方面,優(yōu)點(diǎn)是管理起來很方便,集中管理。
//這是我以前寫的核對數(shù)據(jù)庫實(shí)現(xiàn)登陸的方法,你只看jdbc部分就好,我還特地給你加了點(diǎn)注釋\x0d\x0aString sql = "select username,password from account";\x0d\x0aString user = request.getParameter("user");\x0d\x0aString pass = request.getParameter("password");\x0d\x0aint j = 0;\x0d\x0aConnection conn = null;\x0d\x0aPreparedStatement ps = null;\x0d\x0aResultSet rs = null;\x0d\x0atry {\x0d\x0aconn = JDBCTools1.getConnection();\x0d\x0aps = conn.prepareStatement(sql);\x0d\x0ars = ps.executeQuery();\x0d\x0a//從表中查詢獲取所有賬戶的用戶名密碼的ResultSet 對象\x0d\x0awhile(rs.next()){\x0d\x0aint i = 0;\x0d\x0a\x0d\x0aString username[] = new String[10];//用戶名數(shù)組\x0d\x0aString password[] = new String[10];//密碼數(shù)組\x0d\x0ausername[i] = rs.getString(1);\x0d\x0apassword[i] = rs.getString(2);\x0d\x0aif(user.equals(username[i])pass.equals(password[i])){//比對\x0d\x0aresponse.getWriter().print("you are welcome!");\x0d\x0aj++;\x0d\x0a}else if(user.equals(username[i])!pass.equals(password[i])){\x0d\x0aresponse.getWriter().println("the realy password is :"+ username[i] +","+password[i]+"\r\n");\x0d\x0aresponse.getWriter().println("and you password is :"+user +","+pass+" :so the username or password may not right");\x0d\x0aj++;\x0d\x0a}else{\x0d\x0acontinue;\x0d\x0a}\x0d\x0ai++;\x0d\x0a}\x0d\x0aif(j == 0){\x0d\x0aresponse.getWriter().println("Your username may not be properly");\x0d\x0a}\x0d\x0a} catch (Exception e) {\x0d\x0ae.printStackTrace();\x0d\x0a}finally{\x0d\x0aJDBCTools1.release(rs, ps, conn);\x0d\x0a}\x0d\x0a//這是我JDBCTools的getConnection方法\x0d\x0agetConnection{\x0d\x0aString driverClass = oracle.jdbc.driver.OracleDriver;\x0d\x0aString jdbcUrl = jdbc:oracle:thin:@localhost:1521:orcl;\x0d\x0a//你的數(shù)據(jù)庫的用戶名密碼\x0d\x0aString user = null;\x0d\x0aString password = null;\x0d\x0a// 通過反射創(chuàng)建Driver對象\x0d\x0aClass.forName(driverClass);\x0d\x0areturn DriverManager.getConnection(jdbcUrl, user, password);}\x0d\x0a//這是我JDBCTools的release方法\x0d\x0apublic static void release(ResultSet rs, Statement statement,\x0d\x0aConnection conn) {\x0d\x0aif (rs != null) {\x0d\x0atry {\x0d\x0ars.close();\x0d\x0a} catch (SQLException e) {\x0d\x0ae.printStackTrace();\x0d\x0a}\x0d\x0a}\x0d\x0a\x0d\x0aif (statement != null) {\x0d\x0atry {\x0d\x0astatement.close();\x0d\x0a} catch (Exception e2) {\x0d\x0ae2.printStackTrace();\x0d\x0a}\x0d\x0a}\x0d\x0a\x0d\x0aif (conn != null) {\x0d\x0atry {\x0d\x0aconn.close();\x0d\x0a} catch (Exception e2) {\x0d\x0ae2.printStackTrace();\x0d\x0a}\x0d\x0a}\x0d\x0a}
我的mysql裝在linux上,今天也出現(xiàn)了這種問題,報(bào)的錯(cuò)為:
ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement
linux下需要找到my.cnf文件,看配置中是否有skip-grant-tables 這一行,需要注釋掉。然后進(jìn)入命令行輸入:set global event_scheduler =on;或者set global event_scheduler =1;都可以。
Windows下的話應(yīng)該是需要找到my.ini文件,之后的操作和上面一樣。
至于skip-grant-tables的意思,百度吧。里面有詳細(xì)的講解。
skip-grant-tables作用是跳過驗(yàn)證,有了這個(gè)其實(shí)你可以把之前的忘記的密碼修改掉。 步驟
1、在命令窗登錄mysql。切換庫為mysql庫。
2、update user set password=PASSWORD('newpswd')WHERE user='root';
3、flush privileges;
4、退出命令窗重啟mysql服務(wù),在使用修改時(shí)候的密碼登錄一下看看
如果成功登錄,應(yīng)該就可以設(shè)置event事件任務(wù)了
這種架構(gòu)一般用在以下三類場景
1. 備份多臺(tái) Server 的數(shù)據(jù)到一臺(tái)如果按照數(shù)據(jù)切分方向來講,那就是垂直切分。比如圖 2,業(yè)務(wù) A、B、C、D 是之前拆分好的業(yè)務(wù),現(xiàn)在需要把這些拆分好的業(yè)務(wù)匯總起來備份,那這種需求也很適用于多源復(fù)制架構(gòu)。實(shí)現(xiàn)方法我大概描述下:業(yè)務(wù) A、B、C、D 分別位于 4 臺(tái) Server,每臺(tái) Server 分別有一個(gè)數(shù)據(jù)庫來隔離前端的業(yè)務(wù)數(shù)據(jù),那這樣,在從庫就能把四臺(tái)業(yè)務(wù)的數(shù)據(jù)全部匯總起來,而不需要做額外的操作。那沒有多源復(fù)制之前,要實(shí)現(xiàn)這類需求,只能在匯總機(jī)器上搭建多個(gè) MySQL 實(shí)例,那這樣勢必會(huì)涉及到跨庫關(guān)聯(lián)的問題,不但性能急劇下降,管理多個(gè)實(shí)例也沒有單臺(tái)來的容易。
2. 用來聚合前端多個(gè) Server 的分片數(shù)據(jù)。
同樣,按照數(shù)據(jù)切分方向來講,屬于水平切分。比如圖 3,按照年份拆分好的數(shù)據(jù),要做一個(gè)匯總數(shù)據(jù)展現(xiàn),那這種架構(gòu)也非常合適。實(shí)現(xiàn)方法稍微復(fù)雜些:比如所有 Server 共享同一數(shù)據(jù)庫和表,一般為了開發(fā)極端透明,前端配置有分庫分表的中間件,比如愛可生的 DBLE。
3. 匯總并合并多個(gè) Server 的數(shù)據(jù)
第三類和第一種場景類似。不一樣的是不僅僅是數(shù)據(jù)需要匯總到目標(biāo)端,還得合并這些數(shù)據(jù),這就比第一種來的相對復(fù)雜些。比如圖 4,那這樣的需求,是不是也適合多源復(fù)制呢?答案是 YES。那具體怎么做呢?
MySQL 8.0.27 增加了多因素身份認(rèn)證(MFA)功能,可以為一個(gè)用戶指定多重的身份校驗(yàn)。為此還引入了新的系統(tǒng)變量 authentication_policy ,用于管理多因素身份認(rèn)證功能。
我們知道在 MySQL 8.0.27 之前,create user 的時(shí)候可以指定一種認(rèn)證插件,在未明確指定的情況下會(huì)取系統(tǒng)變量 default_authentication_plugin的值。default_authentication_plugin 的有效值有3個(gè),分別是 mysql_native_password ,sha256_password ,caching_sha2_password ,這個(gè)3個(gè)認(rèn)證插件是內(nèi)置的、不需要注冊步驟的插件。
在 MySQL 8.0.27 中由 authentication_policy 來管理用戶的身份認(rèn)證,先啟個(gè) mysql
同時(shí)查看下 authentication_policy 和 default_authentication_plugin 的值
我們看到 authentication_policy 的默認(rèn)值是*,,
第1個(gè)元素值是星號(hào)( ),表示可以是任意插件,默認(rèn)值取 default_authentication_plugin 的值。如果該元素值不是星號(hào)( ),則必須設(shè)置為 mysql_native_password ,sha256_password ,caching_sha2_password 中的一個(gè)。
第2,3個(gè)元素值為空,這兩個(gè)位置不能設(shè)置成內(nèi)部存儲(chǔ)的插件。如果元素值為空,代表插件是可選的。
建個(gè)用戶看一下,不指定插件名稱時(shí),自動(dòng)使用默認(rèn)插件 caching_sha2_password
指定插件名稱時(shí),會(huì)使用到對應(yīng)的插件
嘗試變更一下 authentication_policy 第一個(gè)元素的值,設(shè)置為 sha256_password
再次創(chuàng)建一個(gè)用戶,不指定插件的名稱
可以看到默認(rèn)使用的插件是 sha256_password ,說明當(dāng) authentication_policy 第一個(gè)元素指定插件名稱時(shí),default_authentication_plugin 被棄用了。
首先我們恢復(fù) authentication_policy 至默認(rèn)值
創(chuàng)建一個(gè)雙重認(rèn)證的用戶。如下創(chuàng)建失敗了,因?yàn)椴豢梢酝瑫r(shí)用2種內(nèi)部存儲(chǔ)插件。
那我們來裝一個(gè)可插拔插件 Socket Peer-Credential
再創(chuàng)建一個(gè)雙重認(rèn)證的用戶
創(chuàng)建成功,之后用戶'wei4'@'localhost'必須提供正確的密碼,且同時(shí)本地主機(jī)的登錄用戶為 root 時(shí),才會(huì)驗(yàn)證通過。
來試一下,以主機(jī) root 用戶身份,提供正確的密碼 123 ,登錄成功。
修改一下,將'wei4'@'localhost'要求的主機(jī)登錄用戶修改為wei4
再次以主機(jī) root 用戶身份,提供正確的密碼 123 ,登錄失敗
因此可以認(rèn)定雙重身份認(rèn)證機(jī)制是生效的。MySQL 8.0.27 最多可以對一個(gè)用戶設(shè)置三重的身份認(rèn)證,這里不再做展示說明。
簡單總結(jié)下,已有的密碼口令身份驗(yàn)證很適合網(wǎng)站或者應(yīng)用程序的訪問,但是在特定的情況下 如網(wǎng)絡(luò)在線金融交易方面可能還是不夠安全。多因素身份認(rèn)證(MFA)功能的引入,可以在一定程度上提升數(shù)據(jù)庫系統(tǒng)的安全性。