mysql集群的研究與實(shí)現(xiàn)課程設(shè)計(jì)_第1頁
已閱讀1頁,還剩25頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、<p>  《MySQL數(shù)據(jù)庫管理》課程設(shè)計(jì)報告</p><p>  題目:MySQL集群的研究與實(shí)現(xiàn)</p><p>  完成日期: 2012 年 12 月 31 日</p><p><b>  目 錄</b></p><p>  1. 課程設(shè)計(jì)題目概述3</p><p>  2

2、. 研究內(nèi)容與目的3</p><p><b>  3. 研究方法4</b></p><p>  3.1研究方法……………………………………………………………………….. 4</p><p>  3.2實(shí)驗(yàn)方法………………………………………………………………………… 5</p><p>  3.3可行性分析..…………

3、………………………………………………………………..... 5</p><p>  4. 研究報告10</p><p>  4.1規(guī)劃階段………………………………………………………………………… 10</p><p>  4.2安裝Mysql server……………………………………………………………… 10</p><p>  4.3安

4、裝Mysql Cluster……………………………………………………………. 11</p><p>  4.4配置管理節(jié)點(diǎn)…………………………………………………………………… 11</p><p>  4.5配置SQL節(jié)點(diǎn)…………………………………………………………………….13</p><p>  4.6 配置存儲節(jié)點(diǎn)……………………………………………………………

5、………13</p><p>  4.7啟動MySQL Cluster…………………………………………………………….13 </p><p>  4.8關(guān)閉MySQL Cluster……………………………………………………………..14</p><p>  4.9數(shù)據(jù)測試………………………………………………………………………… 14</p><p&

6、gt;  4.10安全關(guān)閉………………………………………………………………………. 14</p><p>  5. 測試報告/實(shí)驗(yàn)報告………………………………………………………………...15</p><p>  6. 課題研究結(jié)論……………………………………………………………………....22</p><p>  7. 總結(jié)……………………………………………………

7、……………………………. 23</p><p>  1.課程設(shè)計(jì)題目概述</p><p>  MySQL Cluster 是一種技術(shù),該技術(shù)允許在無共享的系統(tǒng)中部署“內(nèi)存中”數(shù)據(jù)庫的 Cluster 。通過無共享體系結(jié)構(gòu),系統(tǒng)能夠使用廉價的硬件,而且對軟硬件無特殊要求。此外,由于每個組件有自己的內(nèi)存和磁盤,不存在單點(diǎn)故障。</p><p>  MySQL Clust

8、er 由一組計(jì)算機(jī)構(gòu)成,每臺計(jì)算機(jī)上均運(yùn)行著多種進(jìn)程,包括MySQL服務(wù)器,NDB Cluster 的數(shù)據(jù)節(jié)點(diǎn),管理服務(wù)器,以及(可能)專門的數(shù)據(jù)訪問程序。</p><p>  MySQL Cluster 是MySQL適合于分布式計(jì)算環(huán)境的高實(shí)用、高冗余版本。MySQL Cluster 能夠使用多種故障切換和負(fù)載平衡選項(xiàng)配置NDB存儲引擎,但在 Cluster 級別上的存儲引擎上做這個最簡單。MySQL Clus

9、ter的NDB存儲引擎包含完整的數(shù)據(jù)集,僅取決于 Cluster本身內(nèi)的其他數(shù)據(jù)。</p><p>  目前,MySQL Cluster的 Cluster部分可獨(dú)立于MySQL服務(wù)器進(jìn)行配置。在MySQL Cluster中, Cluster的每個部分被視為1個節(jié)點(diǎn)。</p><p>  【關(guān)鍵字】:集群 MySQL Cluster </p><p>  2. 研究內(nèi)

10、容與目的</p><p><b>  研究目的:</b></p><p>  伴隨著企業(yè)的成長,在業(yè)務(wù)量提高的同時,系統(tǒng)的訪問量和數(shù)據(jù)流量的快速增長,其處理能力和計(jì)算強(qiáng)度也相應(yīng)增大,使得單一設(shè)備根本無法承擔(dān)。在此情況下,如果扔掉現(xiàn)有設(shè)備去做大量的硬件升級,這樣將造成現(xiàn)有資源的浪費(fèi),而且如果再面臨下一次業(yè)務(wù)量的提升,這又將導(dǎo)致再一次硬件升級的高額成本投入,甚至性能再卓越

11、的設(shè)備也不能滿足當(dāng)前業(yè)務(wù)量的需求。于是,人們希望通過幾個中小型服務(wù)器組建集群,實(shí)現(xiàn)數(shù)據(jù)庫的負(fù)載均衡,在需要更高數(shù)據(jù)庫處理速度,我們只要簡單地增加數(shù)據(jù)庫服務(wù)器就可以得到擴(kuò)展。</p><p>  數(shù)據(jù)庫作為應(yīng)用系統(tǒng)的核心,在企業(yè)的IT系統(tǒng)中起著非常重要的作用,單一設(shè)備根本無法保證系統(tǒng)的持續(xù)運(yùn)行,發(fā)生系統(tǒng)故障,嚴(yán)重影響系統(tǒng)的正常運(yùn)行,甚至帶來巨大的經(jīng)濟(jì)損失。于是人們希望通過組建數(shù)據(jù)庫集群,來保證系統(tǒng)的可用性,一旦某節(jié)

12、點(diǎn)發(fā)生故障,系統(tǒng)會自動故障轉(zhuǎn)移,實(shí)現(xiàn)系統(tǒng)的持續(xù)工作。</p><p>  企業(yè)的數(shù)據(jù)是企業(yè)的一些重要信息,一些核心數(shù)據(jù)甚至關(guān)系著企業(yè)的命脈,單一設(shè)備根本無法保證數(shù)據(jù)的安全性,一旦發(fā)生丟失,很難再找回來,于是人們希望通過組建數(shù)據(jù)庫集群,實(shí)現(xiàn)數(shù)據(jù)集群的冗余,通過多份數(shù)據(jù)來保證安全性。</p><p>  MySql是一種在目前被廣泛使用著開源的免費(fèi)的數(shù)據(jù)庫,在中小型數(shù)據(jù)應(yīng)用中,一般單臺MySq

13、l服務(wù)器就能滿足要求了,但對于大型WEB或其他應(yīng)用下,巨量的數(shù)據(jù)存儲訪問,單臺MySql服務(wù)器就不能很好地勝任了,而要使多臺MySql服務(wù)器協(xié)同工作,不但要考慮MySql服務(wù)器集群結(jié)構(gòu),要考慮MySql服務(wù)器的HA熱備問題,還要考慮各服務(wù)器之間負(fù)載均衡問題。</p><p><b>  研究內(nèi)容:</b></p><p>  隨著計(jì)算機(jī)應(yīng)用的普及,數(shù)據(jù)庫已經(jīng)成為構(gòu)建電

14、子商務(wù)的關(guān)鍵服務(wù)之一。雖然集群技術(shù)很好地解決了提高訪問容量的問題(如c009le等搜索門戶網(wǎng)站),但數(shù)據(jù)庫卻成為網(wǎng)站的瓶頸,因?yàn)闉榱吮苊鈹?shù)據(jù)一致性問題,網(wǎng)站多采用單一的數(shù)據(jù)庫服務(wù)器為所有網(wǎng)頁服務(wù)提供數(shù)據(jù),當(dāng)訪問量提高時,單個數(shù)據(jù)庫服務(wù)器往往不堪重負(fù)。即使按照過去最優(yōu)配置建設(shè)的服務(wù)器系統(tǒng)可能也無法承擔(dān)訪問量的爆炸性增長。因此,需要創(chuàng)建具有良好可擴(kuò)展性和卓越性能價格比的網(wǎng)絡(luò)數(shù)據(jù)庫服務(wù)器,以滿足快速增長的訪問量和數(shù)據(jù)流量需求。</p&g

15、t;<p>  這就需要使用特定的連接方式,將價格相對較低的硬件設(shè)備結(jié)合起來,同時也能提供高性能相當(dāng)?shù)娜蝿?wù)處理能力,即數(shù)據(jù)庫集群。</p><p>  采用Linux系統(tǒng),可以提高客戶工作站運(yùn)行的可靠性和穩(wěn)定性,獲得高可用性服務(wù)器。在Linux系統(tǒng)下一種雙機(jī)互備份工作方式的MySQL數(shù)據(jù)庫集群的具體實(shí)現(xiàn)方案,實(shí)現(xiàn)了高可用性集群服務(wù)器。兩個相對獨(dú)立的應(yīng)用在兩臺機(jī)器同時運(yùn)行,但彼此均設(shè)為備份機(jī),當(dāng)某一臺

16、服務(wù)器出現(xiàn)故障時,另一臺服務(wù)器可以在短時間內(nèi)將故障服務(wù)器的應(yīng)用接管過來,從而保證了應(yīng)用的持續(xù)性。</p><p><b>  3. 研究方法</b></p><p><b>  3.1研究方法</b></p><p><b>  實(shí)驗(yàn)法</b></p><p><b>

17、;  3.2實(shí)驗(yàn)方法</b></p><p> ?。?)先使用三臺主機(jī)搭建一個集群,分別作為管理節(jié)點(diǎn)、數(shù)據(jù)節(jié)點(diǎn)、SQL節(jié)點(diǎn)</p><p>  <1> 在主節(jié)點(diǎn)上創(chuàng)建數(shù)據(jù)庫、新建數(shù)據(jù)表、插入數(shù)據(jù)</p><p>  <2> 在非主節(jié)點(diǎn)上查看主節(jié)點(diǎn)數(shù)據(jù)更新情況</p><p>  <3> 在非主節(jié)

18、點(diǎn)上上創(chuàng)建數(shù)據(jù)庫、新建數(shù)據(jù)表、插入數(shù)據(jù)</p><p>  <4> 在主節(jié)點(diǎn)上查看非主節(jié)點(diǎn)數(shù)據(jù)更新情況</p><p>  (2)使用三臺主機(jī)搭建一個集群,其中一臺作為管理節(jié)點(diǎn),另兩臺分別作為數(shù)據(jù)節(jié)點(diǎn)和SQL節(jié)點(diǎn)</p><p>  <1> 在主節(jié)點(diǎn)上創(chuàng)建數(shù)據(jù)庫、新建數(shù)據(jù)表、插入數(shù)據(jù)</p><p>  <2&g

19、t; 在非主節(jié)點(diǎn)上查看主節(jié)點(diǎn)數(shù)據(jù)更新情況</p><p>  <3> 在非主節(jié)點(diǎn)上上創(chuàng)建數(shù)據(jù)庫、新建數(shù)據(jù)表、插入數(shù)據(jù)</p><p>  <4> 在主節(jié)點(diǎn)上查看非主節(jié)點(diǎn)數(shù)據(jù)更新情況</p><p><b>  3.3可行性分析</b></p><p> ?。?)MySQL Cluster 是一種技

20、術(shù),該技術(shù)允許在無共享的系統(tǒng)中部署“內(nèi)存中”數(shù)據(jù)庫的 Cluster 。通過無共享體系結(jié)構(gòu),系統(tǒng)能夠使用廉價的硬件,而且對軟硬件無特殊要求。此外,由于每個組件有自己的內(nèi)存和磁盤,不存在單點(diǎn)故障。MySQL Cluster 由一組計(jì)算機(jī)構(gòu)成,每臺計(jì)算機(jī)上均運(yùn)行著多種進(jìn)程,包括MySQL服務(wù)器,NDB Cluster 的數(shù)據(jù)節(jié)點(diǎn),管理服務(wù)器,以及(可能)專門的數(shù)據(jù)訪問程序。</p><p> ?。?)3臺主機(jī)可以通過

21、交換機(jī)連接到一起,只需要在連接前修改主機(jī)的IP地址,安裝好需要安裝的軟件,這三臺主機(jī)同時安裝有ubuntu 11.04 。</p><p> ?。?)在進(jìn)行將5臺安裝有MySQL的主機(jī)搭建成一個集群的時候,只需要用到三臺主機(jī),只需要將其中的兩臺主機(jī)分別作為數(shù)據(jù)節(jié)點(diǎn)和SQL節(jié)點(diǎn)。</p><p>  (4)由于我們安裝的都是虛擬機(jī),可以在其中開啟多臺虛擬系統(tǒng),所以又可以在這兩臺主機(jī)中做出更大

22、的集群,但是出于當(dāng)前計(jì)算機(jī)性能的問題的考慮,實(shí)現(xiàn)一臺主機(jī)跑多個虛擬系統(tǒng)很吃力,所以實(shí)驗(yàn)中我們只做了將3臺安裝MySQL的主機(jī)搭建成一個小的集群。</p><p> ?。?)集群實(shí)現(xiàn)的多種方案</p><p>  <1>MySQL Clustering(ndb-cluster stogare)  MySQL公司以存儲引擎方式提供的高可靠性方案,是事務(wù)安全的,實(shí)時復(fù)制數(shù)據(jù),可用于

23、需要高可靠性及負(fù)載均衡的場合。該方案至少需要三個節(jié)點(diǎn)服務(wù)器才能達(dá)到較好的效果?! 〕杀荆骸 ?1) 節(jié)點(diǎn)服務(wù)器對RAM的需求很大,與數(shù)據(jù)庫大小呈線性比例;  (2) 最好使用千兆以太網(wǎng)絡(luò);  (3) 還需要使用Dolphin公司提供的昂貴的SCI卡。  優(yōu)點(diǎn):  (1) 可用于負(fù)載均衡場合;  (2) 可用于高可靠性場合;  (3) 高伸縮性;  (4) 真正的數(shù)據(jù)庫冗余;  (5) 容易維護(hù)。  缺點(diǎn):  (1

24、) 隨著數(shù)據(jù)庫的變大,對RAM的需求變得更大,因此成本很高;  速度:  (1) 幾乎比典型的單獨(dú)服務(wù)器(無千兆以太網(wǎng),無SCI卡,存儲引擎相關(guān)的 限制少)慢10倍?! ?yīng)用場合:  (1) 冗余,高可靠性,負(fù)載均衡<2>MySQL / GFS-GNBD/ HA (Active/Passive)  GFS是事務(wù)安全的文件系統(tǒng)。同一時刻可以讓一個MySQL使用共享數(shù)據(jù)。  成</p><p&

25、gt;  MySQL Cluster (集群)基本原理MySQL簇概述</p><p>  MySQL簇是一種技術(shù),該技術(shù)允許在無共享的系統(tǒng)中部署“內(nèi)存中”數(shù)據(jù)庫的簇。通過無共享體系結(jié)構(gòu),系統(tǒng)能夠使用廉價的硬件,而且對軟硬件無特殊要求。此外,由于每個組件有自己的內(nèi)存和磁盤,不存在單點(diǎn)故障。</p><p>  MySQL簇將標(biāo)準(zhǔn)的MySQL服務(wù)器與名為NDB的“內(nèi)存中”簇式存儲引擎集成了起

26、來。在我們的文檔中,術(shù)語NDB指的是與存儲引擎相關(guān)的設(shè)置部分,而術(shù)語“MySQL簇”指的是MySQL和NDB存儲引擎的組合。</p><p>  MySQL簇由一組計(jì)算機(jī)構(gòu)成,每臺計(jì)算機(jī)上均運(yùn)行著多種進(jìn)程,包括MySQL服務(wù)器,NDB簇的數(shù)據(jù)節(jié)點(diǎn),管理服務(wù)器,以及(可能)專門的數(shù)據(jù)訪問程序。關(guān)于簇中這些組件的關(guān)系,參見下圖:</p><p>  application</p>

27、<p>  NDB是一種“內(nèi)存中”存儲引擎,它具有可用性高和數(shù)據(jù)一致性好的特點(diǎn)。</p><p>  能夠使用多種故障切換和負(fù)載平衡選項(xiàng)配置NDB存儲引擎,但以簇層面上的存儲引擎開始最簡單。MySQL簇的NDB存儲引擎包含完整的數(shù)據(jù)集,僅取決于簇本身內(nèi)的其他數(shù)據(jù)。</p><p>  在最低的MySQL簇配置中,至少有三個節(jié)點(diǎn),這三類節(jié)點(diǎn)分別是:</p><

28、p>  <1>管理(MGM)節(jié)點(diǎn):這類節(jié)點(diǎn)的作用是管理MySQL簇內(nèi)的其他節(jié)點(diǎn),如提供配置數(shù)據(jù)、啟動并停止節(jié)點(diǎn)、運(yùn)行備份等。由于這類節(jié)點(diǎn)負(fù)責(zé)管理其他節(jié)點(diǎn)的配置,應(yīng)在啟動其他節(jié)點(diǎn)之前首先啟動這類節(jié)點(diǎn)。MGM節(jié)點(diǎn)是用命令ndb_mgmd啟動的。</p><p>  <2> 數(shù)據(jù)節(jié)點(diǎn):這類節(jié)點(diǎn)用于保存簇的數(shù)據(jù)。數(shù)據(jù)節(jié)點(diǎn)的數(shù)目與副本的數(shù)目相關(guān),是片段的倍數(shù)。例如,對于兩個副本,每個副本有兩個

29、片段,那么就有4個數(shù)據(jù)節(jié)點(diǎn)。沒有必要有一個以上的副本。數(shù)據(jù)節(jié)點(diǎn)是用命令ndbd啟動的。</p><p>  <3> SQL節(jié)點(diǎn):這是用來訪問簇數(shù)據(jù)的節(jié)點(diǎn)。對于MySQL簇,客戶端節(jié)點(diǎn)是使用NDB簇存儲引擎的傳統(tǒng)MySQL服務(wù)器。典型情況下,SQL節(jié)點(diǎn)是使用命令mysqld –ndbcluster啟動的,或?qū)dbcluster添加到my.cnf后使用mysqld啟動。簇配置包括對簇中單獨(dú)節(jié)點(diǎn)的配置,以

30、及設(shè)置節(jié)點(diǎn)之間的單獨(dú)通信鏈路。對于目前設(shè)計(jì)MySQL簇,其意圖在于,從處理器的能力、內(nèi)存空間和帶寬來講,存儲節(jié)點(diǎn)是同質(zhì)的,此外,為了提供單一的配置點(diǎn),作為整體,簇的所有配置數(shù)據(jù)均位于1個配置文件中。</p><p><b>  4. 研究報告</b></p><p><b>  4.1 規(guī)劃階段</b></p><p> 

31、 計(jì)劃建立有5個節(jié)點(diǎn)的MySQL CLuster體系,在這里將兩個SQL節(jié)點(diǎn)和數(shù)據(jù)節(jié)點(diǎn)裝在一起,因此需要用到3臺機(jī)器,具體分配如下表:</p><p>  4.2 安裝Mysql server </p><p>  $wget http://dev.mysql.com/get/Downloads/MySQL-5.1/mysql-5.1.59.tar.gz/from/http://mysql

32、.cs.pu.edu.tw/</p><p>  $tar -xzvf mysql-5.1.59.tar.gz</p><p>  $cd mysql-5.1.59</p><p>  $./configure --with-charset=utf8 --with-collation=utf8_bin --with-extra-</p><p&g

33、t;  charsets=gbk,gb2312,big5,utf8,binary,ascii --prefix=/usr/local/mysql --with-plugins=partition,ndbcluster</p><p><b>  $make </b></p><p>  $make install</p><p>  4.3

34、安裝Mysql Cluster</p><p><b>  $wget </b></p><p>  http://dev.mysql.com/get/Downloads/MySQL-Cluster-7. 1/mysql-cluster-</p><p>  gpl-7.1.15a-linux-x86_64-glibc23.tar.gz/fro

35、m/http://mysql.ntu.edu.tw/</p><p>  $tar -xzvf mysql-cluster-gpl-7.1.15a-linux-x86_64-glibc23.tar.gz</p><p>  $mv mysql-cluster-gpl-7.1.15a-linux-x86_64-glibc23.tar.gz</p><p>  /usr

36、/local/mysql-cluster</p><p>  $cd /usr/local/mysql-cluster</p><p>  $groupadd mysql</p><p>  $useradd -g mysql mysql </p><p>  $passwd mysql </p><p>  $cd

37、/usr/local/mysql-cluster</p><p>  $chown -R mysql:mysql . </p><p>  $scripts/mysql_install_db --user=mysql </p><p>  $cp -rp bin/ndb* /usr/local/bin/</p><p>  4.4 配置管理節(jié)

38、點(diǎn)</p><p>  $cp support-files/ndb-config-2-node.ini /etc/ndb_mgmd.ini</p><p>  $vi /etc/ndb_mgmd.ini</p><p>  [ndbd default]</p><p>  NoOfReplicas= 2</p><p>

39、;  MaxNoOfConcurrentOperations= 10000</p><p>  DataMemory= 80M</p><p>  IndexMemory= 24M</p><p>  TimeBetweenWatchDogCheck= 30000</p><p>  DataDir= /usr/local/mysql-clu

40、ster/data</p><p>  MaxNoOfOrderedIndexes= 512</p><p>  #設(shè)置管理節(jié)點(diǎn)服務(wù)器</p><p>  [ndb_mgmd default]</p><p>  DataDir= /usr/local/mysql-cluster/data #MGM上保存日志的目錄</p>&l

41、t;p>  [ndb_mgmd]</p><p><b>  Id=1</b></p><p>  HostName= 10.0.31.49</p><p>  #設(shè)置存儲節(jié)點(diǎn)服務(wù)器(NDB節(jié)點(diǎn))</p><p><b>  [ndbd] </b></p><p>&l

42、t;b>  Id= 2</b></p><p>  HostName= 10.0.31.40</p><p>  DataDir=/usr/local/mysql-cluster/data</p><p><b>  [ndbd]</b></p><p><b>  Id= 3</b&g

43、t;</p><p>  HostName= 10.0.31.41</p><p>  DataDir=/usr/local/mysql-cluster/data</p><p>  #設(shè)置SQL節(jié)點(diǎn)服務(wù)器</p><p><b>  [mysqld]</b></p><p><b> 

44、 Id= 5</b></p><p>  HostName= 10.0.31.40</p><p>  [mysqld]#第二個SQL節(jié)點(diǎn)</p><p><b>  Id= 6</b></p><p>  HostName= 10.0.31.41</p><p>  # 選擇一個未使

45、用的端口</p><p>  [tcp default]</p><p>  PortNumber= 63132</p><p>  4.5 配置SQL節(jié)點(diǎn)</p><p><b>  [mysqld]</b></p><p>  basedir = /usr/local/mysql/</p

46、><p>  datadir = /usr/local/mysql/data</p><p>  user = mysql</p><p>  port = 3306</p><p>  socket = /tmp/mysql.sock</p><p>  ndbcluster</p><p>  

47、ndb-connectstring=10.0.31.40</p><p>  [MYSQL_CLUSTER]</p><p>  ndb-connectstring=10.0.31.41</p><p>  4.6 配置存儲節(jié)點(diǎn)(NDB節(jié)點(diǎn))</p><p>  $vi /etc/ndbd.cnf</p><p>  

48、[mysqld]ndbclusterDataDir=/usr/local/mysql-cluster/data[MYSQL_CLUSTER]ndb-connectstring=nodeid=192.168.0.55</p><p>  4.7 啟動MySQL Cluster</p><p>  首先啟動管理節(jié)點(diǎn)服務(wù)器,然后啟動存儲節(jié)點(diǎn)服務(wù)器,最后才啟動SQL節(jié)點(diǎn)服務(wù)器: </

49、p><p> ?。?)在管理節(jié)點(diǎn)服務(wù)器上,執(zhí)行以下命令啟動MGM節(jié)點(diǎn)進(jìn)程:</p><p>  $/usr/local/bin/ndb_mgmd -f /etc/ndb_mgmd.ini --configdir=/usr/local/mysq</p><p><b>  l-cluster</b></p><p>  $n

50、etstat -ntpl |grep ndb #檢查是否成功</p><p>  (2)在每臺存儲節(jié)點(diǎn)服務(wù)器上,先執(zhí)行以下命令:</p><p>  $/usr/local/bin/ndbd --initial --defaults-file=/etc/ndbd.cnf</p><p> ?。?)運(yùn)行以下命令啟動SQL節(jié)點(diǎn)服務(wù)器:</p><p&

51、gt;  $mysqld_safe --defaults-file=/etc/my.cnf &</p><p>  4.8 關(guān)閉MySQL Cluster</p><p>  在MGM節(jié)點(diǎn)所在的機(jī)器上, Shell中簡單地輸入下述命令用來關(guān)閉Cluster:</p><p>  $/usr/local/bin/ndb_mgm -e shutdown</

52、p><p>  運(yùn)行以下命令關(guān)閉SQL節(jié)點(diǎn)的mysqld服務(wù):</p><p>  $/usr/local/bin/mysqladmin -uroot shutdown</p><p><b>  4.9 數(shù)據(jù)測試</b></p><p>  (1)在主節(jié)點(diǎn)上新建一個數(shù)據(jù)庫ClusterTest,新建數(shù)據(jù)表user,插入一行

53、數(shù)據(jù)</p><p>  mysql> create database ClusterTest</p><p>  mysql> use ClusterTest</p><p>  mysql> create table user(nu mint , name varchar(50) engine=NDB);</p><p>

54、;  mysql> select * from user;</p><p> ?。?)在非主節(jié)點(diǎn)上查看數(shù)據(jù)同步情況</p><p>  mysql> use ClusterTest</p><p>  mysql> select * from user;</p><p>  (3)在非主節(jié)點(diǎn)上新建一個數(shù)據(jù)庫ClusterTe

55、st,新建數(shù)據(jù)表user,插入一行數(shù)據(jù)</p><p>  mysql> create database ClusterTest</p><p>  mysql> use ClusterTest</p><p>  mysql> create table user(nu mint , name varchar(50) engine=NDB);<

56、;/p><p>  mysql> select * from user;</p><p>  (4)在主節(jié)點(diǎn)上查看數(shù)據(jù)同步情況</p><p>  mysql> use ClusterTest</p><p>  mysql> select * from user;</p><p><b>  

57、4.10安全關(guān)閉</b></p><p>  要想關(guān)閉 Cluster,可在MGM節(jié)點(diǎn)所在的機(jī)器上,在Shell中簡單地輸入下述命令:</p><p>  [db1~]root# /usr/local/mysql/ndb_mgm -e shutdown</p><p>  運(yùn)行以下命令關(guān)閉SQL節(jié)點(diǎn)的mysqld服務(wù):</p><p&

58、gt;  [db2~]root# /usr/local/mysql/bin/mysqladmin -uroot shutdown</p><p>  5. 測試報告/實(shí)驗(yàn)報告</p><p><b>  實(shí)驗(yàn)報告</b></p><p>  (1)下載mysql-cluster-gpl-7.1.22-linux-x86_64-glibc 23.

59、tar.gz安裝包,選擇服務(wù)器架構(gòu)類型。</p><p> ?。?)建立mysql用戶組和mysql用戶:#groupadd mysql && useradd mysql -g mysql(3)解壓壓縮包并重命名:</p><p>  #tar zxvf mysql-cluster-gpl-7.1.22-linux-x86_64-glibc 23.tar.gz</

60、p><p>  #mv mysql-cluster-gpl-7.1.22-linux-x86_64-glibc 23 mysqlc</p><p>  (4)進(jìn)入mysqlc目錄創(chuàng)建logs目錄并更改mysqlc目錄的所有者</p><p>  #cd mysqlc && mkdir logs</p><p>  #cd ..

61、 && chown -R mysql:mysql mysqlc</p><p><b>  截圖如下: </b></p><p> ?。?)建系統(tǒng)相關(guān)數(shù)據(jù)庫以及表</p><p>  #scripts/mysql_install_db --user=mysql</p><p><b> ?。?)

62、配置管理節(jié)點(diǎn)</b></p><p>  #mkdir /var/lib/mysql-cluster && cd /var/lib/mysql-cluster</p><p>  # vim /var/lib/mysql-cluster/config.ini</p><p><b>  保存并退回出</b></

63、p><p><b>  截圖如下:</b></p><p>  (7)安裝配置數(shù)據(jù)節(jié)點(diǎn)</p><p>  復(fù)制管理節(jié)點(diǎn)上的mysqlc整個目錄到數(shù)據(jù)節(jié)點(diǎn)1上的/usr/local目錄,重命名為mysql,確保mysql目錄的所屬用戶和組為mysql。</p><p>  復(fù)制配置文件和啟動腳本</p><

64、;p>  #cp support-files/my-medium.cnf /etc /my.cnf</p><p>  #cp support-files/mysql.server /etc /init.d/mysqld</p><p><b>  編輯配置文件</b></p><p>  #vim /etc /my.cnf</p&

65、gt;<p>  增加[mysqld]下面的配置項(xiàng)</p><p>  保存后退出,在數(shù)據(jù)節(jié)點(diǎn)2上進(jìn)行相同操作。</p><p><b>  截圖如下:</b></p><p><b> ?。?)啟動管理節(jié)點(diǎn)</b></p><p><b>  (9)啟動數(shù)據(jù)節(jié)點(diǎn)</b

66、></p><p> ?。?0)啟動SQL節(jié)點(diǎn)</p><p>  (11)在管理端查看集群當(dāng)前狀態(tài)</p><p> ?。?2)在節(jié)點(diǎn)2上啟動數(shù)據(jù)節(jié)點(diǎn)和SQL節(jié)點(diǎn)</p><p><b>  測試報告</b></p><p>  主節(jié)點(diǎn)上創(chuàng)建ClusterTest數(shù)據(jù)庫,user數(shù)據(jù)表,插

67、入一條數(shù)據(jù)。</p><p>  在非主節(jié)點(diǎn)上查看數(shù)據(jù)同步情況: </p><p>  在非主節(jié)點(diǎn)上更新數(shù)據(jù)</p><p>  查看主節(jié)點(diǎn)上數(shù)據(jù)同步情況</p><p><b>  6. 課題研究結(jié)論</b></p><p>  MySQL Cluster 由一組計(jì)算機(jī)構(gòu)成,每臺計(jì)算機(jī)上均運(yùn)行著

68、多種進(jìn)程,包括MySQL服務(wù)器,NDB Cluster 的數(shù)據(jù)節(jié)點(diǎn),管理服務(wù)器,以及(可能)專門的數(shù)據(jù)訪問程序。</p><p>  MySQL Cluster 是MySQL適合于分布式計(jì)算環(huán)境的高實(shí)用、高冗余版本。MySQL Cluster 能夠使用多種故障切換和負(fù)載平衡選項(xiàng)配置NDB存儲引擎,但在 Cluster 級別上的存儲引擎上做這個最簡單。MySQL Cluster的NDB存儲引擎包含完整的數(shù)據(jù)集,僅取

69、決于 Cluster本身內(nèi)的其他數(shù)據(jù)。在課程設(shè)計(jì)中實(shí)現(xiàn)了對一臺計(jì)算機(jī)上進(jìn)行創(chuàng)建數(shù)據(jù)庫、新建數(shù)據(jù)表、插入數(shù)據(jù),在其他計(jì)算機(jī)上均能查看這些信息的功能 。</p><p>  采用Linux系統(tǒng),可以提高客戶工作站運(yùn)行的可靠性和穩(wěn)定性,獲得高可用性服務(wù)器。在Linux系統(tǒng)下一種雙機(jī)互備份工作方式的MySQL數(shù)據(jù)庫集群的具體實(shí)現(xiàn)方案,實(shí)現(xiàn)了高可用性集群服務(wù)器。兩個相對獨(dú)立的應(yīng)用在兩臺機(jī)器同時運(yùn)行,但彼此均設(shè)為備份機(jī),當(dāng)某

70、一臺服務(wù)器出現(xiàn)故障時,另一臺服務(wù)器可以在短時間內(nèi)將故障服務(wù)器的應(yīng)用接管過來,從而保證了應(yīng)用的持續(xù)性。</p><p><b>  7. 總結(jié)</b></p><p>  隨著網(wǎng)絡(luò)技術(shù)的飛速發(fā)展,傳統(tǒng)的服務(wù)器體系結(jié)構(gòu)愈來愈不適應(yīng)當(dāng)前的需求,集群技術(shù)以其獨(dú)特的優(yōu)點(diǎn)很好地適應(yīng)了當(dāng)前網(wǎng)絡(luò)發(fā)展的需要。而Linux以其開源代碼模式成為當(dāng)前集群研究的熱點(diǎn),本文正是基于這一點(diǎn),介紹了

71、MySQL集群的基本概念及其實(shí)現(xiàn)方式,依靠集群文件系統(tǒng)實(shí)現(xiàn)對系統(tǒng)中的所有文件、設(shè)備和網(wǎng)絡(luò)資源的全局訪問,突破了數(shù)據(jù)庫容量的瓶頸限制。開源數(shù)據(jù)庫開發(fā)商MySQL公司在2007 MySQL大會上宣布了最新的MySQL Cluster Carrier Grade Edition數(shù)據(jù)庫DBT2基準(zhǔn)測試結(jié)果。該基準(zhǔn)測試結(jié)果顯示了MySQL Cluster Carrier Grade Edition的高擴(kuò)展性,使用8個節(jié)點(diǎn)的Cluster能達(dá)到每分

72、鐘100,000個事務(wù)處理。所以企業(yè)在網(wǎng)絡(luò)規(guī)劃資金欠缺的情況下,用免費(fèi)的MySQL Cluster架設(shè)數(shù)據(jù)庫集群,完全可以滿足大流量的信息處理需求。</p><p>  MySQL數(shù)據(jù)庫有很多優(yōu)點(diǎn)</p><p><b>  擴(kuò)展性和靈活性 </b></p><p>  MySQL數(shù)據(jù)庫服務(wù)器提供非常強(qiáng)大的擴(kuò)展性,可以支持深度嵌入應(yīng)用系統(tǒng),大小

73、只有1MB。也可以支持TB級別的數(shù)據(jù)倉庫。平臺靈活性一直以來是MySQL的特性,MySQL現(xiàn)在支持Linux,UNIX,和Windows。當(dāng)然,MySQL的開源本性允許全面的自定義,這滿足了那些需要添加特殊要求至數(shù)據(jù)庫的需求。 </p><p><b>  高性能 </b></p><p>  獨(dú)特的存儲引擎架構(gòu)使得數(shù)據(jù)庫專業(yè)人員可以為特定的應(yīng)用配置有針對性的MySQ

74、L數(shù)據(jù)庫,由此,可以獲得出人意料的性能結(jié)果。不管應(yīng)用是高速的事務(wù)處理或是每天處理上億查詢大容量web站點(diǎn),MySQL可以滿足任何系統(tǒng)最急需的性能要求。使用高速加載工具,不同的內(nèi)存緩存,全文索引,以及其它的性能加強(qiáng)機(jī)制,MySQL提供了現(xiàn)今關(guān)鍵業(yè)務(wù)系統(tǒng)需要的所有功能和特性。 </p><p><b>  高可用 </b></p><p>  堅(jiān)若磐石的可靠性和持續(xù)的可用

75、性是MySQL的特征,客戶憑借MySQL確保24小時的服務(wù)。MySQL提供各種高可用的方案,高速的主/從復(fù)制配置,特殊集群服務(wù)器提供的即時切換,以及其它第三方供應(yīng)商為MySQL數(shù)據(jù)庫提供的獨(dú)特高可用解決方法。 </p><p><b>  強(qiáng)大的事務(wù)支持 </b></p><p>  MySQL提供一個強(qiáng)大的事務(wù)處理引擎。特性包括完整的ACID(原子性,一致性,隔離性

76、,持久性)事務(wù)支持,不限制的行級鎖,分布式事務(wù)能力,多版本事務(wù)支持。另外,也確保數(shù)據(jù)完整性,方法是通過服務(wù)器強(qiáng)制的引用完整性,特殊事務(wù)隔離級別,即時死鎖檢測。 </p><p>  Web和數(shù)據(jù)倉庫能力 </p><p>  MySQL事實(shí)上可用于高速web站點(diǎn),因?yàn)樗邆涓咝阅艿牟樵円妫罅靠焖贁?shù)據(jù)插入能力,有力地支持特定web方法如全文搜索。這些特性同樣適用于數(shù)據(jù)倉庫環(huán)境,這里的My

77、SQL擴(kuò)展至可以容納T級別的數(shù)據(jù)年。其它的特性,如內(nèi)存表,B-樹索引和hash索引,以及高達(dá)80%壓縮率的壓縮表。使得MySQL完全可以用于web站點(diǎn)和商業(yè)智能應(yīng)用。 </p><p><b>  強(qiáng)大的數(shù)據(jù)保護(hù) </b></p><p>  保障公司數(shù)據(jù)資產(chǎn)安全是數(shù)據(jù)庫管理員的日常工作之一。MySQL提供超乎尋常的安全特性,可以確保絕對的數(shù)據(jù)安全。在數(shù)據(jù)庫安全認(rèn)證方

78、面,MySQL提供有力機(jī)制以確保只有授機(jī)用戶可以訪問數(shù)據(jù)庫服務(wù)器,這樣就可以有能力將用戶阻止在客戶端機(jī)器的一層。SSH和SLL的支持確保了連接的安全與可靠。粒度對象權(quán)限框架保證了用戶可能看到他們被許可看的,強(qiáng)大的數(shù)據(jù)加密和解密功能確保了敏感數(shù)據(jù)不被未授權(quán)的查看。最后,MySQL和其它第三方軟件提供商提供的備份和恢復(fù)工具允許完全的邏輯與物理備份以及按時間點(diǎn)恢復(fù)。 </p><p><b>  全面的應(yīng)用開

79、發(fā) </b></p><p>  MySQL之所以成為全球最流行的開源數(shù)據(jù)庫的原因之一是它針對每一個應(yīng)用開發(fā)提供全面的支持。在數(shù)據(jù)庫里,支持包括存儲過程,觸發(fā)器,函數(shù),視圖,游標(biāo),ANSI標(biāo)準(zhǔn)SQL,以及更多。對于嵌入式應(yīng)用,可以使用嵌入式MySQL的插件庫,幾乎支持任意應(yīng)用。MySQL提供連接器和驅(qū)動(ODBC,JDBC,等等)。這使得各種應(yīng)用程序都可以使用MySQL作為首選的數(shù)據(jù)庫管理服務(wù)器。不管

80、是,PHP, Perl, Java, Visual Basic, 還是 .NET,MySQL都可滿足應(yīng)用開發(fā)人員成功構(gòu)建數(shù)據(jù)庫驅(qū)動信息系統(tǒng)的需求。 </p><p><b>  管理方便 </b></p><p>  MySQL有著異乎尋常的快速部署能力。軟件從下載到安裝完成平均時間少于是15分鐘。對于以下任意平臺都是: Microsoft Windows, Linu

81、x, Macintosh, 或是 UNIX。一旦安裝,自管理特性,比如自動空間增長,自動重啟,以及動態(tài)改變配置為數(shù)據(jù)庫管理員大大減少了壓力。MySQL提供了一套圖形化管理和遷移工具,使得DBA可以管理,解決問題,以及從一個單一的工作臺控制多個MySQL服務(wù)器。許多第三方的軟件供應(yīng)商提供工具,可以讓DBA進(jìn)行數(shù)據(jù)設(shè)計(jì)和ETL,完成數(shù)據(jù)庫管理工作,任務(wù)管理,性能監(jiān)控。</p><p>  開源自由和24*7支持 &l

82、t;/p><p>  很多公司對于是否完全采用開源軟件還持懷疑態(tài)度。因?yàn)樗麄冋J(rèn)為使用MySQL不可能會得到他們當(dāng)前依賴的商業(yè)服務(wù)對關(guān)鍵業(yè)務(wù)提供的支持。事實(shí)上,這些懷疑是完全沒有必要的,MySQL企業(yè)版提供一天24小時的支持。MySQL不是一個典型的開源項(xiàng)目,因?yàn)槠淙康能浖际怯蒓racle所有,正因?yàn)槿绱?,存在一個特殊的付費(fèi)和支持模型,使得存在一個自由開源和得到支持受信軟件的結(jié)合體。 </p><

83、;p>  最低的總體擁有成本 </p><p>  將當(dāng)前數(shù)據(jù)庫驅(qū)動的應(yīng)用程序遷移至MySQL,或是在新的開發(fā)項(xiàng)目中使用MySQL,公司將可以體會到成本大大的降低了。將MySQL數(shù)據(jù)庫服務(wù)器和使用廉價硬件擴(kuò)展架構(gòu)相結(jié)合,公司可以發(fā)現(xiàn)可以獲得超乎想象的擴(kuò)展性和性能,所有的這些花費(fèi)遠(yuǎn)遠(yuǎn)少于使用水平擴(kuò)展的方式。另外,可靠性和易維護(hù)性意味著MySQL可以讓數(shù)據(jù)庫管理員不用在解決性能問題或是宕機(jī)時間上耗費(fèi)時間,而只需

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論